| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805 |
- Update inputattach to the latest version, as available at
- http://kernel.org/pub/linux/kernel/people/dtor/
- --- joystick-20051019.orig/utils/inputattach.c
- +++ joystick-20051019/utils/inputattach.c
- @@ -1,5 +1,5 @@
- /*
- - * $Id: inputattach.c,v 1.23 2005/03/22 13:12:29 vojtech Exp $
- + * $Id: inputattach.c,v 1.24 2006/02/08 12:19:31 vojtech Exp $
- *
- * Copyright (c) 1999-2000 Vojtech Pavlik
- *
- @@ -16,18 +16,18 @@
- /*
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- - * the Free Software Foundation; either version 2 of the License, or
- + * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- - *
- + *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- - *
- + *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- - *
- + *
- * Should you need to contact me, the author, you can do so either by
- * e-mail - mail your message to <vojtech@ucw.cz>, or by paper mail:
- * Vojtech Pavlik, Simunkova 1594, Prague 8, 182 00 Czech Republic
- @@ -46,29 +46,33 @@
- #include <fcntl.h>
- #include <termios.h>
- #include <string.h>
- +#include <errno.h>
- #include <assert.h>
- #include <ctype.h>
-
- -int readchar(int fd, unsigned char *c, int timeout)
- +#include "serio-ids.h"
- +
- +static int readchar(int fd, unsigned char *c, int timeout)
- {
- struct timeval tv;
- fd_set set;
- -
- +
- tv.tv_sec = 0;
- tv.tv_usec = timeout * 1000;
-
- FD_ZERO(&set);
- FD_SET(fd, &set);
-
- - if (!select(fd+1, &set, NULL, NULL, &tv)) return -1;
- - if (read(fd, c, 1) != 1) return -1;
- + if (!select(fd + 1, &set, NULL, NULL, &tv))
- + return -1;
- +
- + if (read(fd, c, 1) != 1)
- + return -1;
-
- return 0;
- }
-
- -
- -
- -void setline(int fd, int flags, int speed)
- +static void setline(int fd, int flags, int speed)
- {
- struct termios t;
-
- @@ -87,10 +91,11 @@
- tcsetattr(fd, TCSANOW, &t);
- }
-
- -int logitech_command(int fd, char *c)
- +static int logitech_command(int fd, char *c)
- {
- int i;
- unsigned char d;
- +
- for (i = 0; c[i]; i++) {
- write(fd, c + i, 1);
- if (readchar(fd, &d, 1000))
- @@ -101,27 +106,32 @@
- return 0;
- }
-
- -int magellan_init(int fd, long *id, long *extra)
- +static int magellan_init(int fd, unsigned long *id, unsigned long *extra)
- {
- write(fd, "m3\rpBB\rz\r", 9);
- return 0;
- }
-
- -int warrior_init(int fd, long *id, long *extra)
- +static int warrior_init(int fd, unsigned long *id, unsigned long *extra)
- {
- - if (logitech_command(fd, "*S")) return -1;
- + if (logitech_command(fd, "*S"))
- + return -1;
- +
- setline(fd, CS8, B4800);
- return 0;
- }
-
- -int spaceball_waitchar(int fd, unsigned char c, unsigned char *d, int timeout)
- +static int spaceball_waitchar(int fd, unsigned char c, unsigned char *d,
- + int timeout)
- {
- unsigned char b = 0;
-
- while (!readchar(fd, &b, timeout)) {
- - if (b == 0x0a) continue;
- + if (b == 0x0a)
- + continue;
- *d++ = b;
- - if (b == c) break;
- + if (b == c)
- + break;
- }
-
- *d = 0;
- @@ -129,7 +139,7 @@
- return -(b != c);
- }
-
- -int spaceball_waitcmd(int fd, char c, char *d)
- +static int spaceball_waitcmd(int fd, char c, char *d)
- {
- int i;
-
- @@ -143,7 +153,7 @@
- return -1;
- }
-
- -int spaceball_cmd(int fd, char *c, char *d)
- +static int spaceball_cmd(int fd, char *c, char *d)
- {
- int i;
-
- @@ -161,9 +171,9 @@
- #define SPACEBALL_2003C 4
- #define SPACEBALL_3003C 7
- #define SPACEBALL_4000FLX 8
- -#define SPACEBALL_4000FLX_L 9
- +#define SPACEBALL_4000FLX_L 9
-
- -int spaceball_init(int fd, long *id, long *extra)
- +static int spaceball_init(int fd, unsigned long *id, unsigned long *extra)
- {
- char r[64];
-
- @@ -172,13 +182,13 @@
- return -1;
-
- if (spaceball_waitcmd(fd, '@', r))
- - return -1;
- + return -1;
-
- if (strncmp("@1 Spaceball alive", r, 18))
- return -1;
-
- if (spaceball_waitcmd(fd, '@', r))
- - return -1;
- + return -1;
-
- if (spaceball_cmd(fd, "hm", r))
- return -1;
- @@ -199,7 +209,7 @@
- return -1;
-
- if (spaceball_waitcmd(fd, '"', r))
- - return -1;
- + return -1;
-
- if (strstr(r, " L "))
- *id = SPACEBALL_4000FLX_L;
- @@ -207,13 +217,13 @@
- *id = SPACEBALL_4000FLX;
-
- if (spaceball_waitcmd(fd, '"', r))
- - return -1;
- + return -1;
-
- if (spaceball_cmd(fd, "YS", r))
- - return -1;
- + return -1;
-
- if (spaceball_cmd(fd, "M", r))
- - return -1;
- + return -1;
-
- return 0;
- }
- @@ -226,70 +236,79 @@
- return 0;
- }
-
- -int stinger_init(int fd, long *id, long *extra)
- +static int stinger_init(int fd, unsigned long *id, unsigned long *extra)
- {
- int i;
- unsigned char c;
- unsigned char *response = "\r\n0600520058C272";
-
- if (write(fd, " E5E5", 5) != 5) /* Enable command */
- - return -1;
- + return -1;
-
- for (i = 0; i < 16; i++) /* Check for Stinger */
- - if (readchar(fd, &c, 200) || (c != response[i]))
- + if (readchar(fd, &c, 200) || c != response[i])
- return -1;
-
- return 0;
- }
-
- -int mzp_init(int fd, long *id, long *extra)
- +static int mzp_init(int fd, unsigned long *id, unsigned long *extra)
- {
- - if (logitech_command(fd, "*X*q")) return -1;
- + if (logitech_command(fd, "*X*q"))
- + return -1;
- +
- setline(fd, CS8, B9600);
- return 0;
- }
-
- -int newton_init(int fd, long *id, long *extra)
- +static int newton_init(int fd, unsigned long *id, unsigned long *extra)
- {
- - int i;
- - unsigned char c;
- - unsigned char response[35] =
- - { 0x16, 0x10, 0x02, 0x64, 0x5f, 0x69, 0x64, 0x00,
- - 0x00, 0x00, 0x0c, 0x6b, 0x79, 0x62, 0x64, 0x61,
- - 0x70, 0x70, 0x6c, 0x00, 0x00, 0x00, 0x01, 0x6e,
- - 0x6f, 0x66, 0x6d, 0x00, 0x00, 0x00, 0x00, 0x10,
- - 0x03, 0xdd, 0xe7 };
- + int i;
- + unsigned char c;
- + unsigned char response[35] = {
- + 0x16, 0x10, 0x02, 0x64, 0x5f, 0x69, 0x64, 0x00,
- + 0x00, 0x00, 0x0c, 0x6b, 0x79, 0x62, 0x64, 0x61,
- + 0x70, 0x70, 0x6c, 0x00, 0x00, 0x00, 0x01, 0x6e,
- + 0x6f, 0x66, 0x6d, 0x00, 0x00, 0x00, 0x00, 0x10,
- + 0x03, 0xdd, 0xe7
- + };
-
- - for (i = 0; i < 35; i++)
- - if (readchar(fd, &c, 400) || (c != response[i]))
- - return -1;
- + for (i = 0; i < sizeof(response); i++)
- + if (readchar(fd, &c, 400) || c != response[i])
- + return -1;
-
- - return 0;
- + return 0;
- }
-
- -int twiddler_init(int fd, long *id, long *extra)
- +static int twiddler_init(int fd, unsigned long *id, unsigned long *extra)
- {
- unsigned char c[10];
- int count, line;
-
- /* Turn DTR off, otherwise the Twiddler won't send any data. */
- - if (ioctl(fd, TIOCMGET, &line)) return -1;
- + if (ioctl(fd, TIOCMGET, &line))
- + return -1;
- line &= ~TIOCM_DTR;
- - if (ioctl(fd, TIOCMSET, &line)) return -1;
- + if (ioctl(fd, TIOCMSET, &line))
- + return -1;
-
- - /* Check whether the device on the serial line is the Twiddler.
- + /*
- + * Check whether the device on the serial line is the Twiddler.
- *
- * The Twiddler sends data packets of 5 bytes which have the following
- * properties: the MSB is 0 on the first and 1 on all other bytes, and
- * the high order nibble of the last byte is always 0x8.
- *
- * We read and check two of those 5 byte packets to be sure that we
- - * are indeed talking to a Twiddler. */
- + * are indeed talking to a Twiddler.
- + */
-
- /* Read at most 5 bytes until we find one with the MSB set to 0 */
- for (count = 0; count < 5; count++) {
- - if (readchar(fd, c+0, 500)) return -1;
- - if ((c[0] & 0x80) == 0) break;
- + if (readchar(fd, c, 500))
- + return -1;
- + if ((c[0] & 0x80) == 0)
- + break;
- }
-
- if (count == 5) {
- @@ -298,16 +317,16 @@
- }
-
- /* Read remaining 4 bytes plus the full next data packet */
- - for (count = 1; count < 10; count++) {
- - if (readchar(fd, c+count, 500)) return -1;
- - }
- + for (count = 1; count < 10; count++)
- + if (readchar(fd, c + count, 500))
- + return -1;
-
- /* Check whether the bytes of both data packets obey the rules */
- for (count = 1; count < 10; count++) {
- - if ((count % 5 == 0 && (c[count] & 0x80) != 0)
- - || (count % 5 == 4 && (c[count] & 0xF0) != 0x80)
- - || (count % 5 != 0 && (c[count] & 0x80) != 0x80)) {
- - /* Invalid byte in data packet */
- + if ((count % 5 == 0 && (c[count] & 0x80) != 0x00) ||
- + (count % 5 == 4 && (c[count] & 0xF0) != 0x80) ||
- + (count % 5 != 0 && (c[count] & 0x80) != 0x80)) {
- + /* Invalid byte in data packet */
- return -1;
- }
- }
- @@ -315,7 +334,35 @@
- return 0;
- }
-
- -int dump_init(int fd, long *id, long *extra)
- +static int fujitsu_init(int fd, unsigned long *id, unsigned long *extra)
- +{
- + unsigned char cmd, data;
- +
- + /* Wake up the touchscreen */
- + cmd = 0xff; /* Dummy data */;
- + if (write(fd, &cmd, 1) != 1)
- + return -1;
- +
- + /* Wait to settle down */
- + usleep(100 * 1000); /* 100 ms */
- +
- + /* Reset the touchscreen */
- + cmd = 0x81; /* Cold reset */
- + if (write(fd, &cmd, 1) != 1)
- + return -1;
- +
- + /* Read ACK */
- + if (readchar(fd, &data, 100) || (data & 0xbf) != 0x90)
- + return -1;
- +
- + /* Read status */
- + if (readchar(fd, &data, 100) || data != 0x00)
- + return -1;
- +
- + return 0;
- +}
- +
- +static int dump_init(int fd, unsigned long *id, unsigned long *extra)
- {
- unsigned char c, o = 0;
-
- @@ -337,129 +384,230 @@
- }
-
- struct input_types {
- - char name[16];
- - char name2[16];
- + const char *name;
- + const char *name2;
- + const char *desc;
- int speed;
- int flags;
- unsigned long type;
- unsigned long id;
- unsigned long extra;
- int flush;
- - int (*init)(int fd, long *id, long *extra);
- + int (*init)(int fd, unsigned long *id, unsigned long *extra);
- +};
- +
- +static struct input_types input_types[] = {
- +{ "--sunkbd", "-skb", "Sun Type 4 and Type 5 keyboards",
- + B1200, CS8,
- + SERIO_SUNKBD, 0x00, 0x00, 1, NULL },
- +{ "--lkkbd", "-lk", "DEC LK201 / LK401 keyboards",
- + B4800, CS8|CSTOPB,
- + SERIO_LKKBD, 0x00, 0x00, 1, NULL },
- +{ "--vsxxx-aa", "-vs",
- + "DEC VSXXX-AA / VSXXX-GA mouse and VSXXX-A tablet",
- + B4800, CS8|CSTOPB|PARENB|PARODD,
- + SERIO_VSXXXAA, 0x00, 0x00, 1, NULL },
- +{ "--spaceorb", "-orb", "SpaceOrb 360 / SpaceBall Avenger",
- + B9600, CS8,
- + SERIO_SPACEORB, 0x00, 0x00, 1, NULL },
- +{ "--spaceball", "-sbl", "SpaceBall 2003 / 3003 / 4000 FLX",
- + B9600, CS8,
- + SERIO_SPACEBALL, 0x00, 0x00, 0, spaceball_init },
- +{ "--magellan", "-mag", "Magellan / SpaceMouse",
- + B9600, CS8 | CSTOPB | CRTSCTS,
- + SERIO_MAGELLAN, 0x00, 0x00, 1, magellan_init },
- +{ "--warrior", "-war", "WingMan Warrior",
- + B1200, CS7 | CSTOPB,
- + SERIO_WARRIOR, 0x00, 0x00, 1, warrior_init },
- +{ "--stinger", "-sting", "Gravis Stinger",
- + B1200, CS8,
- + SERIO_STINGER, 0x00, 0x00, 1, stinger_init },
- +{ "--mousesystems", "-msc", "3-button Mouse Systems mouse",
- + B1200, CS8,
- + SERIO_MSC, 0x00, 0x01, 1, NULL },
- +{ "--sunmouse", "-sun", "3-button Sun mouse",
- + B1200, CS8,
- + SERIO_SUN, 0x00, 0x01, 1, NULL },
- +{ "--microsoft", "-bare", "2-button Microsoft mouse",
- + B1200, CS7,
- + SERIO_MS, 0x00, 0x00, 1, NULL },
- +{ "--mshack", "-ms", "3-button mouse in Microsoft mode",
- + B1200, CS7,
- + SERIO_MS, 0x00, 0x01, 1, NULL },
- +{ "--mouseman", "-mman", "3-button Logitech / Genius mouse",
- + B1200, CS7,
- + SERIO_MP, 0x00, 0x01, 1, NULL },
- +{ "--intellimouse", "-ms3", "Microsoft IntelliMouse",
- + B1200, CS7,
- + SERIO_MZ, 0x00, 0x11, 1, NULL },
- +{ "--mmwheel", "-mmw",
- + "Logitech mouse with 4-5 buttons or a wheel",
- + B1200, CS7 | CSTOPB,
- + SERIO_MZP, 0x00, 0x13, 1, mzp_init },
- +{ "--iforce", "-ifor", "I-Force joystick or wheel",
- + B38400, CS8,
- + SERIO_IFORCE, 0x00, 0x00, 0, NULL },
- +{ "--newtonkbd", "-newt", "Newton keyboard",
- + B9600, CS8,
- + SERIO_NEWTON, 0x00, 0x00, 1, newton_init },
- +{ "--h3600ts", "-ipaq", "Ipaq h3600 touchscreen",
- + B115200, CS8,
- + SERIO_H3600, 0x00, 0x00, 0, NULL },
- +{ "--stowawaykbd", "-ipaqkbd", "Stowaway keyboard",
- + B115200, CS8,
- + SERIO_STOWAWAY, 0x00, 0x00, 1, NULL },
- +{ "--ps2serkbd", "-ps2ser", "PS/2 via serial keyboard",
- + B1200, CS8,
- + SERIO_PS2SER, 0x00, 0x00, 1, NULL },
- +{ "--twiddler", "-twid", "Handykey Twiddler chording keyboard",
- + B2400, CS8,
- + SERIO_TWIDKBD, 0x00, 0x00, 0, twiddler_init },
- +{ "--twiddler-joy", "-twidjoy", "Handykey Twiddler used as a joystick",
- + B2400, CS8,
- + SERIO_TWIDJOY, 0x00, 0x00, 0, twiddler_init },
- +{ "--elotouch", "-elo", "ELO touchscreen, 10-byte mode",
- + B9600, CS8 | CRTSCTS,
- + SERIO_ELO, 0x00, 0x00, 0, NULL },
- +{ "--elo4002", "-elo6b", "ELO touchscreen, 6-byte mode",
- + B9600, CS8 | CRTSCTS,
- + SERIO_ELO, 0x01, 0x00, 0, NULL },
- +{ "--elo271-140", "-elo4b", "ELO touchscreen, 4-byte mode",
- + B9600, CS8 | CRTSCTS,
- + SERIO_ELO, 0x02, 0x00, 0, NULL },
- +{ "--elo261-280", "-elo3b", "ELO Touchscreen, 3-byte mode",
- + B9600, CS8 | CRTSCTS,
- + SERIO_ELO, 0x03, 0x00, 0, NULL },
- +{ "--mtouch", "-mtouch", "MicroTouch (3M) touchscreen",
- + B9600, CS8 | CRTSCTS,
- + SERIO_MICROTOUCH, 0x00, 0x00, 0, NULL },
- +{ "--touchright", "-tr", "Touchright serial touchscreen",
- + B9600, CS8 | CRTSCTS,
- + SERIO_TOUCHRIGHT, 0x00, 0x00, 0, NULL },
- +{ "--touchwin", "-tw", "Touchwindow serial touchscreen",
- + B4800, CS8 | CRTSCTS,
- + SERIO_TOUCHWIN, 0x00, 0x00, 0, NULL },
- +{ "--penmount", "-pm", "Penmount touchscreen",
- + B19200, CS8 | CRTSCTS,
- + SERIO_PENMOUNT, 0x00, 0x00, 0, NULL },
- +{ "--fujitsu", "-fjt", "Fujitsu serial touchscreen",
- + B9600, CS8,
- + SERIO_FUJITSU, 0x00, 0x00, 1, fujitsu_init },
- +{ "--dump", "-dump", "Just enable device",
- + B2400, CS8,
- + 0, 0x00, 0x00, 0, dump_init },
- +{ NULL, NULL, NULL, 0, 0, 0, 0, 0, 0, NULL }
- };
-
- -struct input_types input_types[] = {
- +static void show_help(void)
- +{
- + struct input_types *type;
-
- -{ "--sunkbd", "-skb", B1200, CS8, SERIO_SUNKBD, 0, 0, 1, NULL },
- -{ "--lkkbd", "-lk", B4800, CS8|CSTOPB, SERIO_LKKBD, 0, 0, 1, NULL },
- -{ "--vsxxx-aa", "-vs", B4800, CS8|CSTOPB|PARENB|PARODD,SERIO_VSXXXAA, 0, 0, 1, NULL },
- -{ "--spaceorb", "-orb", B9600, CS8, SERIO_SPACEORB, 0, 0, 1, NULL },
- -{ "--spaceball", "-sbl", B9600, CS8, SERIO_SPACEBALL,0, 0, 0, spaceball_init },
- -{ "--magellan", "-mag", B9600, CS8 | CSTOPB | CRTSCTS, SERIO_MAGELLAN, 0, 0, 1, magellan_init },
- -{ "--warrior", "-war", B1200, CS7 | CSTOPB, SERIO_WARRIOR, 0, 0, 1, warrior_init },
- -{ "--stinger", "-sting", B1200, CS8, SERIO_STINGER, 0, 0, 1, stinger_init },
- -{ "--mousesystems", "-msc", B1200, CS8, SERIO_MSC, 0, 0x01, 1, NULL },
- -{ "--sunmouse", "-sun", B1200, CS8, SERIO_SUN, 0, 0x01, 1, NULL },
- -{ "--microsoft", "-bare", B1200, CS7, SERIO_MS, 0, 0, 1, NULL },
- -{ "--mshack", "-ms", B1200, CS7, SERIO_MS, 0, 0x01, 1, NULL },
- -{ "--mouseman", "-mman", B1200, CS7, SERIO_MP, 0, 0x01, 1, NULL },
- -{ "--intellimouse", "-ms3", B1200, CS7, SERIO_MZ, 0, 0x11, 1, NULL },
- -{ "--mmwheel", "-mmw", B1200, CS7 | CSTOPB, SERIO_MZP, 0, 0x13, 1, mzp_init },
- -{ "--iforce", "-ifor", B38400, CS8, SERIO_IFORCE, 0, 0, 0, NULL },
- -{ "--newtonkbd", "-newt", B9600, CS8, SERIO_NEWTON, 0, 0, 0, newton_init },
- -{ "--h3600ts", "-ipaq", B115200, CS8, SERIO_H3600, 0, 0, 0, NULL },
- -{ "--stowawaykbd", "-ipaqkbd", B115200, CS8, SERIO_STOWAWAY, 0, 0, 0, NULL },
- -{ "--ps2serkbd", "-ps2ser", B1200, CS8, SERIO_PS2SER, 0, 0, 1, NULL },
- -{ "--twiddler", "-twid", B2400, CS8, SERIO_TWIDKBD, 0, 0, 0, twiddler_init },
- -{ "--twiddler-joy", "-twidjoy", B2400, CS8, SERIO_TWIDJOY, 0, 0, 0, twiddler_init },
- -{ "--elotouch", "-elo", B9600, CS8 | CRTSCTS, SERIO_ELO, 0, 0, 0, NULL },
- -{ "--elo4002", "-elo6b", B9600, CS8 | CRTSCTS, SERIO_ELO, 1, 0, 0, NULL },
- -{ "--elo271-140", "-elo4b", B9600, CS8 | CRTSCTS, SERIO_ELO, 2, 0, 0, NULL },
- -{ "--elo261-280", "-elo3b", B9600, CS8 | CRTSCTS, SERIO_ELO, 3, 0, 0, NULL },
- -{ "--dump", "-dump", B2400, CS8, 0, 0, 0, 0, dump_init },
- -{ "", "", 0, 0 }
- + puts("");
- + puts("Usage: inputattach [--daemon] <mode> <device>");
- + puts("");
- + puts("Modes:");
-
- -};
- + for (type = input_types; type->name; type++)
- + printf(" %-16s %-8s %s\n",
- + type->name, type->name2, type->desc);
- +
- + puts("");
- +}
-
- int main(int argc, char **argv)
- {
- unsigned long devt;
- int ldisc;
- - int type;
- - long id, extra;
- - int fd;
- + struct input_types *type = NULL;
- + const char *device = NULL;
- + int daemon_mode = 0;
- + int need_device = 0;
- + unsigned long id, extra;
- + int fd;
- + int i;
- char c;
- + int retval;
-
- - if (argc < 2 || argc > 3 || !strcmp("--help", argv[1])) {
- - puts("");
- - puts("Usage: inputttach <mode> <device>");
- - puts("");
- - puts("Modes:");
- - puts(" --sunkbd -skb Sun Type 4 and Type 5 keyboards");
- - puts(" --lkkbd -lk DEC LK201 / LK401 keyboards");
- - puts(" --vsxxx-aa -vs DEC VSXXX-AA / VSXXX-GA mouse and VSXXX-AB tablet");
- - puts(" --spaceorb -orb SpaceOrb 360 / SpaceBall Avenger");
- - puts(" --spaceball -sbl SpaceBall 2003 / 3003 / 4000 FLX");
- - puts(" --magellan -mag Magellan / SpaceMouse");
- - puts(" --warrior -war WingMan Warrior");
- - puts(" --stinger -stng Gravis Stinger");
- - puts(" --mousesystems -msc 3-button Mouse Systems mice");
- - puts(" --sunmouse -sun 3-button Sun mice");
- - puts(" --microsoft -bare 2-button Microsoft mice");
- - puts(" --mshack -ms 3-button mice in Microsoft mode");
- - puts(" --mouseman -mman 3-button Logitech and Genius mice");
- - puts(" --intellimouse -ms3 Microsoft IntelliMouse");
- - puts(" --mmwheel -mmw Logitech mice with 4-5 buttons or wheel");
- - puts(" --iforce -ifor I-Force joysticks and wheels");
- - puts(" --h3600ts -ipaq Ipaq h3600 touchscreen");
- - puts(" --stowawaykbd -ipaqkbd Stowaway keyboard");
- - puts(" --ps2serkbd -ps2ser PS/2 via serial keyboard");
- - puts(" --twiddler -twid Handykey Twiddler chording keyboard");
- - puts(" --twiddler-joy -twidjoy Handykey Twiddler used as a joystick");
- - puts("");
- - return 1;
- - }
- + for (i = 1; i < argc; i++) {
- + if (!strcasecmp(argv[i], "--help")) {
- + show_help();
- + return EXIT_SUCCESS;
- + } else if (!strcasecmp(argv[i], "--daemon")) {
- + daemon_mode = 1;
- + } else if (need_device) {
- + device = argv[i];
- + need_device = 0;
- + } else {
- + if (type && type->name) {
- + fprintf(stderr,
- + "inputattach: '%s' - "
- + "only one mode allowed\n", argv[i]);
- + return EXIT_FAILURE;
- + }
- + for (type = input_types; type->name; type++) {
- + if (!strcasecmp(argv[i], type->name) ||
- + !strcasecmp(argv[i], type->name2)) {
- + break;
- + }
- + }
- + if (!type->name) {
- + fprintf(stderr,
- + "inputattach: invalid mode '%s'\n",
- + argv[i]);
- + return EXIT_FAILURE;
- + }
- + need_device = 1;
- + }
- + }
-
- - for (type = 0; input_types[type].speed; type++) {
- - if (!strncasecmp(argv[1], input_types[type].name, 16) ||
- - !strncasecmp(argv[1], input_types[type].name2, 16))
- - break;
- + if (!type || !type->name) {
- + fprintf(stderr, "inputattach: must specify mode\n");
- + return EXIT_FAILURE;
- }
-
- - if (!input_types[type].speed) {
- - fprintf(stderr, "inputattach: invalid mode\n");
- - return 1;
- + if (need_device) {
- + fprintf(stderr, "inputattach: must specify device\n");
- + return EXIT_FAILURE;
- }
-
- - if ((fd = open(argv[2], O_RDWR | O_NOCTTY | O_NONBLOCK)) < 0) {
- - perror("inputattach");
- + fd = open(device, O_RDWR | O_NOCTTY | O_NONBLOCK);
- + if (fd < 0) {
- + fprintf(stderr, "inputattach: '%s' - %s\n",
- + device, strerror(errno));
- return 1;
- }
-
- - setline(fd, input_types[type].flags, input_types[type].speed);
- + setline(fd, type->flags, type->speed);
-
- - if (input_types[type].flush)
- - while (!readchar(fd, &c, 100));
- + if (type->flush)
- + while (!readchar(fd, &c, 100))
- + /* empty */;
-
- - id = input_types[type].id;
- - extra = input_types[type].extra;
- + id = type->id;
- + extra = type->extra;
-
- - if (input_types[type].init && input_types[type].init(fd, &id, &extra)) {
- + if (type->init && type->init(fd, &id, &extra)) {
- fprintf(stderr, "inputattach: device initialization failed\n");
- - return 1;
- + return EXIT_FAILURE;
- }
-
- ldisc = N_MOUSE;
- - if(ioctl(fd, TIOCSETD, &ldisc)) {
- - fprintf(stderr, "inputattach: can't set line discipline\n");
- - return 1;
- + if (ioctl(fd, TIOCSETD, &ldisc)) {
- + fprintf(stderr, "inputattach: can't set line discipline\n");
- + return EXIT_FAILURE;
- }
-
- - devt = SERIO_RS232 | input_types[type].type | (id << 8) | (extra << 16);
- + devt = type->type | (id << 8) | (extra << 16);
-
- - if(ioctl(fd, SPIOCSTYPE, &devt)) {
- + if (ioctl(fd, SPIOCSTYPE, &devt)) {
- fprintf(stderr, "inputattach: can't set device type\n");
- - return 1;
- + return EXIT_FAILURE;
- + }
- +
- + retval = EXIT_SUCCESS;
- + if (daemon_mode && daemon(0, 0) < 0) {
- + perror("inputattach");
- + retval = EXIT_FAILURE;
- }
-
- read(fd, NULL, 0);
- @@ -468,5 +616,5 @@
- ioctl(fd, TIOCSETD, &ldisc);
- close(fd);
-
- - return 0;
- + return retval;
- }
- --- /dev/null
- +++ joystick-20051019/utils/serio-ids.h
- @@ -0,0 +1,111 @@
- +#ifndef _SERIO_IDS_H
- +#define _SERIO_IDS_H
- +
- +#ifndef SERIO_RS232
- +# define SERIO_RS232 0x02
- +#endif
- +
- +/*
- + * Serio types
- + */
- +#ifndef SERIO_UNKNOWN
- +# define SERIO_UNKNOWN 0x00
- +#endif
- +#ifndef SERIO_MSC
- +# define SERIO_MSC 0x01
- +#endif
- +#ifndef SERIO_SUN
- +# define SERIO_SUN 0x02
- +#endif
- +#ifndef SERIO_MS
- +# define SERIO_MS 0x03
- +#endif
- +#ifndef SERIO_MP
- +# define SERIO_MP 0x04
- +#endif
- +#ifndef SERIO_MZ
- +# define SERIO_MZ 0x05
- +#endif
- +#ifndef SERIO_MZP
- +# define SERIO_MZP 0x06
- +#endif
- +#ifndef SERIO_MZPP
- +# define SERIO_MZPP 0x07
- +#endif
- +#ifndef SERIO_VSXXXAA
- +# define SERIO_VSXXXAA 0x08
- +#endif
- +#ifndef SERIO_SUNKBD
- +# define SERIO_SUNKBD 0x10
- +#endif
- +#ifndef SERIO_WARRIOR
- +# define SERIO_WARRIOR 0x18
- +#endif
- +#ifndef SERIO_SPACEORB
- +# define SERIO_SPACEORB 0x19
- +#endif
- +#ifndef SERIO_MAGELLAN
- +# define SERIO_MAGELLAN 0x1a
- +#endif
- +#ifndef SERIO_SPACEBALL
- +# define SERIO_SPACEBALL 0x1b
- +#endif
- +#ifndef SERIO_GUNZE
- +# define SERIO_GUNZE 0x1c
- +#endif
- +#ifndef SERIO_IFORCE
- +# define SERIO_IFORCE 0x1d
- +#endif
- +#ifndef SERIO_STINGER
- +# define SERIO_STINGER 0x1e
- +#endif
- +#ifndef SERIO_NEWTON
- +# define SERIO_NEWTON 0x1f
- +#endif
- +#ifndef SERIO_STOWAWAY
- +# define SERIO_STOWAWAY 0x20
- +#endif
- +#ifndef SERIO_H3600
- +# define SERIO_H3600 0x21
- +#endif
- +#ifndef SERIO_PS2SER
- +# define SERIO_PS2SER 0x22
- +#endif
- +#ifndef SERIO_TWIDKBD
- +# define SERIO_TWIDKBD 0x23
- +#endif
- +#ifndef SERIO_TWIDJOY
- +# define SERIO_TWIDJOY 0x24
- +#endif
- +#ifndef SERIO_HIL
- +# define SERIO_HIL 0x25
- +#endif
- +#ifndef SERIO_SNES232
- +# define SERIO_SNES232 0x26
- +#endif
- +#ifndef SERIO_SEMTECH
- +# define SERIO_SEMTECH 0x27
- +#endif
- +#ifndef SERIO_LKKBD
- +# define SERIO_LKKBD 0x28
- +#endif
- +#ifndef SERIO_ELO
- +# define SERIO_ELO 0x29
- +#endif
- +#ifndef SERIO_MICROTOUCH
- +# define SERIO_MICROTOUCH 0x30
- +#endif
- +#ifndef SERIO_PENMOUNT
- +# define SERIO_PENMOUNT 0x31
- +#endif
- +#ifndef SERIO_TOUCHRIGHT
- +# define SERIO_TOUCHRIGHT 0x32
- +#endif
- +#ifndef SERIO_TOUCHWIN
- +# define SERIO_TOUCHWIN 0x33
- +#endif
- +#ifndef SERIO_FUJITSU
- +# define SERIO_FUJITSU 0x34
- +#endif
- +
- +#endif
|