blob: 97fdda41e0763ac57f5aa4e9cc1300d77c71702b [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __SOUND_INFO_H
2#define __SOUND_INFO_H
3
4/*
5 * Header file for info interface
Jaroslav Kyselac1017a42007-10-15 09:50:19 +02006 * Copyright (c) by Jaroslav Kysela <perex@perex.cz>
Linus Torvalds1da177e2005-04-16 15:20:36 -07007 *
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>
Takashi Iwai4adb7bc2015-04-22 16:10:22 +020026#include <linux/seq_file.h>
Takashi Iwaic560a672015-04-22 18:26:38 +020027#include <sound/core.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
29/* buffer for information */
30struct snd_info_buffer {
31 char *buffer; /* pointer to begin of buffer */
Takashi Iwai7e4eeec2006-04-28 15:13:40 +020032 unsigned int curr; /* current position in buffer */
33 unsigned int size; /* current size */
34 unsigned int len; /* total length of buffer */
Linus Torvalds1da177e2005-04-16 15:20:36 -070035 int stop; /* stop flag */
36 int error; /* error code */
37};
38
Linus Torvalds1da177e2005-04-16 15:20:36 -070039#define SNDRV_INFO_CONTENT_TEXT 0
40#define SNDRV_INFO_CONTENT_DATA 1
41
42struct snd_info_entry;
43
44struct snd_info_entry_text {
Jaroslav Kyselafd641382008-11-12 16:53:47 +010045 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);
Linus Torvalds1da177e2005-04-16 15:20:36 -070049};
50
51struct snd_info_entry_ops {
Jaroslav Kyselafd641382008-11-12 16:53:47 +010052 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);
Takashi Iwai24e4a122010-04-13 11:22:01 +020056 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);
Al Viroa3f86832017-07-02 22:22:01 -040065 __poll_t (*poll)(struct snd_info_entry *entry,
Takashi Iwai24e4a122010-04-13 11:22:01 +020066 void *file_private_data, struct file *file,
67 poll_table *wait);
Jaroslav Kyselafd641382008-11-12 16:53:47 +010068 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);
Linus Torvalds1da177e2005-04-16 15:20:36 -070073};
74
75struct snd_info_entry {
76 const char *name;
Al Virod161a132011-07-24 03:36:29 -040077 umode_t mode;
Linus Torvalds1da177e2005-04-16 15:20:36 -070078 long size;
79 unsigned short content;
Linus Torvalds1da177e2005-04-16 15:20:36 -070080 union {
81 struct snd_info_entry_text text;
82 struct snd_info_entry_ops *ops;
83 } c;
Takashi Iwai24c1f932005-11-17 13:58:48 +010084 struct snd_info_entry *parent;
Linus Torvalds1da177e2005-04-16 15:20:36 -070085 struct module *module;
86 void *private_data;
Takashi Iwai24c1f932005-11-17 13:58:48 +010087 void (*private_free)(struct snd_info_entry *entry);
Linus Torvalds1da177e2005-04-16 15:20:36 -070088 struct proc_dir_entry *p;
Ingo Molnar1a60d4c2006-01-16 16:29:08 +010089 struct mutex access;
Takashi Iwai746d4a02006-06-23 14:37:59 +020090 struct list_head children;
91 struct list_head list;
Linus Torvalds1da177e2005-04-16 15:20:36 -070092};
93
Jie Yangcd6a6502015-05-27 19:45:45 +080094#if defined(CONFIG_SND_OSSEMUL) && defined(CONFIG_SND_PROC_FS)
Takashi Iwai24c1f932005-11-17 13:58:48 +010095int snd_info_minor_register(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -070096#else
Takashi Iwaia0dca822015-04-23 10:56:21 +020097#define snd_info_minor_register() 0
Linus Torvalds1da177e2005-04-16 15:20:36 -070098#endif
99
100
Jie Yangcd6a6502015-05-27 19:45:45 +0800101#ifdef CONFIG_SND_PROC_FS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700102
Takashi Iwai24c1f932005-11-17 13:58:48 +0100103extern struct snd_info_entry *snd_seq_root;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104#ifdef CONFIG_SND_OSSEMUL
Takashi Iwai24c1f932005-11-17 13:58:48 +0100105extern struct snd_info_entry *snd_oss_root;
Marcin Ślusarz36b9cdf2007-12-14 12:58:45 +0100106void snd_card_info_read_oss(struct snd_info_buffer *buffer);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700107#else
108#define snd_oss_root NULL
Marcin Ślusarz36b9cdf2007-12-14 12:58:45 +0100109static inline void snd_card_info_read_oss(struct snd_info_buffer *buffer) {}
Linus Torvalds1da177e2005-04-16 15:20:36 -0700110#endif
111
Takashi Iwai4adb7bc2015-04-22 16:10:22 +0200112/**
113 * snd_iprintf - printf on the procfs buffer
114 * @buf: the procfs buffer
115 * @fmt: the printf format
116 *
117 * Outputs the string on the procfs buffer just like printf().
118 *
119 * Return: zero for success, or a negative error code.
120 */
121#define snd_iprintf(buf, fmt, args...) \
122 seq_printf((struct seq_file *)(buf)->buffer, fmt, ##args)
123
Linus Torvalds1da177e2005-04-16 15:20:36 -0700124int snd_info_init(void);
125int snd_info_done(void);
126
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100127int snd_info_get_line(struct snd_info_buffer *buffer, char *line, int len);
Takashi Iwai4f7454a2009-09-08 14:29:58 +0200128const char *snd_info_get_str(char *dest, const char *src, int len);
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100129struct snd_info_entry *snd_info_create_module_entry(struct module *module,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700130 const char *name,
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100131 struct snd_info_entry *parent);
132struct snd_info_entry *snd_info_create_card_entry(struct snd_card *card,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700133 const char *name,
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100134 struct snd_info_entry *parent);
135void snd_info_free_entry(struct snd_info_entry *entry);
136int snd_info_store_text(struct snd_info_entry *entry);
137int snd_info_restore_text(struct snd_info_entry *entry);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700138
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100139int snd_info_card_create(struct snd_card *card);
140int snd_info_card_register(struct snd_card *card);
141int snd_info_card_free(struct snd_card *card);
142void snd_info_card_disconnect(struct snd_card *card);
143void snd_info_card_id_change(struct snd_card *card);
144int snd_info_register(struct snd_info_entry *entry);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145
146/* for card drivers */
Takashi Iwaic560a672015-04-22 18:26:38 +0200147static inline int snd_card_proc_new(struct snd_card *card, const char *name,
148 struct snd_info_entry **entryp)
149{
150 *entryp = snd_info_create_card_entry(card, name, card->proc_root);
151 return *entryp ? 0 : -ENOMEM;
152}
Linus Torvalds1da177e2005-04-16 15:20:36 -0700153
Takashi Iwai24c1f932005-11-17 13:58:48 +0100154static inline void snd_info_set_text_ops(struct snd_info_entry *entry,
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100155 void *private_data,
156 void (*read)(struct snd_info_entry *, struct snd_info_buffer *))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157{
158 entry->private_data = private_data;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700159 entry->c.text.read = read;
160}
161
Takashi Iwai7453e1d2019-02-04 14:53:04 +0100162int snd_card_rw_proc_new(struct snd_card *card, const char *name,
163 void *private_data,
164 void (*read)(struct snd_info_entry *,
165 struct snd_info_buffer *),
166 void (*write)(struct snd_info_entry *entry,
167 struct snd_info_buffer *buffer));
168
Takashi Iwaie28563c2005-12-01 10:42:42 +0100169int snd_info_check_reserved_words(const char *str);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700170
171#else
172
173#define snd_seq_root NULL
174#define snd_oss_root NULL
175
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100176static inline int snd_iprintf(struct snd_info_buffer *buffer, char *fmt, ...) { return 0; }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700177static inline int snd_info_init(void) { return 0; }
178static inline int snd_info_done(void) { return 0; }
179
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100180static inline int snd_info_get_line(struct snd_info_buffer *buffer, char *line, int len) { return 0; }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700181static inline char *snd_info_get_str(char *dest, char *src, int len) { return NULL; }
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100182static inline struct snd_info_entry *snd_info_create_module_entry(struct module *module, const char *name, struct snd_info_entry *parent) { return NULL; }
183static inline struct snd_info_entry *snd_info_create_card_entry(struct snd_card *card, const char *name, struct snd_info_entry *parent) { return NULL; }
184static inline void snd_info_free_entry(struct snd_info_entry *entry) { ; }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700185
Jaroslav Kyselafd641382008-11-12 16:53:47 +0100186static inline int snd_info_card_create(struct snd_card *card) { return 0; }
187static inline int snd_info_card_register(struct snd_card *card) { return 0; }
188static inline int snd_info_card_free(struct snd_card *card) { return 0; }
189static inline void snd_info_card_disconnect(struct snd_card *card) { }
190static inline void snd_info_card_id_change(struct snd_card *card) { }
191static inline int snd_info_register(struct snd_info_entry *entry) { return 0; }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700192
Takashi Iwaie28563c2005-12-01 10:42:42 +0100193static inline int snd_card_proc_new(struct snd_card *card, const char *name,
194 struct snd_info_entry **entryp) { return -EINVAL; }
195static inline void snd_info_set_text_ops(struct snd_info_entry *entry __attribute__((unused)),
196 void *private_data,
Takashi Iwaie28563c2005-12-01 10:42:42 +0100197 void (*read)(struct snd_info_entry *, struct snd_info_buffer *)) {}
Takashi Iwai7453e1d2019-02-04 14:53:04 +0100198static inline int snd_card_rw_proc_new(struct snd_card *card, const char *name,
199 void *private_data,
200 void (*read)(struct snd_info_entry *,
201 struct snd_info_buffer *),
202 void (*write)(struct snd_info_entry *entry,
203 struct snd_info_buffer *buffer))
204{
205 return 0;
206}
Takashi Iwaie28563c2005-12-01 10:42:42 +0100207static inline int snd_info_check_reserved_words(const char *str) { return 1; }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700208
209#endif
210
Takashi Iwai7453e1d2019-02-04 14:53:04 +0100211/**
212 * snd_card_ro_proc_new - Create a read-only text proc file entry for the card
213 * @card: the card instance
214 * @name: the file name
215 * @private_data: the arbitrary private data
216 * @read: the read callback
217 *
218 * This proc file entry will be registered via snd_card_register() call, and
219 * it will be removed automatically at the card removal, too.
220 */
221static inline int
222snd_card_ro_proc_new(struct snd_card *card, const char *name,
223 void *private_data,
224 void (*read)(struct snd_info_entry *,
225 struct snd_info_buffer *))
226{
227 return snd_card_rw_proc_new(card, name, private_data, read, NULL);
228}
229
Linus Torvalds1da177e2005-04-16 15:20:36 -0700230/*
231 * OSS info part
232 */
233
Jie Yangcd6a6502015-05-27 19:45:45 +0800234#if defined(CONFIG_SND_OSSEMUL) && defined(CONFIG_SND_PROC_FS)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700235
236#define SNDRV_OSS_INFO_DEV_AUDIO 0
237#define SNDRV_OSS_INFO_DEV_SYNTH 1
238#define SNDRV_OSS_INFO_DEV_MIDI 2
239#define SNDRV_OSS_INFO_DEV_TIMERS 4
240#define SNDRV_OSS_INFO_DEV_MIXERS 5
241
242#define SNDRV_OSS_INFO_DEV_COUNT 6
243
Takashi Iwai24c1f932005-11-17 13:58:48 +0100244int snd_oss_info_register(int dev, int num, char *string);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700245#define snd_oss_info_unregister(dev, num) snd_oss_info_register(dev, num, NULL)
246
Jie Yangcd6a6502015-05-27 19:45:45 +0800247#endif /* CONFIG_SND_OSSEMUL && CONFIG_SND_PROC_FS */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700248
249#endif /* __SOUND_INFO_H */