Blame view
sound/core/info_oss.c
3.87 KB
1da177e4c
|
1 2 |
/* * Information interface for ALSA driver |
c1017a4cd
|
3 |
* Copyright (c) by Jaroslav Kysela <perex@perex.cz> |
1da177e4c
|
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
* * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */ |
1da177e4c
|
21 22 |
#include <linux/slab.h> #include <linux/time.h> |
543537bd9
|
23 |
#include <linux/string.h> |
1da177e4c
|
24 25 26 27 28 |
#include <sound/core.h> #include <sound/minors.h> #include <sound/info.h> #include <sound/version.h> #include <linux/utsname.h> |
1a60d4c5a
|
29 |
#include <linux/mutex.h> |
1da177e4c
|
30 31 32 33 34 35 |
#if defined(CONFIG_SND_OSSEMUL) && defined(CONFIG_PROC_FS) /* * OSS compatible part */ |
1a60d4c5a
|
36 |
static DEFINE_MUTEX(strings); |
1da177e4c
|
37 |
static char *snd_sndstat_strings[SNDRV_CARDS][SNDRV_OSS_INFO_DEV_COUNT]; |
174c1f65e
|
38 |
static struct snd_info_entry *snd_sndstat_proc_entry; |
1da177e4c
|
39 40 41 42 |
int snd_oss_info_register(int dev, int num, char *string) { char *x; |
7eaa943c8
|
43 44 45 46 |
if (snd_BUG_ON(dev < 0 || dev >= SNDRV_OSS_INFO_DEV_COUNT)) return -ENXIO; if (snd_BUG_ON(num < 0 || num >= SNDRV_CARDS)) return -ENXIO; |
1a60d4c5a
|
47 |
mutex_lock(&strings); |
1da177e4c
|
48 49 50 51 52 53 |
if (string == NULL) { if ((x = snd_sndstat_strings[num][dev]) != NULL) { kfree(x); x = NULL; } } else { |
543537bd9
|
54 |
x = kstrdup(string, GFP_KERNEL); |
1da177e4c
|
55 |
if (x == NULL) { |
1a60d4c5a
|
56 |
mutex_unlock(&strings); |
1da177e4c
|
57 58 59 60 |
return -ENOMEM; } } snd_sndstat_strings[num][dev] = x; |
1a60d4c5a
|
61 |
mutex_unlock(&strings); |
1da177e4c
|
62 63 |
return 0; } |
c0d3fb39e
|
64 |
EXPORT_SYMBOL(snd_oss_info_register); |
174c1f65e
|
65 |
static int snd_sndstat_show_strings(struct snd_info_buffer *buf, char *id, int dev) |
1da177e4c
|
66 67 68 69 70 71 |
{ int idx, ok = -1; char *str; snd_iprintf(buf, " %s:", id); |
1a60d4c5a
|
72 |
mutex_lock(&strings); |
1da177e4c
|
73 74 75 76 77 78 79 80 81 82 83 84 |
for (idx = 0; idx < SNDRV_CARDS; idx++) { str = snd_sndstat_strings[idx][dev]; if (str) { if (ok < 0) { snd_iprintf(buf, " "); ok++; } snd_iprintf(buf, "%i: %s ", idx, str); } } |
1a60d4c5a
|
85 |
mutex_unlock(&strings); |
1da177e4c
|
86 87 88 89 90 |
if (ok < 0) snd_iprintf(buf, " NOT ENABLED IN CONFIG "); return ok; } |
174c1f65e
|
91 92 |
static void snd_sndstat_proc_read(struct snd_info_entry *entry, struct snd_info_buffer *buffer) |
1da177e4c
|
93 94 95 96 97 |
{ snd_iprintf(buffer, "Sound Driver:3.8.1a-980706 (ALSA v" CONFIG_SND_VERSION " emulation code) "); snd_iprintf(buffer, "Kernel: %s %s %s %s %s ", |
96b644bde
|
98 99 100 101 102 |
init_utsname()->sysname, init_utsname()->nodename, init_utsname()->release, init_utsname()->version, init_utsname()->machine); |
1da177e4c
|
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 |
snd_iprintf(buffer, "Config options: 0 "); snd_iprintf(buffer, " Installed drivers: "); snd_iprintf(buffer, "Type 10: ALSA emulation "); snd_iprintf(buffer, " Card config: "); snd_card_info_read_oss(buffer); snd_sndstat_show_strings(buffer, "Audio devices", SNDRV_OSS_INFO_DEV_AUDIO); snd_sndstat_show_strings(buffer, "Synth devices", SNDRV_OSS_INFO_DEV_SYNTH); snd_sndstat_show_strings(buffer, "Midi devices", SNDRV_OSS_INFO_DEV_MIDI); snd_sndstat_show_strings(buffer, "Timers", SNDRV_OSS_INFO_DEV_TIMERS); snd_sndstat_show_strings(buffer, "Mixers", SNDRV_OSS_INFO_DEV_MIXERS); } int snd_info_minor_register(void) { |
174c1f65e
|
123 |
struct snd_info_entry *entry; |
1da177e4c
|
124 125 126 |
memset(snd_sndstat_strings, 0, sizeof(snd_sndstat_strings)); if ((entry = snd_info_create_module_entry(THIS_MODULE, "sndstat", snd_oss_root)) != NULL) { |
1da177e4c
|
127 128 129 130 131 132 133 134 135 136 137 138 |
entry->c.text.read = snd_sndstat_proc_read; if (snd_info_register(entry) < 0) { snd_info_free_entry(entry); entry = NULL; } } snd_sndstat_proc_entry = entry; return 0; } int snd_info_minor_unregister(void) { |
746d4a02e
|
139 140 |
snd_info_free_entry(snd_sndstat_proc_entry); snd_sndstat_proc_entry = NULL; |
1da177e4c
|
141 142 143 144 |
return 0; } #endif /* CONFIG_SND_OSSEMUL */ |