patch-2.2.14 linux/drivers/char/joystick/joy-turbografx.c
Next file: linux/drivers/char/joystick/joy-warrior.c
Previous file: linux/drivers/char/joystick/joy-thrustmaster.c
Back to the patch index
Back to the overall index
- Lines: 203
- Date:
Tue Jan 4 10:12:14 2000
- Orig file:
v2.2.13/linux/drivers/char/joystick/joy-turbografx.c
- Orig date:
Tue Dec 1 19:05:05 1998
diff -u --recursive --new-file v2.2.13/linux/drivers/char/joystick/joy-turbografx.c linux/drivers/char/joystick/joy-turbografx.c
@@ -1,7 +1,9 @@
/*
* joy-turbografx.c Version 1.2
*
- * Copyright (c) 1998 Vojtech Pavlik
+ * Copyright (c) 1998-1999 Vojtech Pavlik
+ *
+ * Sponsored by SuSE
*/
/*
@@ -26,7 +28,7 @@
* 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:
+ * e-mail - mail your message to <vojtech@suse.cz>, or by paper mail:
* Vojtech Pavlik, Ucitelska 1576, Prague 8, 182 00 Czech Republic
*/
@@ -39,9 +41,10 @@
#include <linux/module.h>
#include <linux/string.h>
#include <linux/delay.h>
+#include <linux/init.h>
-MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
+MODULE_AUTHOR("Vojtech Pavlik <vojtech@suse.cz>");
MODULE_PARM(js_tg, "2-8i");
MODULE_PARM(js_tg_2, "2-8i");
MODULE_PARM(js_tg_3, "2-8i");
@@ -57,18 +60,14 @@
#define JS_TG_BUTTON4 0x01
#define JS_TG_BUTTON5 0x08
-static struct js_port* js_tg_port = NULL;
+static struct js_port* js_tg_port __initdata = NULL;
static int js_tg[] __initdata = { -1, 0, 0, 0, 0, 0, 0, 0 };
static int js_tg_2[] __initdata = { -1, 0, 0, 0, 0, 0, 0, 0 };
static int js_tg_3[] __initdata = { -1, 0, 0, 0, 0, 0, 0, 0 };
struct js_tg_info {
-#ifdef USE_PARPORT
struct pardevice *port; /* parport device */
-#else
- int port; /* hw port */
-#endif
int sticks; /* joysticks connected */
};
@@ -109,9 +108,7 @@
struct js_tg_info *info = dev->port->info;
if (!MOD_IN_USE) {
-#ifdef USE_PARPORT
if (parport_claim(info->port)) return -EBUSY;
-#endif
JS_PAR_CTRL_OUT(0x04, info->port);
}
MOD_INC_USE_COUNT;
@@ -129,9 +126,7 @@
MOD_DEC_USE_COUNT;
if (!MOD_IN_USE) {
JS_PAR_CTRL_OUT(0x00, info->port);
-#ifdef USE_PARPORT
parport_release(info->port);
-#endif
}
return 0;
}
@@ -142,16 +137,12 @@
struct js_tg_info *info;
int i;
- while (js_tg_port != NULL) {
+ while (js_tg_port) {
for (i = 0; i < js_tg_port->ndevs; i++)
- if (js_tg_port->devs[i] != NULL)
+ if (js_tg_port->devs[i])
js_unregister_device(js_tg_port->devs[i]);
info = js_tg_port->info;
-#ifdef USE_PARPORT
parport_unregister_device(info->port);
-#else
- release_region(info->port, 3);
-#endif
js_tg_port = js_unregister_port(js_tg_port);
}
}
@@ -186,33 +177,25 @@
{
struct js_tg_info iniinfo;
struct js_tg_info *info = &iniinfo;
+ struct parport *pp;
int i;
if (config[0] < 0) return port;
-#ifdef USE_PARPORT
- {
- struct parport *pp;
-
- if (config[0] > 0x10)
- for (pp=parport_enumerate(); pp != NULL && (pp->base!=config[0]); pp=pp->next);
- else
- for (pp=parport_enumerate(); pp != NULL && (config[0]>0); pp=pp->next) config[0]--;
-
- if (pp == NULL) {
- printk(KERN_ERR "joy-tg: no such parport\n");
- return port;
- }
- info->port = parport_register_device(pp, "joystick (turbografx)", NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);
- if (!info->port)
- return port;
+ if (config[0] > 0x10)
+ for (pp=parport_enumerate(); pp && (pp->base!=config[0]); pp=pp->next);
+ else
+ for (pp=parport_enumerate(); pp && (config[0]>0); pp=pp->next) config[0]--;
+
+ if (!pp) {
+ printk(KERN_ERR "joy-tg: no such parport\n");
+ return port;
}
-#else
- info->port = config[0];
- if (check_region(info->port, 3)) return port;
- request_region(info->port, 3, "joystick (turbografx)");
-#endif
+
+ info->port = parport_register_device(pp, "joystick (turbografx)", NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);
+ if (!info->port)
+ return port;
port = js_register_port(port, info, 7, sizeof(struct js_tg_info), js_tg_read);
info = port->info;
@@ -221,24 +204,14 @@
for (i = 0; i < 7; i++)
if (config[i+1] > 0 && config[i+1] < 6) {
-#ifdef USE_PARPORT
printk(KERN_INFO "js%d: Multisystem joystick on %s\n",
js_register_device(port, i, 2, config[i+1], "Multisystem joystick", js_tg_open, js_tg_close),
info->port->port->name);
-#else
- printk(KERN_INFO "js%d: Multisystem joystick at %#x\n",
- js_register_device(port, i, 2, config[i+1], "Multisystem joystick", js_tg_open, js_tg_close),
- info->port);
-#endif
info->sticks |= (1 << i);
}
if (!info->sticks) {
-#ifdef USE_PARPORT
parport_unregister_device(info->port);
-#else
- release_region(info->port, 3);
-#endif
return port;
}
@@ -248,18 +221,30 @@
}
#ifndef MODULE
-void __init js_tg_setup(char *str, int *ints)
+int __init js_tg_setup(SETUP_PARAM)
{
int i;
-
- if (!strcmp(str,"js_tg"))
- for (i = 0; i <= ints[0] && i < 2; i++) js_tg[i] = ints[i+1];
- if (!strcmp(str,"js_tg_2"))
- for (i = 0; i <= ints[0] && i < 2; i++) js_tg_2[i] = ints[i+1];
- if (!strcmp(str,"js_tg_3"))
- for (i = 0; i <= ints[0] && i < 2; i++) js_tg_3[i] = ints[i+1];
-
+ SETUP_PARSE(2);
+ for (i = 0; i <= ints[0] && i < 2; i++) js_tg[i] = ints[i+1];
+ return 1;
}
+int __init js_tg_setup_2(SETUP_PARAM)
+{
+ int i;
+ SETUP_PARSE(2);
+ for (i = 0; i <= ints[0] && i < 2; i++) js_tg_2[i] = ints[i+1];
+ return 1;
+}
+int __init js_tg_setup_3(SETUP_PARAM)
+{
+ int i;
+ SETUP_PARSE(2);
+ for (i = 0; i <= ints[0] && i < 2; i++) js_tg_3[i] = ints[i+1];
+ return 1;
+}
+__setup("js_tg=", js_tg_setup);
+__setup("js_tg_2=", js_tg_setup_2);
+__setup("js_tg_3=", js_tg_setup_3);
#endif
#ifdef MODULE
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)