You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gentoo-overlay/dev-libs/libg15/files/g15tools.patch

101 lines
2.9 KiB

Patch from upstream bug tracker:
http://sourceforge.net/tracker/?func=detail&aid=3336448&group_id=167869&atid=844658
As only part of G510 support was merged to upstream. Does NOT apply & compile
on top of 1.2.7-r1.
diff -aNru trunk/libg15/libg15.c mod/libg15/libg15.c
--- trunk/libg15/libg15.c 2011-03-31 23:33:44.000000000 +0000
+++ mod/libg15/libg15.c 2011-06-26 07:08:21.000000000 +0000
@@ -1029,6 +1029,76 @@
}
}
+// Logitech G510 Media Keys implementation. Unknown if this will work for other
+// models. Using the backlight key as a modifier. The assumption is you would
+// normally not be holding down the backlight key while pressing G-keys.
+static void processKeyEvent2Byte(unsigned int *pressed_keys, unsigned char *buffer)
+{
+ // Key modifier
+ *pressed_keys |= G15_KEY_LIGHT;
+
+ // XF86AudioPlay
+ if (*pressed_keys & G15_KEY_G1)
+ *pressed_keys -= G15_KEY_G1;
+
+ // XF86AudioStop
+ if (*pressed_keys & G15_KEY_G2)
+ *pressed_keys -= G15_KEY_G2;
+
+ // XF86AudioPrev
+ if (*pressed_keys & G15_KEY_G3)
+ *pressed_keys -= G15_KEY_G3;
+
+ // XF86AudioNext
+ if (*pressed_keys & G15_KEY_G4)
+ *pressed_keys -= G15_KEY_G4;
+
+ // XF86AudioMute
+ if (*pressed_keys & G15_KEY_G5)
+ *pressed_keys -= G15_KEY_G5;
+
+ // XF86AudioRaiseVolume
+ if (*pressed_keys & G15_KEY_G6)
+ *pressed_keys -= G15_KEY_G6;
+
+ // XF86AudioLowerVolume
+ if (*pressed_keys & G15_KEY_G7)
+ *pressed_keys -= G15_KEY_G7;
+
+ g15_log(stderr,G15_LOG_WARN,"Keyboard: %x, %x\n", buffer[0], buffer[1]);
+
+ if (buffer[0] == 0x02)
+ {
+ // XF86AudioPlay
+ if (buffer[1] & 0x08)
+ *pressed_keys |= G15_KEY_G1;
+
+ // XF86AudioStop
+ if (buffer[1] & 0x04)
+ *pressed_keys |= G15_KEY_G2;
+
+ // XF86AudioPrev
+ if (buffer[1] & 0x02)
+ *pressed_keys |= G15_KEY_G3;
+
+ // XF86AudioNext
+ if (buffer[1] & 0x01)
+ *pressed_keys |= G15_KEY_G4;
+
+ // XF86AudioMute
+ if (buffer[1] & 0x16)
+ *pressed_keys |= G15_KEY_G5;
+
+ // XF86AudioRaiseVolume
+ if (buffer[1] & 0x32)
+ *pressed_keys |= G15_KEY_G6;
+
+ // XF86AudioLowerVolume
+ if (buffer[1] & 0x64)
+ *pressed_keys |= G15_KEY_G7;
+ }
+}
+
int getPressedKeys(unsigned int *pressed_keys, unsigned int timeout)
{
unsigned char buffer[G15_KEY_READ_LENGTH];
@@ -1063,6 +1133,13 @@
case 9:
processKeyEvent9Byte(pressed_keys, buffer);
return G15_NO_ERROR;
+ case 2:
+ if (g15DeviceCapabilities() & G15_DEVICE_G510)
+ {
+ processKeyEvent2Byte(pressed_keys, buffer);
+ return G15_NO_ERROR;
+ }
+ // Deliberate fallthrough
default:
return handle_usb_errors("Keyboard Read", ret); /* allow the app to deal with errors */
}