HID: amd_sfh: Add NULL check for hid device
authorBasavaraj Natikar <Basavaraj.Natikar@amd.com>
Tue, 12 Jul 2022 18:18:26 +0000 (23:48 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 17 Aug 2022 12:23:56 +0000 (14:23 +0200)
[ Upstream commit 06aa2a43c307cf4096f422dcb575e5d2913e528f ]

On removal of hid device during SFH set report may cause NULL pointer
exception. Hence add NULL check for hid device before accessing.

Fixes: 4b2c53d93a4b ("SFH:Transport Driver to add support of AMD Sensor Fusion Hub (SFH)")
Signed-off-by: Basavaraj Natikar <Basavaraj.Natikar@amd.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/hid/amd-sfh-hid/amd_sfh_hid.c

index a4bda2ac713e9acc01c0f62f87030187e3762fca..3b0615c6aecff212b8309287c37bf2ec3484bf32 100644 (file)
@@ -98,11 +98,15 @@ static int amdtp_wait_for_response(struct hid_device *hid)
 
 void amdtp_hid_wakeup(struct hid_device *hid)
 {
-       struct amdtp_hid_data *hid_data = hid->driver_data;
-       struct amdtp_cl_data *cli_data = hid_data->cli_data;
+       struct amdtp_hid_data *hid_data;
+       struct amdtp_cl_data *cli_data;
 
-       cli_data->request_done[cli_data->cur_hid_dev] = true;
-       wake_up_interruptible(&hid_data->hid_wait);
+       if (hid) {
+               hid_data = hid->driver_data;
+               cli_data = hid_data->cli_data;
+               cli_data->request_done[cli_data->cur_hid_dev] = true;
+               wake_up_interruptible(&hid_data->hid_wait);
+       }
 }
 
 static struct hid_ll_driver amdtp_hid_ll_driver = {