patch-2.4.19 linux-2.4.19/drivers/sound/mad16.c
Next file: linux-2.4.19/drivers/sound/maestro.c
Previous file: linux-2.4.19/drivers/sound/ite8172.c
Back to the patch index
Back to the overall index
- Lines: 91
- Date:
Fri Aug 2 17:39:44 2002
- Orig file:
linux-2.4.18/drivers/sound/mad16.c
- Orig date:
Sun Sep 30 12:26:08 2001
diff -urN linux-2.4.18/drivers/sound/mad16.c linux-2.4.19/drivers/sound/mad16.c
@@ -42,6 +42,7 @@
#include <linux/config.h>
#include <linux/init.h>
#include <linux/module.h>
+#include <linux/gameport.h>
#include "sound_config.h"
@@ -51,6 +52,7 @@
static int mad16_conf;
static int mad16_cdsel;
+static struct gameport gameport;
static int already_initialized = 0;
@@ -664,13 +666,13 @@
outb((bits | dma_bits[dma] | dma2_bit), config_port); /* Write IRQ+DMA setup */
- hw_config->slots[0] = ad1848_init("MAD16 WSS", hw_config->io_base + 4,
+ hw_config->slots[0] = ad1848_init("mad16 WSS", hw_config->io_base + 4,
hw_config->irq,
dma,
dma2, 0,
hw_config->osp,
THIS_MODULE);
- request_region(hw_config->io_base, 4, "MAD16 WSS config");
+ request_region(hw_config->io_base, 4, "mad16 WSS config");
}
static int __init probe_mad16_mpu(struct address_info *hw_config)
@@ -1010,14 +1012,6 @@
}
printk(".\n");
- printk(KERN_INFO "Joystick port ");
- if (joystick == 1)
- printk("enabled.\n");
- else
- {
- joystick = 0;
- printk("disabled.\n");
- }
cfg.io_base = io;
cfg.irq = irq;
@@ -1038,6 +1032,18 @@
attach_mad16(&cfg);
found_mpu = probe_mad16_mpu(&cfg_mpu);
+
+ if (joystick == 1) {
+ /* register gameport */
+ if (!request_region(0x201, 1, "mad16 gameport"))
+ printk(KERN_ERR "mad16: gameport address 0x201 already in use\n");
+ else {
+ printk(KERN_ERR "mad16: gameport enabled at 0x201\n");
+ gameport.io = 0x201;
+ gameport_register_port(&gameport);
+ }
+ }
+ else printk(KERN_ERR "mad16: gameport disabled.\n");
return 0;
}
@@ -1055,16 +1061,17 @@
static int __init setup_mad16(char *str)
{
/* io, irq */
- int ints[7];
+ int ints[8];
str = get_options(str, ARRAY_SIZE(ints), ints);
- io = ints[1];
- irq = ints[2];
- dma = ints[3];
- dma16 = ints[4];
- mpu_io = ints[5];
- mpu_irq = ints[6];
+ io = ints[1];
+ irq = ints[2];
+ dma = ints[3];
+ dma16 = ints[4];
+ mpu_io = ints[5];
+ mpu_irq = ints[6];
+ joystick = ints[7];
return 1;
}
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)