diff options
-rw-r--r-- | driver/xf86-input-mouse/src/mouse.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/driver/xf86-input-mouse/src/mouse.c b/driver/xf86-input-mouse/src/mouse.c index d3eb62a00..d9875348b 100644 --- a/driver/xf86-input-mouse/src/mouse.c +++ b/driver/xf86-input-mouse/src/mouse.c @@ -348,6 +348,7 @@ static MouseProtocolRec mouseProtocols[] = { { "IntelliMouse", MSE_SERIAL, msDefaults, PROT_IMSERIAL }, { "ThinkingMouse", MSE_SERIAL, msDefaults, PROT_THINKING }, { "AceCad", MSE_SERIAL, acecadDefaults, PROT_ACECAD }, + { "SunMouse", MSE_SERIAL, mlDefaults, PROT_SUNMOUSE }, { "ValuMouseScroll", MSE_SERIAL, msDefaults, PROT_VALUMOUSESCROLL }, /* Standard PS/2 */ @@ -376,6 +377,8 @@ static MouseProtocolRec mouseProtocols[] = { { NULL, MSE_NONE, NULL, PROT_UNKNOWN } }; +static unsigned char proto[PROT_NUMPROTOS][8]; + #ifdef XFree86LOADER /*ARGSUSED*/ static const OptionInfoRec * @@ -1376,6 +1379,14 @@ MouseReadInput(InputInfoPtr pInfo) for (j = 0; j < pBufP; j++) pBuf[j] = pBuf[j+1]; pMse->inSync = 0; + + /* If SunMouse gets a 5 byte packet, switch to MouseSystems */ + if (!baddata && pMse->protocolID == PROT_SUNMOUSE && + (u & pMse->protoPara[5]) == pMse->protoPara[6]) { + pMse->protocolID = PROT_MSC; + memcpy(pMse->protoPara, proto[pMse->protocolID], + sizeof(pMse->protoPara)); + } continue; } /* Tell auto probe that we were successful */ @@ -1423,6 +1434,7 @@ MouseReadInput(InputInfoPtr pInfo) break; case PROT_MSC: /* Mouse Systems Corp */ + case PROT_SUNMOUSE: buttons = (~pBuf[0]) & 0x07; dx = (char)(pBuf[1]) + (char)(pBuf[3]); dy = - ((char)(pBuf[2]) + (char)(pBuf[4])); @@ -2494,6 +2506,7 @@ static unsigned char proto[PROT_NUMPROTOS][8] = { { 0xf8, 0x80, 0x00, 0x00, 5, 0x00, 0xff, MPF_NONE }, /* BusMouse */ { 0xf8, 0x80, 0x00, 0x00, 5, 0x00, 0xff, MPF_NONE }, /* Auto (dummy) */ { 0xf8, 0x80, 0x00, 0x00, 8, 0x00, 0xff, MPF_NONE }, /* SysMouse */ + { 0xf8, 0x88, 0x00, 0x00, 3, 0xf8, 0x80, MPF_SAFE }, /* SunMouse */ }; @@ -2792,6 +2805,7 @@ initMouseHW(InputInfoPtr pInfo) break; case PROT_MSC: /* MouseSystems Corp */ + case PROT_SUNMOUSE: usleep(100000); xf86FlushInput(pInfo->fd); break; |