mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-25 07:14:36 +08:00
HID: amd_sfh: Split sensor and HID initialization for SFH1.1
Sensors are enabled independently of HID device initialization. Sensor initialization should be kept separate in this case, while HID devices should be initialized according to the sensor state. Hence split sensor initialization and HID initialization for SFH1.1 into separate blocks. Signed-off-by: Basavaraj Natikar <Basavaraj.Natikar@amd.com> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
This commit is contained in:
parent
c0709c6c9b
commit
19b60accb6
@ -168,16 +168,16 @@ static int amd_sfh1_1_hid_client_init(struct amd_mp2_dev *privdata)
|
|||||||
status = amd_sfh_wait_for_response
|
status = amd_sfh_wait_for_response
|
||||||
(privdata, cl_data->sensor_idx[i], ENABLE_SENSOR);
|
(privdata, cl_data->sensor_idx[i], ENABLE_SENSOR);
|
||||||
|
|
||||||
status = (status == 0) ? SENSOR_ENABLED : SENSOR_DISABLED;
|
cl_data->sensor_sts[i] = (status == 0) ? SENSOR_ENABLED : SENSOR_DISABLED;
|
||||||
|
}
|
||||||
|
|
||||||
if (status == SENSOR_ENABLED) {
|
for (i = 0; i < cl_data->num_hid_devices; i++) {
|
||||||
|
cl_data->cur_hid_dev = i;
|
||||||
|
if (cl_data->sensor_sts[i] == SENSOR_ENABLED) {
|
||||||
cl_data->is_any_sensor_enabled = true;
|
cl_data->is_any_sensor_enabled = true;
|
||||||
cl_data->sensor_sts[i] = SENSOR_ENABLED;
|
|
||||||
rc = amdtp_hid_probe(i, cl_data);
|
rc = amdtp_hid_probe(i, cl_data);
|
||||||
if (rc)
|
if (rc)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
} else {
|
|
||||||
cl_data->sensor_sts[i] = SENSOR_DISABLED;
|
|
||||||
}
|
}
|
||||||
dev_dbg(dev, "sid 0x%x (%s) status 0x%x\n",
|
dev_dbg(dev, "sid 0x%x (%s) status 0x%x\n",
|
||||||
cl_data->sensor_idx[i], get_sensor_name(cl_data->sensor_idx[i]),
|
cl_data->sensor_idx[i], get_sensor_name(cl_data->sensor_idx[i]),
|
||||||
|
Loading…
Reference in New Issue
Block a user