diff options
author | Len Brown <len.brown@intel.com> | 2005-12-22 22:01:55 -0500 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2005-12-22 22:01:55 -0500 |
commit | db9ace7083dbdcc3d02bdd6a1d26132c80b5b726 (patch) | |
tree | 022e1162c2ef3f83d6214fdc7f3678bc5545714a /drivers/media/video/saa7134/saa7134-oss.c | |
parent | d8bcd8e41576809f276fa44be5012568296cce41 (diff) | |
parent | c162eeaa21fde6c27112690f5bc0a461a9f1763e (diff) | |
download | op-kernel-dev-db9ace7083dbdcc3d02bdd6a1d26132c80b5b726.zip op-kernel-dev-db9ace7083dbdcc3d02bdd6a1d26132c80b5b726.tar.gz |
Auto-update from upstream
Diffstat (limited to 'drivers/media/video/saa7134/saa7134-oss.c')
-rw-r--r-- | drivers/media/video/saa7134/saa7134-oss.c | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/drivers/media/video/saa7134/saa7134-oss.c b/drivers/media/video/saa7134/saa7134-oss.c index 513a699..8badd2a 100644 --- a/drivers/media/video/saa7134/saa7134-oss.c +++ b/drivers/media/video/saa7134/saa7134-oss.c @@ -959,8 +959,17 @@ static int saa7134_oss_init(void) struct saa7134_dev *dev = NULL; struct list_head *list; + if (!dmasound_init && !dmasound_exit) { + dmasound_init = oss_device_init; + dmasound_exit = oss_device_exit; + } else { + printk(KERN_WARNING "saa7134 OSS: can't load, DMA sound handler already assigned (probably to ALSA)\n"); + return -EBUSY; + } + printk(KERN_INFO "saa7134 OSS driver for DMA sound loaded\n"); + list_for_each(list,&saa7134_devlist) { dev = list_entry(list, struct saa7134_dev, devlist); if (dev->dmasound.priv_data == NULL) { @@ -974,9 +983,6 @@ static int saa7134_oss_init(void) if (dev == NULL) printk(KERN_INFO "saa7134 OSS: no saa7134 cards found\n"); - dmasound_init = oss_device_init; - dmasound_exit = oss_device_exit; - return 0; } @@ -997,12 +1003,16 @@ static void saa7134_oss_exit(void) } + dmasound_init = NULL; + dmasound_exit = NULL; + printk(KERN_INFO "saa7134 OSS driver for DMA sound unloaded\n"); return; } -module_init(saa7134_oss_init); +/* We initialize this late, to make sure the sound system is up and running */ +late_initcall(saa7134_oss_init); module_exit(saa7134_oss_exit); MODULE_LICENSE("GPL"); MODULE_AUTHOR("Gerd Knorr <kraxel@bytesex.org> [SuSE Labs]"); |