diff options
Diffstat (limited to 'sys/arch/powerpc/mac')
-rw-r--r-- | sys/arch/powerpc/mac/ams.c | 218 |
1 files changed, 94 insertions, 124 deletions
diff --git a/sys/arch/powerpc/mac/ams.c b/sys/arch/powerpc/mac/ams.c index e8033ea4152..9805098377f 100644 --- a/sys/arch/powerpc/mac/ams.c +++ b/sys/arch/powerpc/mac/ams.c @@ -1,4 +1,4 @@ -/* $NetBSD: ams.c,v 1.8 2000/01/08 02:57:25 takemura Exp $ */ +/* $NetBSD: ams.c,v 1.11 2000/12/19 03:13:40 tsubai Exp $ */ /* * Copyright (C) 1998 Colin Wood @@ -39,11 +39,11 @@ #include <sys/signalvar.h> #include <sys/systm.h> +#include <machine/autoconf.h> + #include <dev/wscons/wsconsio.h> #include <dev/wscons/wsmousevar.h> -#include <machine/autoconf.h> - #include <powerpc/mac/adbvar.h> #include <powerpc/mac/aedvar.h> #include <powerpc/mac/amsvar.h> @@ -58,27 +58,15 @@ static void amsattach __P((struct device *, struct device *, void *)); static void ems_init __P((struct ams_softc *)); static void ms_processevent __P((adb_event_t *event, struct ams_softc *)); -/* - * Global variables. - */ -extern int kbd_polling; /* Are we polling (Debugger mode)? from kbd.c */ - -/* - * Local variables. - */ -static volatile int extdms_done; /* Did ADBOp() complete? */ - - -/* Driver definition. */ -struct cfdriver ams_cd = { - NULL, "ams", DV_DULL -}; /* Driver definition. */ struct cfattach ams_ca = { sizeof(struct ams_softc), amsmatch, amsattach }; +/* Driver definition. */ +struct cfdriver ams_cd = { + NULL, "ams", DV_DULL +}; -extern struct cfdriver ms_cd; int ams_enable __P((void *)); int ams_ioctl __P((void *, u_long, caddr_t, int, struct proc *)); @@ -96,7 +84,7 @@ amsmatch(parent, cf, aux) void *cf; void *aux; { - struct adb_attach_args * aa_args = (struct adb_attach_args *)aux; + struct adb_attach_args *aa_args = aux; if (aa_args->origaddr == ADBADDR_MS) return 1; @@ -111,7 +99,7 @@ amsattach(parent, self, aux) { ADBSetInfoBlock adbinfo; struct ams_softc *sc = (struct ams_softc *)self; - struct adb_attach_args * aa_args = (struct adb_attach_args *)aux; + struct adb_attach_args *aa_args = aux; int error; struct wsmousedev_attach_args a; @@ -151,6 +139,9 @@ amsattach(parent, self, aux) case ADBMS_UCONTOUR: printf("Contour mouse, default parameters\n"); break; + case ADBMS_TURBO: + printf("Kensington Turbo Mouse\n"); + break; case ADBMS_EXTENDED: if (sc->sc_devid[0] == '\0') { printf("Logitech "); @@ -197,7 +188,7 @@ amsattach(parent, self, aux) error = SetADBInfo(&adbinfo, sc->adbaddr); #ifdef ADB_DEBUG if (adb_debug) - printf("ms: returned %d from SetADBInfo\n", error); + printf("ams: returned %d from SetADBInfo\n", error); #endif a.accessops = &ams_accessops; @@ -220,7 +211,7 @@ void ems_init(sc) struct ams_softc *sc; { - int adbaddr, count; + int adbaddr; short cmd; u_char buffer[9]; @@ -230,7 +221,7 @@ ems_init(sc) if (sc->handler_id == ADBMS_USPEED || sc->handler_id == ADBMS_UCONTOUR) { /* Found MicroSpeed Mouse Deluxe Mac or Contour Mouse */ - cmd = ((adbaddr<<4)&0xF0)|0x9; /* listen 1 */ + cmd = ADBLISTEN(adbaddr, 1); /* * To setup the MicroSpeed or the Contour, it appears @@ -256,69 +247,68 @@ ems_init(sc) buffer[4] = 0x07; /* Locking mask = 0000b, * enable buttons = 0111b */ - extdms_done = 0; - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, cmd); - while (!extdms_done) - /* busy wait until done */; + adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd); sc->sc_buttons = 3; sc->sc_res = 200; return; } - if ((sc->handler_id == ADBMS_100DPI) || - (sc->handler_id == ADBMS_200DPI)) { - /* found a mouse */ - cmd = ((adbaddr << 4) & 0xf0) | 0x3; + if (sc->handler_id == ADBMS_TURBO) { + /* Found Kensington Turbo Mouse */ + static u_char data1[] = + { 8, 0xe7, 0x8c, 0, 0, 0, 0xff, 0xff, 0x94 }; + static u_char data2[] = + { 8, 0xa5, 0x14, 0, 0, 0x69, 0xff, 0xff, 0x27 }; + + buffer[0] = 0; + adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, ADBFLUSH(adbaddr)); - extdms_done = 0; - cmd = (cmd & 0xf3) | 0x0c; /* talk command */ - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, cmd); + adb_op_sync((Ptr)data1, (Ptr)0, (Ptr)0, ADBLISTEN(adbaddr, 2)); - /* Wait until done, but no more than 2 secs */ - count = 40000; - while (!extdms_done && count-- > 0) - delay(50); + buffer[0] = 0; + adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, ADBFLUSH(adbaddr)); - if (!extdms_done) { + adb_op_sync((Ptr)data2, (Ptr)0, (Ptr)0, ADBLISTEN(adbaddr, 2)); + return; + } + if ((sc->handler_id == ADBMS_100DPI) || + (sc->handler_id == ADBMS_200DPI)) { + /* found a mouse */ + cmd = ADBTALK(adbaddr, 3); + if (adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd)) { #ifdef ADB_DEBUG if (adb_debug) - printf("adb: extdms_init timed out\n"); + printf("adb: ems_init timed out\n"); #endif return; } /* Attempt to initialize Extended Mouse Protocol */ - buffer[2] = '\004'; /* make handler ID 4 */ - extdms_done = 0; - cmd = (cmd & 0xf3) | 0x08; /* listen command */ - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, cmd); - while (!extdms_done) - /* busy wait until done */; + buffer[2] = 4; /* make handler ID 4 */ + cmd = ADBLISTEN(adbaddr, 3); + if (adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd)) { +#ifdef ADB_DEBUG + if (adb_debug) + printf("adb: ems_init timed out\n"); +#endif + return; + } /* * Check to see if successful, if not * try to initialize it as other types */ - cmd = ((adbaddr << 4) & 0xf0) | 0x3; - extdms_done = 0; - cmd = (cmd & 0xf3) | 0x0c; /* talk command */ - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, cmd); - while (!extdms_done) - /* busy wait until done */; - - if (buffer[2] == ADBMS_EXTENDED) { + cmd = ADBTALK(adbaddr, 3); + if (adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd) == 0 && + buffer[2] == ADBMS_EXTENDED) { sc->handler_id = ADBMS_EXTENDED; - extdms_done = 0; - /* talk register 1 */ - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, (adbaddr << 4) | 0xd); - while (!extdms_done) - /* busy-wait until done */; - if (buffer[0] == 8) { + cmd = ADBTALK(adbaddr, 1); + if (adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd)) { +#ifdef ADB_DEBUG + if (adb_debug) + printf("adb: ems_init timed out\n"); +#endif + } else if (buffer[0] == 8) { /* we have a true EMP device */ sc->sc_class = buffer[7]; sc->sc_buttons = buffer[8]; @@ -331,42 +321,30 @@ ems_init(sc) * button bits in 3rd byte instead of sending * via pseudo keyboard device. */ - extdms_done = 0; - /* listen register 1 */ + cmd = ADBLISTEN(adbaddr, 1); buffer[0]=2; buffer[1]=0x00; buffer[2]=0x81; - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, (adbaddr << 4) | 0x9); - while (!extdms_done) - /* busy-wait until done */; - extdms_done = 0; - /* listen register 1 */ + adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd); + + cmd = ADBLISTEN(adbaddr, 1); buffer[0]=2; buffer[1]=0x01; buffer[2]=0x81; - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, (adbaddr << 4) | 0x9); - while (!extdms_done) - /* busy-wait until done */; - extdms_done = 0; - /* listen register 1 */ + adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd); + + cmd = ADBLISTEN(adbaddr, 1); buffer[0]=2; buffer[1]=0x02; buffer[2]=0x81; - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, (adbaddr << 4) | 0x9); - while (!extdms_done) - /* busy-wait until done */; - extdms_done = 0; - /* listen register 1 */ + adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd); + + cmd = ADBLISTEN(adbaddr, 1); buffer[0]=2; buffer[1]=0x03; buffer[2]=0x38; - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, (adbaddr << 4) | 0x9); - while (!extdms_done) - /* busy-wait until done */; + adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd); + sc->sc_buttons = 3; sc->sc_res = 400; if (buffer[2] == 0x21) @@ -378,29 +356,25 @@ ems_init(sc) } else { /* Attempt to initialize as an A3 mouse */ buffer[2] = 0x03; /* make handler ID 3 */ - extdms_done = 0; - cmd = (cmd & 0xf3) | 0x08; /* listen command */ - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, cmd); - while (!extdms_done) - /* busy wait until done */; + cmd = ADBLISTEN(adbaddr, 3); + if (adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd)) { +#ifdef ADB_DEBUG + if (adb_debug) + printf("adb: ems_init timed out\n"); +#endif + return; + } /* * Check to see if successful, if not * try to initialize it as other types */ - cmd = ((adbaddr << 4) & 0xf0) | 0x3; - extdms_done = 0; - cmd = (cmd & 0xf3) | 0x0c; /* talk command */ - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, cmd); - while (!extdms_done) - /* busy wait until done */; - - if (buffer[2] == ADBMS_MSA3) { + cmd = ADBTALK(adbaddr, 3); + if (adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd) == 0 + && buffer[2] == ADBMS_MSA3) { sc->handler_id = ADBMS_MSA3; /* Initialize as above */ - cmd = ((adbaddr << 4) & 0xF0) | 0xA; + cmd = ADBLISTEN(adbaddr, 2); /* listen 2 */ buffer[0] = 3; buffer[1] = 0x00; @@ -410,11 +384,7 @@ ems_init(sc) * enable 3 button mode = 0111b, * speed = normal */ - extdms_done = 0; - ADBOp((Ptr)buffer, (Ptr)extdms_complete, - (Ptr)&extdms_done, cmd); - while (!extdms_done) - /* busy wait until done */; + adb_op_sync((Ptr)buffer, (Ptr)0, (Ptr)0, cmd); sc->sc_buttons = 3; sc->sc_res = 300; } else { @@ -435,7 +405,7 @@ ms_adbcomplete(buffer, data_area, adb_command) int adb_command; { adb_event_t event; - struct ams_softc *msc; + struct ams_softc *sc; int adbaddr; #ifdef ADB_DEBUG int i; @@ -444,10 +414,10 @@ ms_adbcomplete(buffer, data_area, adb_command) printf("adb: transaction completion\n"); #endif - adbaddr = (adb_command & 0xf0) >> 4; - msc = (struct ams_softc *)data_area; + adbaddr = ADB_CMDADDR(adb_command); + sc = (struct ams_softc *)data_area; - if ((msc->handler_id == ADBMS_EXTENDED) && (msc->sc_devid[0] == 0)) { + if ((sc->handler_id == ADBMS_EXTENDED) && (sc->sc_devid[0] == 0)) { /* massage the data to look like EMP data */ if ((buffer[3] & 0x04) == 0x04) buffer[1] &= 0x7f; @@ -464,14 +434,14 @@ ms_adbcomplete(buffer, data_area, adb_command) } event.addr = adbaddr; - event.hand_id = msc->handler_id; - event.def_addr = msc->origaddr; + event.hand_id = sc->handler_id; + event.def_addr = sc->origaddr; event.byte_count = buffer[0]; memcpy(event.bytes, buffer + 1, event.byte_count); #ifdef ADB_DEBUG if (adb_debug) { - printf("ms: from %d at %d (org %d) %d:", event.addr, + printf("ams: from %d at %d (org %d) %d:", event.addr, event.hand_id, event.def_addr, buffer[0]); for (i = 1; i <= buffer[0]; i++) printf(" %x", buffer[i]); @@ -481,7 +451,7 @@ ms_adbcomplete(buffer, data_area, adb_command) microtime(&event.timestamp); - ms_processevent(&event, msc); + ms_processevent(&event, sc); } /* @@ -489,9 +459,9 @@ ms_adbcomplete(buffer, data_area, adb_command) * x- and y-axis motion, and handoff the event to the appropriate subsystem. */ static void -ms_processevent(event, msc) +ms_processevent(event, sc) adb_event_t *event; - struct ams_softc *msc; + struct ams_softc *sc; { adb_event_t new_event; int i, button_bit, max_byte, mask, buttons; @@ -542,14 +512,14 @@ ms_processevent(event, msc) } break; } - new_event.u.m.buttons = msc->sc_mb | buttons; + new_event.u.m.buttons = sc->sc_mb | buttons; new_event.u.m.dx = ((signed int) (event->bytes[1] & 0x3f)) - ((event->bytes[1] & 0x40) ? 64 : 0); new_event.u.m.dy = ((signed int) (event->bytes[0] & 0x3f)) - ((event->bytes[0] & 0x40) ? 64 : 0); - if (msc->sc_wsmousedev) - wsmouse_input(msc->sc_wsmousedev, new_event.u.m.buttons, + if (sc->sc_wsmousedev) + wsmouse_input(sc->sc_wsmousedev, new_event.u.m.buttons, new_event.u.m.dx, -new_event.u.m.dy, 0, WSMOUSE_INPUT_DELTA); #if NAED > 0 |