HID: sensor-hub: Move the memset to sensor_hub_get_feature()
While applying patchd443a0aa3a
: "HID: hid-sensor-hub: clear memory to avoid random data", there was some issues in applying correct version of the patch. This resulted in the breakage of sensor functions as all request like power-up will be reset by the memset() in the function sensor_hub_set_feature(). The reset of caller buffer should be in the function sensor_hub_get_feature(), not in the sensor_hub_set_feature(). Fixes:d443a0aa3a
("HID: hid-sensor-hub: clear memory to avoid random data") Cc: Stable <stable@vger.kernel.org> # 4.9+ Signed-off-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
This commit is contained in:
parent
8aa2cc7e74
commit
143fca77cc
1 changed files with 2 additions and 1 deletions
|
@ -212,7 +212,6 @@ int sensor_hub_set_feature(struct hid_sensor_hub_device *hsdev, u32 report_id,
|
||||||
__s32 value;
|
__s32 value;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
memset(buffer, 0, buffer_size);
|
|
||||||
mutex_lock(&data->mutex);
|
mutex_lock(&data->mutex);
|
||||||
report = sensor_hub_report(report_id, hsdev->hdev, HID_FEATURE_REPORT);
|
report = sensor_hub_report(report_id, hsdev->hdev, HID_FEATURE_REPORT);
|
||||||
if (!report || (field_index >= report->maxfield)) {
|
if (!report || (field_index >= report->maxfield)) {
|
||||||
|
@ -256,6 +255,8 @@ int sensor_hub_get_feature(struct hid_sensor_hub_device *hsdev, u32 report_id,
|
||||||
int buffer_index = 0;
|
int buffer_index = 0;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
memset(buffer, 0, buffer_size);
|
||||||
|
|
||||||
mutex_lock(&data->mutex);
|
mutex_lock(&data->mutex);
|
||||||
report = sensor_hub_report(report_id, hsdev->hdev, HID_FEATURE_REPORT);
|
report = sensor_hub_report(report_id, hsdev->hdev, HID_FEATURE_REPORT);
|
||||||
if (!report || (field_index >= report->maxfield) ||
|
if (!report || (field_index >= report->maxfield) ||
|
||||||
|
|
Loading…
Reference in a new issue