]> git.proxmox.com Git - mirror_ubuntu-zesty-kernel.git/blob - include/sound/info.h
ALSA: core: Remove child proc file elements recursively
[mirror_ubuntu-zesty-kernel.git] / include / sound / info.h
1 #ifndef __SOUND_INFO_H
2 #define __SOUND_INFO_H
3
4 /*
5 * Header file for info interface
6 * Copyright (c) by Jaroslav Kysela <perex@perex.cz>
7 *
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 *
23 */
24
25 #include <linux/poll.h>
26 #include <linux/seq_file.h>
27 #include <sound/core.h>
28
29 /* buffer for information */
30 struct snd_info_buffer {
31 char *buffer; /* pointer to begin of buffer */
32 unsigned int curr; /* current position in buffer */
33 unsigned int size; /* current size */
34 unsigned int len; /* total length of buffer */
35 int stop; /* stop flag */
36 int error; /* error code */
37 };
38
39 #define SNDRV_INFO_CONTENT_TEXT 0
40 #define SNDRV_INFO_CONTENT_DATA 1
41
42 struct snd_info_entry;
43
44 struct snd_info_entry_text {
45 void (*read)(struct snd_info_entry *entry,
46 struct snd_info_buffer *buffer);
47 void (*write)(struct snd_info_entry *entry,
48 struct snd_info_buffer *buffer);
49 };
50
51 struct snd_info_entry_ops {
52 int (*open)(struct snd_info_entry *entry,
53 unsigned short mode, void **file_private_data);
54 int (*release)(struct snd_info_entry *entry,
55 unsigned short mode, void *file_private_data);
56 ssize_t (*read)(struct snd_info_entry *entry, void *file_private_data,
57 struct file *file, char __user *buf,
58 size_t count, loff_t pos);
59 ssize_t (*write)(struct snd_info_entry *entry, void *file_private_data,
60 struct file *file, const char __user *buf,
61 size_t count, loff_t pos);
62 loff_t (*llseek)(struct snd_info_entry *entry,
63 void *file_private_data, struct file *file,
64 loff_t offset, int orig);
65 unsigned int (*poll)(struct snd_info_entry *entry,
66 void *file_private_data, struct file *file,
67 poll_table *wait);
68 int (*ioctl)(struct snd_info_entry *entry, void *file_private_data,
69 struct file *file, unsigned int cmd, unsigned long arg);
70 int (*mmap)(struct snd_info_entry *entry, void *file_private_data,
71 struct inode *inode, struct file *file,
72 struct vm_area_struct *vma);
73 };
74
75 struct snd_info_entry {
76 const char *name;
77 umode_t mode;
78 long size;
79 unsigned short content;
80 union {
81 struct snd_info_entry_text text;
82 struct snd_info_entry_ops *ops;
83 } c;
84 struct snd_info_entry *parent;
85 struct snd_card *card;
86 struct module *module;
87 void *private_data;
88 void (*private_free)(struct snd_info_entry *entry);
89 struct proc_dir_entry *p;
90 struct mutex access;
91 struct list_head children;
92 struct list_head list;
93 };
94
95 #if defined(CONFIG_SND_OSSEMUL) && defined(CONFIG_PROC_FS)
96 int snd_info_minor_register(void);
97 int snd_info_minor_unregister(void);
98 #else
99 #define snd_info_minor_register() /* NOP */
100 #define snd_info_minor_unregister() /* NOP */
101 #endif
102
103
104 #ifdef CONFIG_PROC_FS
105
106 extern struct snd_info_entry *snd_seq_root;
107 #ifdef CONFIG_SND_OSSEMUL
108 extern struct snd_info_entry *snd_oss_root;
109 void snd_card_info_read_oss(struct snd_info_buffer *buffer);
110 #else
111 #define snd_oss_root NULL
112 static inline void snd_card_info_read_oss(struct snd_info_buffer *buffer) {}
113 #endif
114
115 /**
116 * snd_iprintf - printf on the procfs buffer
117 * @buf: the procfs buffer
118 * @fmt: the printf format
119 *
120 * Outputs the string on the procfs buffer just like printf().
121 *
122 * Return: zero for success, or a negative error code.
123 */
124 #define snd_iprintf(buf, fmt, args...) \
125 seq_printf((struct seq_file *)(buf)->buffer, fmt, ##args)
126
127 int snd_info_init(void);
128 int snd_info_done(void);
129
130 int snd_info_get_line(struct snd_info_buffer *buffer, char *line, int len);
131 const char *snd_info_get_str(char *dest, const char *src, int len);
132 struct snd_info_entry *snd_info_create_module_entry(struct module *module,
133 const char *name,
134 struct snd_info_entry *parent);
135 struct snd_info_entry *snd_info_create_card_entry(struct snd_card *card,
136 const char *name,
137 struct snd_info_entry *parent);
138 void snd_info_free_entry(struct snd_info_entry *entry);
139 int snd_info_store_text(struct snd_info_entry *entry);
140 int snd_info_restore_text(struct snd_info_entry *entry);
141
142 int snd_info_card_create(struct snd_card *card);
143 int snd_info_card_register(struct snd_card *card);
144 int snd_info_card_free(struct snd_card *card);
145 void snd_info_card_disconnect(struct snd_card *card);
146 void snd_info_card_id_change(struct snd_card *card);
147 int snd_info_register(struct snd_info_entry *entry);
148
149 /* for card drivers */
150 static inline int snd_card_proc_new(struct snd_card *card, const char *name,
151 struct snd_info_entry **entryp)
152 {
153 *entryp = snd_info_create_card_entry(card, name, card->proc_root);
154 return *entryp ? 0 : -ENOMEM;
155 }
156
157 static inline void snd_info_set_text_ops(struct snd_info_entry *entry,
158 void *private_data,
159 void (*read)(struct snd_info_entry *, struct snd_info_buffer *))
160 {
161 entry->private_data = private_data;
162 entry->c.text.read = read;
163 }
164
165 int snd_info_check_reserved_words(const char *str);
166
167 #else
168
169 #define snd_seq_root NULL
170 #define snd_oss_root NULL
171
172 static inline int snd_iprintf(struct snd_info_buffer *buffer, char *fmt, ...) { return 0; }
173 static inline int snd_info_init(void) { return 0; }
174 static inline int snd_info_done(void) { return 0; }
175
176 static inline int snd_info_get_line(struct snd_info_buffer *buffer, char *line, int len) { return 0; }
177 static inline char *snd_info_get_str(char *dest, char *src, int len) { return NULL; }
178 static inline struct snd_info_entry *snd_info_create_module_entry(struct module *module, const char *name, struct snd_info_entry *parent) { return NULL; }
179 static inline struct snd_info_entry *snd_info_create_card_entry(struct snd_card *card, const char *name, struct snd_info_entry *parent) { return NULL; }
180 static inline void snd_info_free_entry(struct snd_info_entry *entry) { ; }
181
182 static inline int snd_info_card_create(struct snd_card *card) { return 0; }
183 static inline int snd_info_card_register(struct snd_card *card) { return 0; }
184 static inline int snd_info_card_free(struct snd_card *card) { return 0; }
185 static inline void snd_info_card_disconnect(struct snd_card *card) { }
186 static inline void snd_info_card_id_change(struct snd_card *card) { }
187 static inline int snd_info_register(struct snd_info_entry *entry) { return 0; }
188
189 static inline int snd_card_proc_new(struct snd_card *card, const char *name,
190 struct snd_info_entry **entryp) { return -EINVAL; }
191 static inline void snd_info_set_text_ops(struct snd_info_entry *entry __attribute__((unused)),
192 void *private_data,
193 void (*read)(struct snd_info_entry *, struct snd_info_buffer *)) {}
194 static inline int snd_info_check_reserved_words(const char *str) { return 1; }
195
196 #endif
197
198 /*
199 * OSS info part
200 */
201
202 #if defined(CONFIG_SND_OSSEMUL) && defined(CONFIG_PROC_FS)
203
204 #define SNDRV_OSS_INFO_DEV_AUDIO 0
205 #define SNDRV_OSS_INFO_DEV_SYNTH 1
206 #define SNDRV_OSS_INFO_DEV_MIDI 2
207 #define SNDRV_OSS_INFO_DEV_TIMERS 4
208 #define SNDRV_OSS_INFO_DEV_MIXERS 5
209
210 #define SNDRV_OSS_INFO_DEV_COUNT 6
211
212 int snd_oss_info_register(int dev, int num, char *string);
213 #define snd_oss_info_unregister(dev, num) snd_oss_info_register(dev, num, NULL)
214
215 #endif /* CONFIG_SND_OSSEMUL && CONFIG_PROC_FS */
216
217 #endif /* __SOUND_INFO_H */