1993-10-23 10:55:52 +00:00
|
|
|
/*
|
1994-03-11 10:27:25 +00:00
|
|
|
* sound/dev_table.c
|
1994-04-23 01:50:14 +00:00
|
|
|
*
|
1993-10-23 10:55:52 +00:00
|
|
|
* Device call tables.
|
1994-04-23 01:50:14 +00:00
|
|
|
*
|
1993-10-29 03:44:07 +00:00
|
|
|
* Copyright by Hannu Savolainen 1993
|
1994-04-23 01:50:14 +00:00
|
|
|
*
|
1993-10-29 03:44:07 +00:00
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions are
|
|
|
|
* met: 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer. 2.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
|
|
* and/or other materials provided with the distribution.
|
1994-04-23 01:50:14 +00:00
|
|
|
*
|
1993-10-29 03:44:07 +00:00
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY
|
|
|
|
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
|
|
|
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
|
|
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
1994-04-23 01:50:14 +00:00
|
|
|
*
|
1993-10-23 10:55:52 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#define _DEV_TABLE_C_
|
|
|
|
#include "sound_config.h"
|
|
|
|
|
|
|
|
#ifdef CONFIGURE_SOUNDCARD
|
|
|
|
|
1994-10-01 02:17:17 +00:00
|
|
|
int
|
|
|
|
snd_find_driver (int type)
|
|
|
|
{
|
|
|
|
int i, n = sizeof (sound_drivers) / sizeof (struct driver_info);
|
|
|
|
|
|
|
|
for (i = 0; i < (n - 1); i++)
|
|
|
|
if (sound_drivers[i].card_type == type)
|
|
|
|
return i;
|
|
|
|
|
|
|
|
return -1; /*
|
|
|
|
* Not found
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
1995-12-11 09:26:18 +00:00
|
|
|
static long
|
1993-10-23 10:55:52 +00:00
|
|
|
sndtable_init (long mem_start)
|
|
|
|
{
|
1994-10-01 02:17:17 +00:00
|
|
|
int i, n = sizeof (snd_installed_cards) / sizeof (struct card_info);
|
|
|
|
int drv;
|
1993-10-23 10:55:52 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
printk ("Sound initialization started\n");
|
|
|
|
|
1993-10-23 10:55:52 +00:00
|
|
|
for (i = 0; i < (n - 1); i++)
|
1994-10-01 02:17:17 +00:00
|
|
|
if (snd_installed_cards[i].enabled)
|
|
|
|
if ((drv = snd_find_driver (snd_installed_cards[i].card_type)) == -1)
|
|
|
|
snd_installed_cards[i].enabled = 0; /*
|
|
|
|
* Mark as not detected
|
|
|
|
*/
|
|
|
|
else if (sound_drivers[drv].probe (&snd_installed_cards[i].config))
|
1994-03-11 10:27:25 +00:00
|
|
|
{
|
1993-10-23 10:55:52 +00:00
|
|
|
#ifndef SHORT_BANNERS
|
1994-03-11 10:27:25 +00:00
|
|
|
printk ("snd%d",
|
1994-10-01 02:17:17 +00:00
|
|
|
snd_installed_cards[i].card_type);
|
1993-10-23 10:55:52 +00:00
|
|
|
#endif
|
|
|
|
|
1994-10-01 02:17:17 +00:00
|
|
|
mem_start = sound_drivers[drv].attach (mem_start, &snd_installed_cards[i].config);
|
1993-10-23 10:55:52 +00:00
|
|
|
#ifndef SHORT_BANNERS
|
1994-03-11 10:27:25 +00:00
|
|
|
printk (" at 0x%x irq %d drq %d\n",
|
1994-10-01 02:17:17 +00:00
|
|
|
snd_installed_cards[i].config.io_base,
|
|
|
|
snd_installed_cards[i].config.irq,
|
|
|
|
snd_installed_cards[i].config.dma);
|
1993-10-23 10:55:52 +00:00
|
|
|
#endif
|
1994-03-11 10:27:25 +00:00
|
|
|
}
|
|
|
|
else
|
1994-10-01 02:17:17 +00:00
|
|
|
snd_installed_cards[i].enabled = 0; /*
|
|
|
|
* Mark as not detected
|
|
|
|
*/
|
1995-07-28 21:40:49 +00:00
|
|
|
printk ("Sound initialization complete\n");
|
1993-10-23 10:55:52 +00:00
|
|
|
return mem_start;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
sndtable_probe (int unit, struct address_info *hw_config)
|
1995-07-28 21:40:49 +00:00
|
|
|
{
|
|
|
|
int i, n = sizeof (snd_installed_cards) / sizeof (struct card_info);
|
1993-10-23 10:55:52 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
if (!unit)
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
for (i = 0; i < (n - 1); i++)
|
|
|
|
if (snd_installed_cards[i].enabled)
|
|
|
|
if (snd_installed_cards[i].card_type == unit)
|
|
|
|
{
|
|
|
|
int drv;
|
1993-10-23 10:55:52 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
snd_installed_cards[i].config.io_base = hw_config->io_base;
|
|
|
|
snd_installed_cards[i].config.irq = hw_config->irq;
|
|
|
|
snd_installed_cards[i].config.dma = hw_config->dma;
|
|
|
|
if ((drv = snd_find_driver (snd_installed_cards[i].card_type)) == -1)
|
|
|
|
snd_installed_cards[i].enabled = 0; /*
|
1994-10-01 02:17:17 +00:00
|
|
|
* Mark as not
|
|
|
|
* detected
|
|
|
|
*/
|
1995-07-28 21:40:49 +00:00
|
|
|
else if (sound_drivers[drv].probe (hw_config))
|
|
|
|
return 1;
|
|
|
|
snd_installed_cards[i].enabled = 0; /*
|
1994-10-01 02:17:17 +00:00
|
|
|
* Mark as not detected
|
|
|
|
*/
|
1995-07-28 21:40:49 +00:00
|
|
|
return 0;
|
|
|
|
}
|
1994-10-01 02:17:17 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
1993-10-23 10:55:52 +00:00
|
|
|
|
|
|
|
int
|
|
|
|
sndtable_init_card (int unit, struct address_info *hw_config)
|
1995-07-28 21:40:49 +00:00
|
|
|
{
|
|
|
|
int i, n = sizeof (snd_installed_cards) / sizeof (struct card_info);
|
1993-10-23 10:55:52 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
if (!unit)
|
|
|
|
{
|
|
|
|
if (sndtable_init (0) != 0)
|
|
|
|
panic ("snd: Invalid memory allocation\n");
|
|
|
|
return TRUE;
|
|
|
|
}
|
1993-10-23 10:55:52 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
for (i = 0; i < (n - 1); i++)
|
|
|
|
if (snd_installed_cards[i].card_type == unit)
|
|
|
|
{
|
|
|
|
int drv;
|
1994-10-01 02:17:17 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
snd_installed_cards[i].config.io_base = hw_config->io_base;
|
|
|
|
snd_installed_cards[i].config.irq = hw_config->irq;
|
|
|
|
snd_installed_cards[i].config.dma = hw_config->dma;
|
1994-10-01 02:17:17 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
if ((drv = snd_find_driver (snd_installed_cards[i].card_type)) == -1)
|
|
|
|
snd_installed_cards[i].enabled = 0; /*
|
1994-10-01 02:17:17 +00:00
|
|
|
* Mark as not detected
|
|
|
|
*/
|
1995-07-28 21:40:49 +00:00
|
|
|
else if (sound_drivers[drv].attach (0, hw_config) != 0)
|
|
|
|
panic ("snd#: Invalid memory allocation\n");
|
|
|
|
return TRUE;
|
|
|
|
}
|
1994-10-01 02:17:17 +00:00
|
|
|
|
1995-07-28 21:40:49 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
1993-10-23 10:55:52 +00:00
|
|
|
|
|
|
|
int
|
|
|
|
sndtable_get_cardcount (void)
|
|
|
|
{
|
1994-10-01 02:17:17 +00:00
|
|
|
return num_audiodevs + num_mixers + num_synths + num_midis;
|
1993-10-23 10:55:52 +00:00
|
|
|
}
|
|
|
|
|
1994-03-11 10:27:25 +00:00
|
|
|
struct address_info *
|
|
|
|
sound_getconf (int card_type)
|
|
|
|
{
|
|
|
|
int j, ptr;
|
1994-10-01 02:17:17 +00:00
|
|
|
int n = sizeof (snd_installed_cards) / sizeof (struct card_info);
|
1994-03-11 10:27:25 +00:00
|
|
|
|
|
|
|
ptr = -1;
|
|
|
|
for (j = 0; j < n && ptr == -1; j++)
|
1994-10-01 02:17:17 +00:00
|
|
|
if (snd_installed_cards[j].card_type == card_type)
|
1994-03-11 10:27:25 +00:00
|
|
|
ptr = j;
|
|
|
|
|
|
|
|
if (ptr == -1)
|
|
|
|
return (struct address_info *) NULL;
|
|
|
|
|
1994-10-01 02:17:17 +00:00
|
|
|
return &snd_installed_cards[ptr].config;
|
|
|
|
}
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
void
|
|
|
|
sound_setup (char *str, int *ints)
|
|
|
|
{
|
1994-03-11 10:27:25 +00:00
|
|
|
}
|
1994-04-23 01:50:14 +00:00
|
|
|
|
1993-10-23 10:55:52 +00:00
|
|
|
#endif
|