iio: hid-sensor-rotation: Fix quaternion data not correct
authorYe Xiang <xiang.ye@intel.com>
Sat, 30 Jan 2021 10:25:46 +0000 (18:25 +0800)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Thu, 11 Mar 2021 20:46:56 +0000 (20:46 +0000)
Because the data of HID_USAGE_SENSOR_ORIENT_QUATERNION defined by ISH FW
is s16, but quaternion data type is in_rot_quaternion_type(le:s16/32X4>>0),
need to transform data type from s16 to s32

May require manual backporting.

Fixes: fc18dddc0625 ("iio: hid-sensors: Added device rotation support")
Signed-off-by: Ye Xiang <xiang.ye@intel.com>
Link: https://lore.kernel.org/r/20210130102546.31397-1-xiang.ye@intel.com
Cc: <Stable@vger.kernel.org>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
drivers/iio/orientation/hid-sensor-rotation.c

index 18e4ef0600963cee30c556e124a03a48c491b7ff..c087d8f72a5464835c659540a60cb3e717bb5933 100644 (file)
@@ -21,7 +21,7 @@ struct dev_rot_state {
        struct hid_sensor_common common_attributes;
        struct hid_sensor_hub_attribute_info quaternion;
        struct {
-               u32 sampled_vals[4] __aligned(16);
+               s32 sampled_vals[4] __aligned(16);
                u64 timestamp __aligned(8);
        } scan;
        int scale_pre_decml;
@@ -170,8 +170,15 @@ static int dev_rot_capture_sample(struct hid_sensor_hub_device *hsdev,
        struct dev_rot_state *rot_state = iio_priv(indio_dev);
 
        if (usage_id == HID_USAGE_SENSOR_ORIENT_QUATERNION) {
-               memcpy(&rot_state->scan.sampled_vals, raw_data,
-                      sizeof(rot_state->scan.sampled_vals));
+               if (raw_len / 4 == sizeof(s16)) {
+                       rot_state->scan.sampled_vals[0] = ((s16 *)raw_data)[0];
+                       rot_state->scan.sampled_vals[1] = ((s16 *)raw_data)[1];
+                       rot_state->scan.sampled_vals[2] = ((s16 *)raw_data)[2];
+                       rot_state->scan.sampled_vals[3] = ((s16 *)raw_data)[3];
+               } else {
+                       memcpy(&rot_state->scan.sampled_vals, raw_data,
+                              sizeof(rot_state->scan.sampled_vals));
+               }
 
                dev_dbg(&indio_dev->dev, "Recd Quat len:%zu::%zu\n", raw_len,
                        sizeof(rot_state->scan.sampled_vals));