1#ifndef __SOUND_SB16_CSP_H
2#define __SOUND_SB16_CSP_H
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27#define SNDRV_SB_CSP_MODE_NONE 0x00
28#define SNDRV_SB_CSP_MODE_DSP_READ 0x01
29#define SNDRV_SB_CSP_MODE_DSP_WRITE 0x02
30#define SNDRV_SB_CSP_MODE_QSOUND 0x04
31
32
33#define SNDRV_SB_CSP_LOAD_FROMUSER 0x01
34#define SNDRV_SB_CSP_LOAD_INITBLOCK 0x02
35
36
37#define SNDRV_SB_CSP_SAMPLE_8BIT 0x01
38#define SNDRV_SB_CSP_SAMPLE_16BIT 0x02
39
40
41#define SNDRV_SB_CSP_MONO 0x01
42#define SNDRV_SB_CSP_STEREO 0x02
43
44
45#define SNDRV_SB_CSP_RATE_8000 0x01
46#define SNDRV_SB_CSP_RATE_11025 0x02
47#define SNDRV_SB_CSP_RATE_22050 0x04
48#define SNDRV_SB_CSP_RATE_44100 0x08
49#define SNDRV_SB_CSP_RATE_ALL 0x0f
50
51
52#define SNDRV_SB_CSP_ST_IDLE 0x00
53#define SNDRV_SB_CSP_ST_LOADED 0x01
54#define SNDRV_SB_CSP_ST_RUNNING 0x02
55#define SNDRV_SB_CSP_ST_PAUSED 0x04
56#define SNDRV_SB_CSP_ST_AUTO 0x08
57#define SNDRV_SB_CSP_ST_QSOUND 0x10
58
59
60#define SNDRV_SB_CSP_QSOUND_MAX_RIGHT 0x20
61
62
63#define SNDRV_SB_CSP_MAX_MICROCODE_FILE_SIZE 0x3000
64
65
66struct snd_sb_csp_mc_header {
67 char codec_name[16];
68 unsigned short func_req;
69};
70
71
72struct snd_sb_csp_microcode {
73 struct snd_sb_csp_mc_header info;
74 unsigned char data[SNDRV_SB_CSP_MAX_MICROCODE_FILE_SIZE];
75};
76
77
78struct snd_sb_csp_start {
79 int sample_width;
80 int channels;
81};
82
83
84struct snd_sb_csp_info {
85 char codec_name[16];
86 unsigned short func_nr;
87 unsigned int acc_format;
88 unsigned short acc_channels;
89 unsigned short acc_width;
90 unsigned short acc_rates;
91 unsigned short csp_mode;
92 unsigned short run_channels;
93 unsigned short run_width;
94 unsigned short version;
95 unsigned short state;
96};
97
98
99
100#define SNDRV_SB_CSP_IOCTL_INFO _IOR('H', 0x10, struct snd_sb_csp_info)
101
102#define SNDRV_SB_CSP_IOCTL_LOAD_CODE _IOW('H', 0x11, struct snd_sb_csp_microcode)
103
104#define SNDRV_SB_CSP_IOCTL_UNLOAD_CODE _IO('H', 0x12)
105
106#define SNDRV_SB_CSP_IOCTL_START _IOW('H', 0x13, struct snd_sb_csp_start)
107
108#define SNDRV_SB_CSP_IOCTL_STOP _IO('H', 0x14)
109
110#define SNDRV_SB_CSP_IOCTL_PAUSE _IO('H', 0x15)
111
112#define SNDRV_SB_CSP_IOCTL_RESTART _IO('H', 0x16)
113
114#ifdef __KERNEL__
115#include "sb.h"
116#include "hwdep.h"
117#include <linux/firmware.h>
118
119struct snd_sb_csp;
120
121
122enum {
123 CSP_PROGRAM_MULAW,
124 CSP_PROGRAM_ALAW,
125 CSP_PROGRAM_ADPCM_INIT,
126 CSP_PROGRAM_ADPCM_PLAYBACK,
127 CSP_PROGRAM_ADPCM_CAPTURE,
128
129 CSP_PROGRAM_COUNT
130};
131
132
133
134
135struct snd_sb_csp_ops {
136 int (*csp_use) (struct snd_sb_csp * p);
137 int (*csp_unuse) (struct snd_sb_csp * p);
138 int (*csp_autoload) (struct snd_sb_csp * p, int pcm_sfmt, int play_rec_mode);
139 int (*csp_start) (struct snd_sb_csp * p, int sample_width, int channels);
140 int (*csp_stop) (struct snd_sb_csp * p);
141 int (*csp_qsound_transfer) (struct snd_sb_csp * p);
142};
143
144
145
146
147struct snd_sb_csp {
148 struct snd_sb *chip;
149 int used;
150 char codec_name[16];
151 unsigned short func_nr;
152 unsigned int acc_format;
153 int acc_channels;
154 int acc_width;
155 int acc_rates;
156 int mode;
157 int run_channels;
158 int run_width;
159 int version;
160 int running;
161
162 struct snd_sb_csp_ops ops;
163
164 spinlock_t q_lock;
165 int q_enabled;
166 int qpos_left;
167 int qpos_right;
168 int qpos_changed;
169
170 struct snd_kcontrol *qsound_switch;
171 struct snd_kcontrol *qsound_space;
172
173 struct mutex access_mutex;
174
175 const struct firmware *csp_programs[CSP_PROGRAM_COUNT];
176};
177
178int snd_sb_csp_new(struct snd_sb *chip, int device, struct snd_hwdep ** rhwdep);
179#endif
180
181#endif
182