Commit 04b6389a authored by Dmitry Torokhov's avatar Dmitry Torokhov

Input: ESS Solo (OSS) - do not carry around gameport code if gameport

       core support is disabled.
Signed-off-by: default avatarDmitry Torokhov <dtor@mail.ru>
parent 3f9f17d4
...@@ -149,6 +149,10 @@ ...@@ -149,6 +149,10 @@
#define FMODE_DMFM 0x10 #define FMODE_DMFM 0x10
#if defined(CONFIG_GAMEPORT) || (defined(MODULE) && defined(CONFIG_GAMEPORT_MODULE))
#define SUPPORT_JOYSTICK 1
#endif
static struct pci_driver solo1_driver; static struct pci_driver solo1_driver;
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
...@@ -226,7 +230,9 @@ struct solo1_state { ...@@ -226,7 +230,9 @@ struct solo1_state {
unsigned char obuf[MIDIOUTBUF]; unsigned char obuf[MIDIOUTBUF];
} midi; } midi;
#if SUPPORT_JOYSTICK
struct gameport *gameport; struct gameport *gameport;
#endif
}; };
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
...@@ -2280,6 +2286,7 @@ solo1_resume(struct pci_dev *pci_dev) { ...@@ -2280,6 +2286,7 @@ solo1_resume(struct pci_dev *pci_dev) {
return 0; return 0;
} }
#ifdef SUPPORT_JOYSTICK
static int __devinit solo1_register_gameport(struct solo1_state *s, int io_port) static int __devinit solo1_register_gameport(struct solo1_state *s, int io_port)
{ {
struct gameport *gp; struct gameport *gp;
...@@ -2306,6 +2313,19 @@ static int __devinit solo1_register_gameport(struct solo1_state *s, int io_port) ...@@ -2306,6 +2313,19 @@ static int __devinit solo1_register_gameport(struct solo1_state *s, int io_port)
return 0; return 0;
} }
static inline void solo1_unregister_gameport(struct solo1_state *s)
{
if (s->gameport) {
int gpio = s->gameport->io;
gameport_unregister_port(s->gameport);
release_region(gpio, GAMEPORT_EXTENT);
}
}
#else
static inline int solo1_register_gameport(struct solo1_state *s, int io_port) { return -ENOSYS; }
static inline void solo1_unregister_gameport(struct solo1_state *s) { }
#endif /* SUPPORT_JOYSTICK */
static int __devinit solo1_probe(struct pci_dev *pcidev, const struct pci_device_id *pciid) static int __devinit solo1_probe(struct pci_dev *pcidev, const struct pci_device_id *pciid)
{ {
struct solo1_state *s; struct solo1_state *s;
...@@ -2437,11 +2457,7 @@ static void __devexit solo1_remove(struct pci_dev *dev) ...@@ -2437,11 +2457,7 @@ static void __devexit solo1_remove(struct pci_dev *dev)
synchronize_irq(s->irq); synchronize_irq(s->irq);
pci_write_config_word(s->dev, 0x60, 0); /* turn off DDMA controller address space */ pci_write_config_word(s->dev, 0x60, 0); /* turn off DDMA controller address space */
free_irq(s->irq, s); free_irq(s->irq, s);
if (s->gameport) { solo1_unregister_gameport(s);
int gpio = s->gameport->io;
gameport_unregister_port(s->gameport);
release_region(gpio, GAMEPORT_EXTENT);
}
release_region(s->iobase, IOBASE_EXTENT); release_region(s->iobase, IOBASE_EXTENT);
release_region(s->sbbase+FMSYNTH_EXTENT, SBBASE_EXTENT-FMSYNTH_EXTENT); release_region(s->sbbase+FMSYNTH_EXTENT, SBBASE_EXTENT-FMSYNTH_EXTENT);
release_region(s->ddmabase, DDMABASE_EXTENT); release_region(s->ddmabase, DDMABASE_EXTENT);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment