mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-12 23:54:19 +08:00
Input: aiptek - correct the tool switching code
Now the old tool is remembered, and reset when a new tool is selected via the sysfs files. Signed-off-by: Rene van Paassen <rene.vanpaassen@gmail.com> Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
This commit is contained in:
parent
da9fda434c
commit
b3b6cf1d47
@ -218,15 +218,9 @@
|
|||||||
#define AIPTEK_WHEEL_DISABLE (-10101)
|
#define AIPTEK_WHEEL_DISABLE (-10101)
|
||||||
|
|
||||||
/* ToolCode values, which BTW are 0x140 .. 0x14f
|
/* ToolCode values, which BTW are 0x140 .. 0x14f
|
||||||
* We have things set up such that if TOOL_BUTTON_FIRED_BIT is
|
* We have things set up such that if the tool button has changed,
|
||||||
* not set, we'll send one instance of AIPTEK_TOOL_BUTTON_xxx.
|
* the tools get reset.
|
||||||
*
|
|
||||||
* Whenever the user resets the value, TOOL_BUTTON_FIRED_BIT will
|
|
||||||
* get reset.
|
|
||||||
*/
|
*/
|
||||||
#define TOOL_BUTTON(x) ((x) & 0x14f)
|
|
||||||
#define TOOL_BUTTON_FIRED(x) ((x) & 0x200)
|
|
||||||
#define TOOL_BUTTON_FIRED_BIT 0x200
|
|
||||||
/* toolMode codes
|
/* toolMode codes
|
||||||
*/
|
*/
|
||||||
#define AIPTEK_TOOL_BUTTON_PEN_MODE BTN_TOOL_PEN
|
#define AIPTEK_TOOL_BUTTON_PEN_MODE BTN_TOOL_PEN
|
||||||
@ -326,6 +320,9 @@ struct aiptek {
|
|||||||
int inDelay; /* jitter: in jitter delay? */
|
int inDelay; /* jitter: in jitter delay? */
|
||||||
unsigned long endDelay; /* jitter: time when delay ends */
|
unsigned long endDelay; /* jitter: time when delay ends */
|
||||||
int previousJitterable; /* jitterable prev value */
|
int previousJitterable; /* jitterable prev value */
|
||||||
|
|
||||||
|
int lastMacro; /* macro key to reset */
|
||||||
|
int previousToolMode; /* pen, pencil, brush, etc. tool */
|
||||||
unsigned char *data; /* incoming packet data */
|
unsigned char *data; /* incoming packet data */
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -542,16 +539,18 @@ static void aiptek_irq(struct urb *urb)
|
|||||||
* all 'bad' reports...
|
* all 'bad' reports...
|
||||||
*/
|
*/
|
||||||
if (dv != 0) {
|
if (dv != 0) {
|
||||||
/* If we've not already sent a tool_button_?? code, do
|
/* If the selected tool changed, reset the old
|
||||||
* so now. Then set FIRED_BIT so it won't be resent unless
|
* tool key, and set the new one.
|
||||||
* the user forces FIRED_BIT off.
|
|
||||||
*/
|
*/
|
||||||
if (TOOL_BUTTON_FIRED
|
if (aiptek->previousToolMode !=
|
||||||
(aiptek->curSetting.toolMode) == 0) {
|
aiptek->curSetting.toolMode) {
|
||||||
|
input_report_key(inputdev,
|
||||||
|
aiptek->previousToolMode, 0);
|
||||||
input_report_key(inputdev,
|
input_report_key(inputdev,
|
||||||
TOOL_BUTTON(aiptek->curSetting.toolMode),
|
aiptek->curSetting.toolMode,
|
||||||
1);
|
1);
|
||||||
aiptek->curSetting.toolMode |= TOOL_BUTTON_FIRED_BIT;
|
aiptek->previousToolMode =
|
||||||
|
aiptek->curSetting.toolMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p != 0) {
|
if (p != 0) {
|
||||||
@ -612,16 +611,18 @@ static void aiptek_irq(struct urb *urb)
|
|||||||
middle = (data[5] & aiptek->curSetting.mouseButtonMiddle) != 0 ? 1 : 0;
|
middle = (data[5] & aiptek->curSetting.mouseButtonMiddle) != 0 ? 1 : 0;
|
||||||
|
|
||||||
if (dv != 0) {
|
if (dv != 0) {
|
||||||
/* If we've not already sent a tool_button_?? code, do
|
/* If the selected tool changed, reset the old
|
||||||
* so now. Then set FIRED_BIT so it won't be resent unless
|
* tool key, and set the new one.
|
||||||
* the user forces FIRED_BIT off.
|
|
||||||
*/
|
*/
|
||||||
if (TOOL_BUTTON_FIRED
|
if (aiptek->previousToolMode !=
|
||||||
(aiptek->curSetting.toolMode) == 0) {
|
aiptek->curSetting.toolMode) {
|
||||||
|
input_report_key(inputdev,
|
||||||
|
aiptek->previousToolMode, 0);
|
||||||
input_report_key(inputdev,
|
input_report_key(inputdev,
|
||||||
TOOL_BUTTON(aiptek->curSetting.toolMode),
|
aiptek->curSetting.toolMode,
|
||||||
1);
|
1);
|
||||||
aiptek->curSetting.toolMode |= TOOL_BUTTON_FIRED_BIT;
|
aiptek->previousToolMode =
|
||||||
|
aiptek->curSetting.toolMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p != 0) {
|
if (p != 0) {
|
||||||
@ -662,15 +663,18 @@ static void aiptek_irq(struct urb *urb)
|
|||||||
z = le16_to_cpu(get_unaligned((__le16 *) (data + 4)));
|
z = le16_to_cpu(get_unaligned((__le16 *) (data + 4)));
|
||||||
|
|
||||||
if (dv != 0) {
|
if (dv != 0) {
|
||||||
/* If we've not already sent a tool_button_?? code, do
|
/* If the selected tool changed, reset the old
|
||||||
* so now. Then set FIRED_BIT so it won't be resent unless
|
* tool key, and set the new one.
|
||||||
* the user forces FIRED_BIT off.
|
|
||||||
*/
|
*/
|
||||||
if (TOOL_BUTTON_FIRED(aiptek->curSetting.toolMode) == 0) {
|
if (aiptek->previousToolMode !=
|
||||||
|
aiptek->curSetting.toolMode) {
|
||||||
|
input_report_key(inputdev,
|
||||||
|
aiptek->previousToolMode, 0);
|
||||||
input_report_key(inputdev,
|
input_report_key(inputdev,
|
||||||
TOOL_BUTTON(aiptek->curSetting.toolMode),
|
aiptek->curSetting.toolMode,
|
||||||
1);
|
1);
|
||||||
aiptek->curSetting.toolMode |= TOOL_BUTTON_FIRED_BIT;
|
aiptek->previousToolMode =
|
||||||
|
aiptek->curSetting.toolMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p != 0) {
|
if (p != 0) {
|
||||||
@ -710,15 +714,18 @@ static void aiptek_irq(struct urb *urb)
|
|||||||
macro = data[3];
|
macro = data[3];
|
||||||
|
|
||||||
if (dv != 0) {
|
if (dv != 0) {
|
||||||
/* If we've not already sent a tool_button_?? code, do
|
/* If the selected tool changed, reset the old
|
||||||
* so now. Then set FIRED_BIT so it won't be resent unless
|
* tool key, and set the new one.
|
||||||
* the user forces FIRED_BIT off.
|
|
||||||
*/
|
*/
|
||||||
if (TOOL_BUTTON_FIRED(aiptek->curSetting.toolMode) == 0) {
|
if (aiptek->previousToolMode !=
|
||||||
|
aiptek->curSetting.toolMode) {
|
||||||
|
input_report_key(inputdev,
|
||||||
|
aiptek->previousToolMode, 0);
|
||||||
input_report_key(inputdev,
|
input_report_key(inputdev,
|
||||||
TOOL_BUTTON(aiptek->curSetting.toolMode),
|
aiptek->curSetting.toolMode,
|
||||||
1);
|
1);
|
||||||
aiptek->curSetting.toolMode |= TOOL_BUTTON_FIRED_BIT;
|
aiptek->previousToolMode =
|
||||||
|
aiptek->curSetting.toolMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p != 0) {
|
if (p != 0) {
|
||||||
@ -762,15 +769,18 @@ static void aiptek_irq(struct urb *urb)
|
|||||||
0);
|
0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If we've not already sent a tool_button_?? code, do
|
/* If the selected tool changed, reset the old
|
||||||
* so now. Then set FIRED_BIT so it won't be resent unless
|
tool key, and set the new one.
|
||||||
* the user forces FIRED_BIT off.
|
*/
|
||||||
*/
|
if (aiptek->previousToolMode !=
|
||||||
if (TOOL_BUTTON_FIRED(aiptek->curSetting.toolMode) == 0) {
|
aiptek->curSetting.toolMode) {
|
||||||
|
input_report_key(inputdev,
|
||||||
|
aiptek->previousToolMode, 0);
|
||||||
input_report_key(inputdev,
|
input_report_key(inputdev,
|
||||||
TOOL_BUTTON(aiptek->curSetting.
|
aiptek->curSetting.toolMode,
|
||||||
toolMode), 1);
|
1);
|
||||||
aiptek->curSetting.toolMode |= TOOL_BUTTON_FIRED_BIT;
|
aiptek->previousToolMode =
|
||||||
|
aiptek->curSetting.toolMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
input_report_key(inputdev, macroKeyEvents[macro], 1);
|
input_report_key(inputdev, macroKeyEvents[macro], 1);
|
||||||
|
Loading…
Reference in New Issue
Block a user