Commit ba7376e9 authored by Dmitry Torokhov's avatar Dmitry Torokhov

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

       core support is disabled.
Signed-off-by: default avatarDmitry Torokhov <dtor@mail.ru>
parent 263aba71
...@@ -122,6 +122,9 @@ ...@@ -122,6 +122,9 @@
#include "dm.h" #include "dm.h"
#if defined(CONFIG_GAMEPORT) || (defined(MODULE) && defined(CONFIG_GAMEPORT_MODULE))
#define SUPPORT_JOYSTICK 1
#endif
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
...@@ -365,7 +368,9 @@ struct sv_state { ...@@ -365,7 +368,9 @@ struct sv_state {
unsigned char obuf[MIDIOUTBUF]; unsigned char obuf[MIDIOUTBUF];
} midi; } midi;
#if SUPPORT_JOYSTICK
struct gameport *gameport; struct gameport *gameport;
#endif
}; };
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
...@@ -2485,6 +2490,7 @@ static struct initvol { ...@@ -2485,6 +2490,7 @@ static struct initvol {
#define RSRCISIOREGION(dev,num) (pci_resource_start((dev), (num)) != 0 && \ #define RSRCISIOREGION(dev,num) (pci_resource_start((dev), (num)) != 0 && \
(pci_resource_flags((dev), (num)) & IORESOURCE_IO)) (pci_resource_flags((dev), (num)) & IORESOURCE_IO))
#ifdef SUPPORT_JOYSTICK
static int __devinit sv_register_gameport(struct sv_state *s, int io_port) static int __devinit sv_register_gameport(struct sv_state *s, int io_port)
{ {
struct gameport *gp; struct gameport *gp;
...@@ -2511,6 +2517,19 @@ static int __devinit sv_register_gameport(struct sv_state *s, int io_port) ...@@ -2511,6 +2517,19 @@ static int __devinit sv_register_gameport(struct sv_state *s, int io_port)
return 0; return 0;
} }
static inline void sv_unregister_gameport(struct sv_state *s)
{
if (s->gameport) {
int gpio = s->gameport->io;
gameport_unregister_port(s->gameport);
release_region(gpio, SV_EXTENT_GAME);
}
}
#else
static inline int sv_register_gameport(struct sv_state *s, int io_port) { return -ENOSYS; }
static inline void sv_unregister_gameport(struct sv_state *s) { }
#endif /* SUPPORT_JOYSTICK */
static int __devinit sv_probe(struct pci_dev *pcidev, const struct pci_device_id *pciid) static int __devinit sv_probe(struct pci_dev *pcidev, const struct pci_device_id *pciid)
{ {
static char __devinitdata sv_ddma_name[] = "S3 Inc. SonicVibes DDMA Controller"; static char __devinitdata sv_ddma_name[] = "S3 Inc. SonicVibes DDMA Controller";
...@@ -2711,11 +2730,7 @@ static void __devexit sv_remove(struct pci_dev *dev) ...@@ -2711,11 +2730,7 @@ static void __devexit sv_remove(struct pci_dev *dev)
/*outb(0, s->iodmaa + SV_DMA_RESET);*/ /*outb(0, s->iodmaa + SV_DMA_RESET);*/
/*outb(0, s->iodmac + SV_DMA_RESET);*/ /*outb(0, s->iodmac + SV_DMA_RESET);*/
free_irq(s->irq, s); free_irq(s->irq, s);
if (s->gameport) { sv_unregister_gameport(s);
int gpio = s->gameport->io;
gameport_unregister_port(s->gameport);
release_region(gpio, SV_EXTENT_GAME);
}
release_region(s->iodmac, SV_EXTENT_DMA); release_region(s->iodmac, SV_EXTENT_DMA);
release_region(s->iodmaa, SV_EXTENT_DMA); release_region(s->iodmaa, SV_EXTENT_DMA);
release_region(s->ioenh, SV_EXTENT_ENH); release_region(s->ioenh, SV_EXTENT_ENH);
......
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