Commit 97f09cb5 authored by Anssi Hannula's avatar Anssi Hannula Committed by Dmitry Torokhov

Input: xpad - fix inverted Y and RY axes

The commit ae91d10a inverted Y and RY
axes on xbox360 so that up is positive and down is negative.
This is wrong, as axes on game controllers have up as negative per
convention. Also, even xpad itself reports HAT0X with up as negative.

Fix that by inverting them again.

Also, according to http://bugzilla.kernel.org/show_bug.cgi?id=10337 the
original xbox controllers also have the Y and RY axes inverted.
Fix that by inverting them as well.

Cc: Brian Magnuson <bdmagnuson@gmail.com>
Signed-off-by: default avatarAnssi Hannula <anssi.hannula@gmail.com>
Signed-off-by: default avatarDmitry Torokhov <dtor@mail.ru>
parent a0979923
...@@ -236,13 +236,13 @@ static void xpad_process_packet(struct usb_xpad *xpad, u16 cmd, unsigned char *d ...@@ -236,13 +236,13 @@ static void xpad_process_packet(struct usb_xpad *xpad, u16 cmd, unsigned char *d
input_report_abs(dev, ABS_X, input_report_abs(dev, ABS_X,
(__s16) le16_to_cpup((__le16 *)(data + 12))); (__s16) le16_to_cpup((__le16 *)(data + 12)));
input_report_abs(dev, ABS_Y, input_report_abs(dev, ABS_Y,
(__s16) le16_to_cpup((__le16 *)(data + 14))); ~(__s16) le16_to_cpup((__le16 *)(data + 14)));
/* right stick */ /* right stick */
input_report_abs(dev, ABS_RX, input_report_abs(dev, ABS_RX,
(__s16) le16_to_cpup((__le16 *)(data + 16))); (__s16) le16_to_cpup((__le16 *)(data + 16)));
input_report_abs(dev, ABS_RY, input_report_abs(dev, ABS_RY,
(__s16) le16_to_cpup((__le16 *)(data + 18))); ~(__s16) le16_to_cpup((__le16 *)(data + 18)));
/* triggers left/right */ /* triggers left/right */
input_report_abs(dev, ABS_Z, data[10]); input_report_abs(dev, ABS_Z, data[10]);
...@@ -330,13 +330,13 @@ static void xpad360_process_packet(struct usb_xpad *xpad, ...@@ -330,13 +330,13 @@ static void xpad360_process_packet(struct usb_xpad *xpad,
input_report_abs(dev, ABS_X, input_report_abs(dev, ABS_X,
(__s16) le16_to_cpup((__le16 *)(data + 6))); (__s16) le16_to_cpup((__le16 *)(data + 6)));
input_report_abs(dev, ABS_Y, input_report_abs(dev, ABS_Y,
(__s16) le16_to_cpup((__le16 *)(data + 8))); ~(__s16) le16_to_cpup((__le16 *)(data + 8)));
/* right stick */ /* right stick */
input_report_abs(dev, ABS_RX, input_report_abs(dev, ABS_RX,
(__s16) le16_to_cpup((__le16 *)(data + 10))); (__s16) le16_to_cpup((__le16 *)(data + 10)));
input_report_abs(dev, ABS_RY, input_report_abs(dev, ABS_RY,
(__s16) le16_to_cpup((__le16 *)(data + 12))); ~(__s16) le16_to_cpup((__le16 *)(data + 12)));
/* triggers left/right */ /* triggers left/right */
input_report_abs(dev, ABS_Z, data[4]); input_report_abs(dev, ABS_Z, data[4]);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment