diff options
-rw-r--r-- | include/sound/pcm_oss.h | 41 | ||||
-rw-r--r-- | sound/core/oss/copy.c | 16 | ||||
-rw-r--r-- | sound/core/oss/io.c | 28 | ||||
-rw-r--r-- | sound/core/oss/linear.c | 38 | ||||
-rw-r--r-- | sound/core/oss/mulaw.c | 54 | ||||
-rw-r--r-- | sound/core/oss/pcm_oss.c | 364 | ||||
-rw-r--r-- | sound/core/oss/pcm_plugin.c | 110 | ||||
-rw-r--r-- | sound/core/oss/pcm_plugin.h | 208 | ||||
-rw-r--r-- | sound/core/oss/rate.c | 83 | ||||
-rw-r--r-- | sound/core/oss/route.c | 134 |
10 files changed, 543 insertions, 533 deletions
diff --git a/include/sound/pcm_oss.h b/include/sound/pcm_oss.h index 0b67c9d105af..fddaddde47b4 100644 --- a/include/sound/pcm_oss.h +++ b/include/sound/pcm_oss.h | |||
@@ -22,10 +22,7 @@ | |||
22 | * | 22 | * |
23 | */ | 23 | */ |
24 | 24 | ||
25 | typedef struct _snd_pcm_plugin snd_pcm_plugin_t; | 25 | struct snd_pcm_oss_setup { |
26 | typedef struct _snd_pcm_oss_setup snd_pcm_oss_setup_t; | ||
27 | |||
28 | struct _snd_pcm_oss_setup { | ||
29 | char *task_name; | 26 | char *task_name; |
30 | unsigned int disable:1, | 27 | unsigned int disable:1, |
31 | direct:1, | 28 | direct:1, |
@@ -36,10 +33,10 @@ struct _snd_pcm_oss_setup { | |||
36 | buggyptr:1; | 33 | buggyptr:1; |
37 | unsigned int periods; | 34 | unsigned int periods; |
38 | unsigned int period_size; | 35 | unsigned int period_size; |
39 | snd_pcm_oss_setup_t *next; | 36 | struct snd_pcm_oss_setup *next; |
40 | }; | 37 | }; |
41 | 38 | ||
42 | typedef struct _snd_pcm_oss_runtime { | 39 | struct snd_pcm_oss_runtime { |
43 | unsigned params: 1, /* format/parameter change */ | 40 | unsigned params: 1, /* format/parameter change */ |
44 | prepare: 1, /* need to prepare the operation */ | 41 | prepare: 1, /* need to prepare the operation */ |
45 | trigger: 1, /* trigger flag */ | 42 | trigger: 1, /* trigger flag */ |
@@ -59,30 +56,30 @@ typedef struct _snd_pcm_oss_runtime { | |||
59 | size_t mmap_bytes; | 56 | size_t mmap_bytes; |
60 | char *buffer; /* vmallocated period */ | 57 | char *buffer; /* vmallocated period */ |
61 | size_t buffer_used; /* used length from period buffer */ | 58 | size_t buffer_used; /* used length from period buffer */ |
62 | snd_pcm_plugin_t *plugin_first; | 59 | struct snd_pcm_plugin *plugin_first; |
63 | snd_pcm_plugin_t *plugin_last; | 60 | struct snd_pcm_plugin *plugin_last; |
64 | unsigned int prev_hw_ptr_interrupt; | 61 | unsigned int prev_hw_ptr_interrupt; |
65 | } snd_pcm_oss_runtime_t; | 62 | }; |
66 | 63 | ||
67 | typedef struct _snd_pcm_oss_file { | 64 | struct snd_pcm_oss_file { |
68 | snd_pcm_substream_t *streams[2]; | 65 | struct snd_pcm_substream *streams[2]; |
69 | } snd_pcm_oss_file_t; | 66 | }; |
70 | 67 | ||
71 | typedef struct _snd_pcm_oss_substream { | 68 | struct snd_pcm_oss_substream { |
72 | unsigned oss: 1; /* oss mode */ | 69 | unsigned oss: 1; /* oss mode */ |
73 | snd_pcm_oss_setup_t *setup; /* active setup */ | 70 | struct snd_pcm_oss_setup *setup; /* active setup */ |
74 | snd_pcm_oss_file_t *file; | 71 | struct snd_pcm_oss_file *file; |
75 | } snd_pcm_oss_substream_t; | 72 | }; |
76 | 73 | ||
77 | typedef struct _snd_pcm_oss_stream { | 74 | struct snd_pcm_oss_stream { |
78 | snd_pcm_oss_setup_t *setup_list; /* setup list */ | 75 | struct snd_pcm_oss_setup *setup_list; /* setup list */ |
79 | struct semaphore setup_mutex; | 76 | struct semaphore setup_mutex; |
80 | snd_info_entry_t *proc_entry; | 77 | struct snd_info_entry *proc_entry; |
81 | } snd_pcm_oss_stream_t; | 78 | }; |
82 | 79 | ||
83 | typedef struct _snd_pcm_oss { | 80 | struct snd_pcm_oss { |
84 | int reg; | 81 | int reg; |
85 | unsigned int reg_mask; | 82 | unsigned int reg_mask; |
86 | } snd_pcm_oss_t; | 83 | }; |
87 | 84 | ||
88 | #endif /* __SOUND_PCM_OSS_H */ | 85 | #endif /* __SOUND_PCM_OSS_H */ |
diff --git a/sound/core/oss/copy.c b/sound/core/oss/copy.c index edecbe7417bd..d6a04c2d5a75 100644 --- a/sound/core/oss/copy.c +++ b/sound/core/oss/copy.c | |||
@@ -25,9 +25,9 @@ | |||
25 | #include <sound/pcm.h> | 25 | #include <sound/pcm.h> |
26 | #include "pcm_plugin.h" | 26 | #include "pcm_plugin.h" |
27 | 27 | ||
28 | static snd_pcm_sframes_t copy_transfer(snd_pcm_plugin_t *plugin, | 28 | static snd_pcm_sframes_t copy_transfer(struct snd_pcm_plugin *plugin, |
29 | const snd_pcm_plugin_channel_t *src_channels, | 29 | const struct snd_pcm_plugin_channel *src_channels, |
30 | snd_pcm_plugin_channel_t *dst_channels, | 30 | struct snd_pcm_plugin_channel *dst_channels, |
31 | snd_pcm_uframes_t frames) | 31 | snd_pcm_uframes_t frames) |
32 | { | 32 | { |
33 | unsigned int channel; | 33 | unsigned int channel; |
@@ -58,13 +58,13 @@ static snd_pcm_sframes_t copy_transfer(snd_pcm_plugin_t *plugin, | |||
58 | return frames; | 58 | return frames; |
59 | } | 59 | } |
60 | 60 | ||
61 | int snd_pcm_plugin_build_copy(snd_pcm_plug_t *plug, | 61 | int snd_pcm_plugin_build_copy(struct snd_pcm_substream *plug, |
62 | snd_pcm_plugin_format_t *src_format, | 62 | struct snd_pcm_plugin_format *src_format, |
63 | snd_pcm_plugin_format_t *dst_format, | 63 | struct snd_pcm_plugin_format *dst_format, |
64 | snd_pcm_plugin_t **r_plugin) | 64 | struct snd_pcm_plugin **r_plugin) |
65 | { | 65 | { |
66 | int err; | 66 | int err; |
67 | snd_pcm_plugin_t *plugin; | 67 | struct snd_pcm_plugin *plugin; |
68 | int width; | 68 | int width; |
69 | 69 | ||
70 | snd_assert(r_plugin != NULL, return -ENXIO); | 70 | snd_assert(r_plugin != NULL, return -ENXIO); |
diff --git a/sound/core/oss/io.c b/sound/core/oss/io.c index 63eca9aec961..322702e05f3e 100644 --- a/sound/core/oss/io.c +++ b/sound/core/oss/io.c | |||
@@ -35,9 +35,9 @@ | |||
35 | * Basic io plugin | 35 | * Basic io plugin |
36 | */ | 36 | */ |
37 | 37 | ||
38 | static snd_pcm_sframes_t io_playback_transfer(snd_pcm_plugin_t *plugin, | 38 | static snd_pcm_sframes_t io_playback_transfer(struct snd_pcm_plugin *plugin, |
39 | const snd_pcm_plugin_channel_t *src_channels, | 39 | const struct snd_pcm_plugin_channel *src_channels, |
40 | snd_pcm_plugin_channel_t *dst_channels, | 40 | struct snd_pcm_plugin_channel *dst_channels, |
41 | snd_pcm_uframes_t frames) | 41 | snd_pcm_uframes_t frames) |
42 | { | 42 | { |
43 | snd_assert(plugin != NULL, return -ENXIO); | 43 | snd_assert(plugin != NULL, return -ENXIO); |
@@ -58,9 +58,9 @@ static snd_pcm_sframes_t io_playback_transfer(snd_pcm_plugin_t *plugin, | |||
58 | } | 58 | } |
59 | } | 59 | } |
60 | 60 | ||
61 | static snd_pcm_sframes_t io_capture_transfer(snd_pcm_plugin_t *plugin, | 61 | static snd_pcm_sframes_t io_capture_transfer(struct snd_pcm_plugin *plugin, |
62 | const snd_pcm_plugin_channel_t *src_channels, | 62 | const struct snd_pcm_plugin_channel *src_channels, |
63 | snd_pcm_plugin_channel_t *dst_channels, | 63 | struct snd_pcm_plugin_channel *dst_channels, |
64 | snd_pcm_uframes_t frames) | 64 | snd_pcm_uframes_t frames) |
65 | { | 65 | { |
66 | snd_assert(plugin != NULL, return -ENXIO); | 66 | snd_assert(plugin != NULL, return -ENXIO); |
@@ -82,13 +82,13 @@ static snd_pcm_sframes_t io_capture_transfer(snd_pcm_plugin_t *plugin, | |||
82 | return 0; | 82 | return 0; |
83 | } | 83 | } |
84 | 84 | ||
85 | static snd_pcm_sframes_t io_src_channels(snd_pcm_plugin_t *plugin, | 85 | static snd_pcm_sframes_t io_src_channels(struct snd_pcm_plugin *plugin, |
86 | snd_pcm_uframes_t frames, | 86 | snd_pcm_uframes_t frames, |
87 | snd_pcm_plugin_channel_t **channels) | 87 | struct snd_pcm_plugin_channel **channels) |
88 | { | 88 | { |
89 | int err; | 89 | int err; |
90 | unsigned int channel; | 90 | unsigned int channel; |
91 | snd_pcm_plugin_channel_t *v; | 91 | struct snd_pcm_plugin_channel *v; |
92 | err = snd_pcm_plugin_client_channels(plugin, frames, &v); | 92 | err = snd_pcm_plugin_client_channels(plugin, frames, &v); |
93 | if (err < 0) | 93 | if (err < 0) |
94 | return err; | 94 | return err; |
@@ -100,13 +100,13 @@ static snd_pcm_sframes_t io_src_channels(snd_pcm_plugin_t *plugin, | |||
100 | return frames; | 100 | return frames; |
101 | } | 101 | } |
102 | 102 | ||
103 | int snd_pcm_plugin_build_io(snd_pcm_plug_t *plug, | 103 | int snd_pcm_plugin_build_io(struct snd_pcm_substream *plug, |
104 | snd_pcm_hw_params_t *params, | 104 | struct snd_pcm_hw_params *params, |
105 | snd_pcm_plugin_t **r_plugin) | 105 | struct snd_pcm_plugin **r_plugin) |
106 | { | 106 | { |
107 | int err; | 107 | int err; |
108 | snd_pcm_plugin_format_t format; | 108 | struct snd_pcm_plugin_format format; |
109 | snd_pcm_plugin_t *plugin; | 109 | struct snd_pcm_plugin *plugin; |
110 | 110 | ||
111 | snd_assert(r_plugin != NULL, return -ENXIO); | 111 | snd_assert(r_plugin != NULL, return -ENXIO); |
112 | *r_plugin = NULL; | 112 | *r_plugin = NULL; |
diff --git a/sound/core/oss/linear.c b/sound/core/oss/linear.c index 12ed27a57b27..8cbfa415ce40 100644 --- a/sound/core/oss/linear.c +++ b/sound/core/oss/linear.c | |||
@@ -30,19 +30,19 @@ | |||
30 | * Basic linear conversion plugin | 30 | * Basic linear conversion plugin |
31 | */ | 31 | */ |
32 | 32 | ||
33 | typedef struct linear_private_data { | 33 | struct linear_priv { |
34 | int conv; | 34 | int conv; |
35 | } linear_t; | 35 | }; |
36 | 36 | ||
37 | static void convert(snd_pcm_plugin_t *plugin, | 37 | static void convert(struct snd_pcm_plugin *plugin, |
38 | const snd_pcm_plugin_channel_t *src_channels, | 38 | const struct snd_pcm_plugin_channel *src_channels, |
39 | snd_pcm_plugin_channel_t *dst_channels, | 39 | struct snd_pcm_plugin_channel *dst_channels, |
40 | snd_pcm_uframes_t frames) | 40 | snd_pcm_uframes_t frames) |
41 | { | 41 | { |
42 | #define CONV_LABELS | 42 | #define CONV_LABELS |
43 | #include "plugin_ops.h" | 43 | #include "plugin_ops.h" |
44 | #undef CONV_LABELS | 44 | #undef CONV_LABELS |
45 | linear_t *data = (linear_t *)plugin->extra_data; | 45 | struct linear_priv *data = (struct linear_priv *)plugin->extra_data; |
46 | void *conv = conv_labels[data->conv]; | 46 | void *conv = conv_labels[data->conv]; |
47 | int channel; | 47 | int channel; |
48 | int nchannels = plugin->src_format.channels; | 48 | int nchannels = plugin->src_format.channels; |
@@ -75,15 +75,15 @@ static void convert(snd_pcm_plugin_t *plugin, | |||
75 | } | 75 | } |
76 | } | 76 | } |
77 | 77 | ||
78 | static snd_pcm_sframes_t linear_transfer(snd_pcm_plugin_t *plugin, | 78 | static snd_pcm_sframes_t linear_transfer(struct snd_pcm_plugin *plugin, |
79 | const snd_pcm_plugin_channel_t *src_channels, | 79 | const struct snd_pcm_plugin_channel *src_channels, |
80 | snd_pcm_plugin_channel_t *dst_channels, | 80 | struct snd_pcm_plugin_channel *dst_channels, |
81 | snd_pcm_uframes_t frames) | 81 | snd_pcm_uframes_t frames) |
82 | { | 82 | { |
83 | linear_t *data; | 83 | struct linear_priv *data; |
84 | 84 | ||
85 | snd_assert(plugin != NULL && src_channels != NULL && dst_channels != NULL, return -ENXIO); | 85 | snd_assert(plugin != NULL && src_channels != NULL && dst_channels != NULL, return -ENXIO); |
86 | data = (linear_t *)plugin->extra_data; | 86 | data = (struct linear_priv *)plugin->extra_data; |
87 | if (frames == 0) | 87 | if (frames == 0) |
88 | return 0; | 88 | return 0; |
89 | #ifdef CONFIG_SND_DEBUG | 89 | #ifdef CONFIG_SND_DEBUG |
@@ -128,14 +128,14 @@ int conv_index(int src_format, int dst_format) | |||
128 | return src_width * 32 + src_endian * 16 + sign * 8 + dst_width * 2 + dst_endian; | 128 | return src_width * 32 + src_endian * 16 + sign * 8 + dst_width * 2 + dst_endian; |
129 | } | 129 | } |
130 | 130 | ||
131 | int snd_pcm_plugin_build_linear(snd_pcm_plug_t *plug, | 131 | int snd_pcm_plugin_build_linear(struct snd_pcm_substream *plug, |
132 | snd_pcm_plugin_format_t *src_format, | 132 | struct snd_pcm_plugin_format *src_format, |
133 | snd_pcm_plugin_format_t *dst_format, | 133 | struct snd_pcm_plugin_format *dst_format, |
134 | snd_pcm_plugin_t **r_plugin) | 134 | struct snd_pcm_plugin **r_plugin) |
135 | { | 135 | { |
136 | int err; | 136 | int err; |
137 | struct linear_private_data *data; | 137 | struct linear_priv *data; |
138 | snd_pcm_plugin_t *plugin; | 138 | struct snd_pcm_plugin *plugin; |
139 | 139 | ||
140 | snd_assert(r_plugin != NULL, return -ENXIO); | 140 | snd_assert(r_plugin != NULL, return -ENXIO); |
141 | *r_plugin = NULL; | 141 | *r_plugin = NULL; |
@@ -147,10 +147,10 @@ int snd_pcm_plugin_build_linear(snd_pcm_plug_t *plug, | |||
147 | 147 | ||
148 | err = snd_pcm_plugin_build(plug, "linear format conversion", | 148 | err = snd_pcm_plugin_build(plug, "linear format conversion", |
149 | src_format, dst_format, | 149 | src_format, dst_format, |
150 | sizeof(linear_t), &plugin); | 150 | sizeof(struct linear_priv), &plugin); |
151 | if (err < 0) | 151 | if (err < 0) |
152 | return err; | 152 | return err; |
153 | data = (linear_t *)plugin->extra_data; | 153 | data = (struct linear_priv *)plugin->extra_data; |
154 | data->conv = conv_index(src_format->format, dst_format->format); | 154 | data->conv = conv_index(src_format->format, dst_format->format); |
155 | plugin->transfer = linear_transfer; | 155 | plugin->transfer = linear_transfer; |
156 | *r_plugin = plugin; | 156 | *r_plugin = plugin; |
diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c index 44ec4c66eb19..14f5578ec7a7 100644 --- a/sound/core/oss/mulaw.c +++ b/sound/core/oss/mulaw.c | |||
@@ -139,25 +139,25 @@ static int ulaw2linear(unsigned char u_val) | |||
139 | * Basic Mu-Law plugin | 139 | * Basic Mu-Law plugin |
140 | */ | 140 | */ |
141 | 141 | ||
142 | typedef void (*mulaw_f)(snd_pcm_plugin_t *plugin, | 142 | typedef void (*mulaw_f)(struct snd_pcm_plugin *plugin, |
143 | const snd_pcm_plugin_channel_t *src_channels, | 143 | const struct snd_pcm_plugin_channel *src_channels, |
144 | snd_pcm_plugin_channel_t *dst_channels, | 144 | struct snd_pcm_plugin_channel *dst_channels, |
145 | snd_pcm_uframes_t frames); | 145 | snd_pcm_uframes_t frames); |
146 | 146 | ||
147 | typedef struct mulaw_private_data { | 147 | struct mulaw_priv { |
148 | mulaw_f func; | 148 | mulaw_f func; |
149 | int conv; | 149 | int conv; |
150 | } mulaw_t; | 150 | }; |
151 | 151 | ||
152 | static void mulaw_decode(snd_pcm_plugin_t *plugin, | 152 | static void mulaw_decode(struct snd_pcm_plugin *plugin, |
153 | const snd_pcm_plugin_channel_t *src_channels, | 153 | const struct snd_pcm_plugin_channel *src_channels, |
154 | snd_pcm_plugin_channel_t *dst_channels, | 154 | struct snd_pcm_plugin_channel *dst_channels, |
155 | snd_pcm_uframes_t frames) | 155 | snd_pcm_uframes_t frames) |
156 | { | 156 | { |
157 | #define PUT_S16_LABELS | 157 | #define PUT_S16_LABELS |
158 | #include "plugin_ops.h" | 158 | #include "plugin_ops.h" |
159 | #undef PUT_S16_LABELS | 159 | #undef PUT_S16_LABELS |
160 | mulaw_t *data = (mulaw_t *)plugin->extra_data; | 160 | struct mulaw_priv *data = (struct mulaw_priv *)plugin->extra_data; |
161 | void *put = put_s16_labels[data->conv]; | 161 | void *put = put_s16_labels[data->conv]; |
162 | int channel; | 162 | int channel; |
163 | int nchannels = plugin->src_format.channels; | 163 | int nchannels = plugin->src_format.channels; |
@@ -191,15 +191,15 @@ static void mulaw_decode(snd_pcm_plugin_t *plugin, | |||
191 | } | 191 | } |
192 | } | 192 | } |
193 | 193 | ||
194 | static void mulaw_encode(snd_pcm_plugin_t *plugin, | 194 | static void mulaw_encode(struct snd_pcm_plugin *plugin, |
195 | const snd_pcm_plugin_channel_t *src_channels, | 195 | const struct snd_pcm_plugin_channel *src_channels, |
196 | snd_pcm_plugin_channel_t *dst_channels, | 196 | struct snd_pcm_plugin_channel *dst_channels, |
197 | snd_pcm_uframes_t frames) | 197 | snd_pcm_uframes_t frames) |
198 | { | 198 | { |
199 | #define GET_S16_LABELS | 199 | #define GET_S16_LABELS |
200 | #include "plugin_ops.h" | 200 | #include "plugin_ops.h" |
201 | #undef GET_S16_LABELS | 201 | #undef GET_S16_LABELS |
202 | mulaw_t *data = (mulaw_t *)plugin->extra_data; | 202 | struct mulaw_priv *data = (struct mulaw_priv *)plugin->extra_data; |
203 | void *get = get_s16_labels[data->conv]; | 203 | void *get = get_s16_labels[data->conv]; |
204 | int channel; | 204 | int channel; |
205 | int nchannels = plugin->src_format.channels; | 205 | int nchannels = plugin->src_format.channels; |
@@ -234,12 +234,12 @@ static void mulaw_encode(snd_pcm_plugin_t *plugin, | |||
234 | } | 234 | } |
235 | } | 235 | } |
236 | 236 | ||
237 | static snd_pcm_sframes_t mulaw_transfer(snd_pcm_plugin_t *plugin, | 237 | static snd_pcm_sframes_t mulaw_transfer(struct snd_pcm_plugin *plugin, |
238 | const snd_pcm_plugin_channel_t *src_channels, | 238 | const struct snd_pcm_plugin_channel *src_channels, |
239 | snd_pcm_plugin_channel_t *dst_channels, | 239 | struct snd_pcm_plugin_channel *dst_channels, |
240 | snd_pcm_uframes_t frames) | 240 | snd_pcm_uframes_t frames) |
241 | { | 241 | { |
242 | mulaw_t *data; | 242 | struct mulaw_priv *data; |
243 | 243 | ||
244 | snd_assert(plugin != NULL && src_channels != NULL && dst_channels != NULL, return -ENXIO); | 244 | snd_assert(plugin != NULL && src_channels != NULL && dst_channels != NULL, return -ENXIO); |
245 | if (frames == 0) | 245 | if (frames == 0) |
@@ -257,20 +257,20 @@ static snd_pcm_sframes_t mulaw_transfer(snd_pcm_plugin_t *plugin, | |||
257 | } | 257 | } |
258 | } | 258 | } |
259 | #endif | 259 | #endif |
260 | data = (mulaw_t *)plugin->extra_data; | 260 | data = (struct mulaw_priv *)plugin->extra_data; |
261 | data->func(plugin, src_channels, dst_channels, frames); | 261 | data->func(plugin, src_channels, dst_channels, frames); |
262 | return frames; | 262 | return frames; |
263 | } | 263 | } |
264 | 264 | ||
265 | int snd_pcm_plugin_build_mulaw(snd_pcm_plug_t *plug, | 265 | int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *plug, |
266 | snd_pcm_plugin_format_t *src_format, | 266 | struct snd_pcm_plugin_format *src_format, |
267 | snd_pcm_plugin_format_t *dst_format, | 267 | struct snd_pcm_plugin_format *dst_format, |
268 | snd_pcm_plugin_t **r_plugin) | 268 | struct snd_pcm_plugin **r_plugin) |
269 | { | 269 | { |
270 | int err; | 270 | int err; |
271 | mulaw_t *data; | 271 | struct mulaw_priv *data; |
272 | snd_pcm_plugin_t *plugin; | 272 | struct snd_pcm_plugin *plugin; |
273 | snd_pcm_plugin_format_t *format; | 273 | struct snd_pcm_plugin_format *format; |
274 | mulaw_f func; | 274 | mulaw_f func; |
275 | 275 | ||
276 | snd_assert(r_plugin != NULL, return -ENXIO); | 276 | snd_assert(r_plugin != NULL, return -ENXIO); |
@@ -295,10 +295,10 @@ int snd_pcm_plugin_build_mulaw(snd_pcm_plug_t *plug, | |||
295 | 295 | ||
296 | err = snd_pcm_plugin_build(plug, "Mu-Law<->linear conversion", | 296 | err = snd_pcm_plugin_build(plug, "Mu-Law<->linear conversion", |
297 | src_format, dst_format, | 297 | src_format, dst_format, |
298 | sizeof(mulaw_t), &plugin); | 298 | sizeof(struct mulaw_priv), &plugin); |
299 | if (err < 0) | 299 | if (err < 0) |
300 | return err; | 300 | return err; |
301 | data = (mulaw_t*)plugin->extra_data; | 301 | data = (struct mulaw_priv *)plugin->extra_data; |
302 | data->func = func; | 302 | data->func = func; |
303 | data->conv = getput_index(format->format); | 303 | data->conv = getput_index(format->format); |
304 | snd_assert(data->conv >= 0 && data->conv < 4*2*2, return -EINVAL); | 304 | snd_assert(data->conv >= 0 && data->conv < 4*2*2, return -EINVAL); |
diff --git a/sound/core/oss/pcm_oss.c b/sound/core/oss/pcm_oss.c index bcc970759134..ffc13b9194b7 100644 --- a/sound/core/oss/pcm_oss.c +++ b/sound/core/oss/pcm_oss.c | |||
@@ -61,10 +61,10 @@ MODULE_PARM_DESC(nonblock_open, "Don't block opening busy PCM devices."); | |||
61 | MODULE_ALIAS_SNDRV_MINOR(SNDRV_MINOR_OSS_PCM); | 61 | MODULE_ALIAS_SNDRV_MINOR(SNDRV_MINOR_OSS_PCM); |
62 | MODULE_ALIAS_SNDRV_MINOR(SNDRV_MINOR_OSS_PCM1); | 62 | MODULE_ALIAS_SNDRV_MINOR(SNDRV_MINOR_OSS_PCM1); |
63 | 63 | ||
64 | extern int snd_mixer_oss_ioctl_card(snd_card_t *card, unsigned int cmd, unsigned long arg); | 64 | extern int snd_mixer_oss_ioctl_card(struct snd_card *card, unsigned int cmd, unsigned long arg); |
65 | static int snd_pcm_oss_get_rate(snd_pcm_oss_file_t *pcm_oss_file); | 65 | static int snd_pcm_oss_get_rate(struct snd_pcm_oss_file *pcm_oss_file); |
66 | static int snd_pcm_oss_get_channels(snd_pcm_oss_file_t *pcm_oss_file); | 66 | static int snd_pcm_oss_get_channels(struct snd_pcm_oss_file *pcm_oss_file); |
67 | static int snd_pcm_oss_get_format(snd_pcm_oss_file_t *pcm_oss_file); | 67 | static int snd_pcm_oss_get_format(struct snd_pcm_oss_file *pcm_oss_file); |
68 | 68 | ||
69 | static inline mm_segment_t snd_enter_user(void) | 69 | static inline mm_segment_t snd_enter_user(void) |
70 | { | 70 | { |
@@ -78,10 +78,10 @@ static inline void snd_leave_user(mm_segment_t fs) | |||
78 | set_fs(fs); | 78 | set_fs(fs); |
79 | } | 79 | } |
80 | 80 | ||
81 | static int snd_pcm_oss_plugin_clear(snd_pcm_substream_t *substream) | 81 | static int snd_pcm_oss_plugin_clear(struct snd_pcm_substream *substream) |
82 | { | 82 | { |
83 | snd_pcm_runtime_t *runtime = substream->runtime; | 83 | struct snd_pcm_runtime *runtime = substream->runtime; |
84 | snd_pcm_plugin_t *plugin, *next; | 84 | struct snd_pcm_plugin *plugin, *next; |
85 | 85 | ||
86 | plugin = runtime->oss.plugin_first; | 86 | plugin = runtime->oss.plugin_first; |
87 | while (plugin) { | 87 | while (plugin) { |
@@ -93,9 +93,9 @@ static int snd_pcm_oss_plugin_clear(snd_pcm_substream_t *substream) | |||
93 | return 0; | 93 | return 0; |
94 | } | 94 | } |
95 | 95 | ||
96 | static int snd_pcm_plugin_insert(snd_pcm_plugin_t *plugin) | 96 | static int snd_pcm_plugin_insert(struct snd_pcm_plugin *plugin) |
97 | { | 97 | { |
98 | snd_pcm_runtime_t *runtime = plugin->plug->runtime; | 98 | struct snd_pcm_runtime *runtime = plugin->plug->runtime; |
99 | plugin->next = runtime->oss.plugin_first; | 99 | plugin->next = runtime->oss.plugin_first; |
100 | plugin->prev = NULL; | 100 | plugin->prev = NULL; |
101 | if (runtime->oss.plugin_first) { | 101 | if (runtime->oss.plugin_first) { |
@@ -108,9 +108,9 @@ static int snd_pcm_plugin_insert(snd_pcm_plugin_t *plugin) | |||
108 | return 0; | 108 | return 0; |
109 | } | 109 | } |
110 | 110 | ||
111 | int snd_pcm_plugin_append(snd_pcm_plugin_t *plugin) | 111 | int snd_pcm_plugin_append(struct snd_pcm_plugin *plugin) |
112 | { | 112 | { |
113 | snd_pcm_runtime_t *runtime = plugin->plug->runtime; | 113 | struct snd_pcm_runtime *runtime = plugin->plug->runtime; |
114 | plugin->next = NULL; | 114 | plugin->next = NULL; |
115 | plugin->prev = runtime->oss.plugin_last; | 115 | plugin->prev = runtime->oss.plugin_last; |
116 | if (runtime->oss.plugin_last) { | 116 | if (runtime->oss.plugin_last) { |
@@ -123,9 +123,9 @@ int snd_pcm_plugin_append(snd_pcm_plugin_t *plugin) | |||
123 | return 0; | 123 | return 0; |
124 | } | 124 | } |
125 | 125 | ||
126 | static long snd_pcm_oss_bytes(snd_pcm_substream_t *substream, long frames) | 126 | static long snd_pcm_oss_bytes(struct snd_pcm_substream *substream, long frames) |
127 | { | 127 | { |
128 | snd_pcm_runtime_t *runtime = substream->runtime; | 128 | struct snd_pcm_runtime *runtime = substream->runtime; |
129 | long buffer_size = snd_pcm_lib_buffer_bytes(substream); | 129 | long buffer_size = snd_pcm_lib_buffer_bytes(substream); |
130 | long bytes = frames_to_bytes(runtime, frames); | 130 | long bytes = frames_to_bytes(runtime, frames); |
131 | if (buffer_size == runtime->oss.buffer_bytes) | 131 | if (buffer_size == runtime->oss.buffer_bytes) |
@@ -142,9 +142,9 @@ static long snd_pcm_oss_bytes(snd_pcm_substream_t *substream, long frames) | |||
142 | #endif | 142 | #endif |
143 | } | 143 | } |
144 | 144 | ||
145 | static long snd_pcm_alsa_frames(snd_pcm_substream_t *substream, long bytes) | 145 | static long snd_pcm_alsa_frames(struct snd_pcm_substream *substream, long bytes) |
146 | { | 146 | { |
147 | snd_pcm_runtime_t *runtime = substream->runtime; | 147 | struct snd_pcm_runtime *runtime = substream->runtime; |
148 | long buffer_size = snd_pcm_lib_buffer_bytes(substream); | 148 | long buffer_size = snd_pcm_lib_buffer_bytes(substream); |
149 | if (buffer_size == runtime->oss.buffer_bytes) | 149 | if (buffer_size == runtime->oss.buffer_bytes) |
150 | return bytes_to_frames(runtime, bytes); | 150 | return bytes_to_frames(runtime, bytes); |
@@ -185,14 +185,14 @@ static int snd_pcm_oss_format_to(int format) | |||
185 | } | 185 | } |
186 | } | 186 | } |
187 | 187 | ||
188 | static int snd_pcm_oss_period_size(snd_pcm_substream_t *substream, | 188 | static int snd_pcm_oss_period_size(struct snd_pcm_substream *substream, |
189 | snd_pcm_hw_params_t *oss_params, | 189 | struct snd_pcm_hw_params *oss_params, |
190 | snd_pcm_hw_params_t *slave_params) | 190 | struct snd_pcm_hw_params *slave_params) |
191 | { | 191 | { |
192 | size_t s; | 192 | size_t s; |
193 | size_t oss_buffer_size, oss_period_size, oss_periods; | 193 | size_t oss_buffer_size, oss_period_size, oss_periods; |
194 | size_t min_period_size, max_period_size; | 194 | size_t min_period_size, max_period_size; |
195 | snd_pcm_runtime_t *runtime = substream->runtime; | 195 | struct snd_pcm_runtime *runtime = substream->runtime; |
196 | size_t oss_frame_size; | 196 | size_t oss_frame_size; |
197 | 197 | ||
198 | oss_frame_size = snd_pcm_format_physical_width(params_format(oss_params)) * | 198 | oss_frame_size = snd_pcm_format_physical_width(params_format(oss_params)) * |
@@ -277,11 +277,11 @@ static int snd_pcm_oss_period_size(snd_pcm_substream_t *substream, | |||
277 | return 0; | 277 | return 0; |
278 | } | 278 | } |
279 | 279 | ||
280 | static int choose_rate(snd_pcm_substream_t *substream, | 280 | static int choose_rate(struct snd_pcm_substream *substream, |
281 | snd_pcm_hw_params_t *params, unsigned int best_rate) | 281 | struct snd_pcm_hw_params *params, unsigned int best_rate) |
282 | { | 282 | { |
283 | snd_interval_t *it; | 283 | struct snd_interval *it; |
284 | snd_pcm_hw_params_t *save; | 284 | struct snd_pcm_hw_params *save; |
285 | unsigned int rate, prev; | 285 | unsigned int rate, prev; |
286 | 286 | ||
287 | save = kmalloc(sizeof(*save), GFP_KERNEL); | 287 | save = kmalloc(sizeof(*save), GFP_KERNEL); |
@@ -317,18 +317,18 @@ static int choose_rate(snd_pcm_substream_t *substream, | |||
317 | return snd_pcm_hw_param_near(substream, params, SNDRV_PCM_HW_PARAM_RATE, best_rate, NULL); | 317 | return snd_pcm_hw_param_near(substream, params, SNDRV_PCM_HW_PARAM_RATE, best_rate, NULL); |
318 | } | 318 | } |
319 | 319 | ||
320 | static int snd_pcm_oss_change_params(snd_pcm_substream_t *substream) | 320 | static int snd_pcm_oss_change_params(struct snd_pcm_substream *substream) |
321 | { | 321 | { |
322 | snd_pcm_runtime_t *runtime = substream->runtime; | 322 | struct snd_pcm_runtime *runtime = substream->runtime; |
323 | snd_pcm_hw_params_t *params, *sparams; | 323 | struct snd_pcm_hw_params *params, *sparams; |
324 | snd_pcm_sw_params_t *sw_params; | 324 | struct snd_pcm_sw_params *sw_params; |
325 | ssize_t oss_buffer_size, oss_period_size; | 325 | ssize_t oss_buffer_size, oss_period_size; |
326 | size_t oss_frame_size; | 326 | size_t oss_frame_size; |
327 | int err; | 327 | int err; |
328 | int direct; | 328 | int direct; |
329 | int format, sformat, n; | 329 | int format, sformat, n; |
330 | snd_mask_t sformat_mask; | 330 | struct snd_mask sformat_mask; |
331 | snd_mask_t mask; | 331 | struct snd_mask mask; |
332 | 332 | ||
333 | sw_params = kmalloc(sizeof(*sw_params), GFP_KERNEL); | 333 | sw_params = kmalloc(sizeof(*sw_params), GFP_KERNEL); |
334 | params = kmalloc(sizeof(*params), GFP_KERNEL); | 334 | params = kmalloc(sizeof(*params), GFP_KERNEL); |
@@ -342,7 +342,7 @@ static int snd_pcm_oss_change_params(snd_pcm_substream_t *substream) | |||
342 | if (atomic_read(&runtime->mmap_count)) { | 342 | if (atomic_read(&runtime->mmap_count)) { |
343 | direct = 1; | 343 | direct = 1; |
344 | } else { | 344 | } else { |
345 | snd_pcm_oss_setup_t *setup = substream->oss.setup; | 345 | struct snd_pcm_oss_setup *setup = substream->oss.setup; |
346 | direct = (setup != NULL && setup->direct); | 346 | direct = (setup != NULL && setup->direct); |
347 | } | 347 | } |
348 | 348 | ||
@@ -424,7 +424,7 @@ static int snd_pcm_oss_change_params(snd_pcm_substream_t *substream) | |||
424 | goto failure; | 424 | goto failure; |
425 | } | 425 | } |
426 | if (runtime->oss.plugin_first) { | 426 | if (runtime->oss.plugin_first) { |
427 | snd_pcm_plugin_t *plugin; | 427 | struct snd_pcm_plugin *plugin; |
428 | if ((err = snd_pcm_plugin_build_io(substream, sparams, &plugin)) < 0) { | 428 | if ((err = snd_pcm_plugin_build_io(substream, sparams, &plugin)) < 0) { |
429 | snd_printd("snd_pcm_plugin_build_io failed: %i\n", err); | 429 | snd_printd("snd_pcm_plugin_build_io failed: %i\n", err); |
430 | snd_pcm_oss_plugin_clear(substream); | 430 | snd_pcm_oss_plugin_clear(substream); |
@@ -540,10 +540,10 @@ failure: | |||
540 | return err; | 540 | return err; |
541 | } | 541 | } |
542 | 542 | ||
543 | static int snd_pcm_oss_get_active_substream(snd_pcm_oss_file_t *pcm_oss_file, snd_pcm_substream_t **r_substream) | 543 | static int snd_pcm_oss_get_active_substream(struct snd_pcm_oss_file *pcm_oss_file, struct snd_pcm_substream **r_substream) |
544 | { | 544 | { |
545 | int idx, err; | 545 | int idx, err; |
546 | snd_pcm_substream_t *asubstream = NULL, *substream; | 546 | struct snd_pcm_substream *asubstream = NULL, *substream; |
547 | 547 | ||
548 | for (idx = 0; idx < 2; idx++) { | 548 | for (idx = 0; idx < 2; idx++) { |
549 | substream = pcm_oss_file->streams[idx]; | 549 | substream = pcm_oss_file->streams[idx]; |
@@ -563,10 +563,10 @@ static int snd_pcm_oss_get_active_substream(snd_pcm_oss_file_t *pcm_oss_file, sn | |||
563 | return 0; | 563 | return 0; |
564 | } | 564 | } |
565 | 565 | ||
566 | static int snd_pcm_oss_prepare(snd_pcm_substream_t *substream) | 566 | static int snd_pcm_oss_prepare(struct snd_pcm_substream *substream) |
567 | { | 567 | { |
568 | int err; | 568 | int err; |
569 | snd_pcm_runtime_t *runtime = substream->runtime; | 569 | struct snd_pcm_runtime *runtime = substream->runtime; |
570 | 570 | ||
571 | err = snd_pcm_kernel_ioctl(substream, SNDRV_PCM_IOCTL_PREPARE, NULL); | 571 | err = snd_pcm_kernel_ioctl(substream, SNDRV_PCM_IOCTL_PREPARE, NULL); |
572 | if (err < 0) { | 572 | if (err < 0) { |
@@ -581,9 +581,9 @@ static int snd_pcm_oss_prepare(snd_pcm_substream_t *substream) | |||
581 | return 0; | 581 | return 0; |
582 | } | 582 | } |
583 | 583 | ||
584 | static int snd_pcm_oss_make_ready(snd_pcm_substream_t *substream) | 584 | static int snd_pcm_oss_make_ready(struct snd_pcm_substream *substream) |
585 | { | 585 | { |
586 | snd_pcm_runtime_t *runtime; | 586 | struct snd_pcm_runtime *runtime; |
587 | int err; | 587 | int err; |
588 | 588 | ||
589 | if (substream == NULL) | 589 | if (substream == NULL) |
@@ -602,9 +602,9 @@ static int snd_pcm_oss_make_ready(snd_pcm_substream_t *substream) | |||
602 | return 0; | 602 | return 0; |
603 | } | 603 | } |
604 | 604 | ||
605 | static int snd_pcm_oss_capture_position_fixup(snd_pcm_substream_t *substream, snd_pcm_sframes_t *delay) | 605 | static int snd_pcm_oss_capture_position_fixup(struct snd_pcm_substream *substream, snd_pcm_sframes_t *delay) |
606 | { | 606 | { |
607 | snd_pcm_runtime_t *runtime; | 607 | struct snd_pcm_runtime *runtime; |
608 | snd_pcm_uframes_t frames; | 608 | snd_pcm_uframes_t frames; |
609 | int err = 0; | 609 | int err = 0; |
610 | 610 | ||
@@ -627,9 +627,9 @@ static int snd_pcm_oss_capture_position_fixup(snd_pcm_substream_t *substream, sn | |||
627 | return err; | 627 | return err; |
628 | } | 628 | } |
629 | 629 | ||
630 | snd_pcm_sframes_t snd_pcm_oss_write3(snd_pcm_substream_t *substream, const char *ptr, snd_pcm_uframes_t frames, int in_kernel) | 630 | snd_pcm_sframes_t snd_pcm_oss_write3(struct snd_pcm_substream *substream, const char *ptr, snd_pcm_uframes_t frames, int in_kernel) |
631 | { | 631 | { |
632 | snd_pcm_runtime_t *runtime = substream->runtime; | 632 | struct snd_pcm_runtime *runtime = substream->runtime; |
633 | int ret; | 633 | int ret; |
634 | while (1) { | 634 | while (1) { |
635 | if (runtime->status->state == SNDRV_PCM_STATE_XRUN || | 635 | if (runtime->status->state == SNDRV_PCM_STATE_XRUN || |
@@ -662,9 +662,9 @@ snd_pcm_sframes_t snd_pcm_oss_write3(snd_pcm_substream_t *substream, const char | |||
662 | return ret; | 662 | return ret; |
663 | } | 663 | } |
664 | 664 | ||
665 | snd_pcm_sframes_t snd_pcm_oss_read3(snd_pcm_substream_t *substream, char *ptr, snd_pcm_uframes_t frames, int in_kernel) | 665 | snd_pcm_sframes_t snd_pcm_oss_read3(struct snd_pcm_substream *substream, char *ptr, snd_pcm_uframes_t frames, int in_kernel) |
666 | { | 666 | { |
667 | snd_pcm_runtime_t *runtime = substream->runtime; | 667 | struct snd_pcm_runtime *runtime = substream->runtime; |
668 | snd_pcm_sframes_t delay; | 668 | snd_pcm_sframes_t delay; |
669 | int ret; | 669 | int ret; |
670 | while (1) { | 670 | while (1) { |
@@ -709,9 +709,9 @@ snd_pcm_sframes_t snd_pcm_oss_read3(snd_pcm_substream_t *substream, char *ptr, s | |||
709 | return ret; | 709 | return ret; |
710 | } | 710 | } |
711 | 711 | ||
712 | snd_pcm_sframes_t snd_pcm_oss_writev3(snd_pcm_substream_t *substream, void **bufs, snd_pcm_uframes_t frames, int in_kernel) | 712 | snd_pcm_sframes_t snd_pcm_oss_writev3(struct snd_pcm_substream *substream, void **bufs, snd_pcm_uframes_t frames, int in_kernel) |
713 | { | 713 | { |
714 | snd_pcm_runtime_t *runtime = substream->runtime; | 714 | struct snd_pcm_runtime *runtime = substream->runtime; |
715 | int ret; | 715 | int ret; |
716 | while (1) { | 716 | while (1) { |
717 | if (runtime->status->state == SNDRV_PCM_STATE_XRUN || | 717 | if (runtime->status->state == SNDRV_PCM_STATE_XRUN || |
@@ -745,9 +745,9 @@ snd_pcm_sframes_t snd_pcm_oss_writev3(snd_pcm_substream_t *substream, void **buf | |||
745 | return ret; | 745 | return ret; |
746 | } | 746 | } |
747 | 747 | ||
748 | snd_pcm_sframes_t snd_pcm_oss_readv3(snd_pcm_substream_t *substream, void **bufs, snd_pcm_uframes_t frames, int in_kernel) | 748 | snd_pcm_sframes_t snd_pcm_oss_readv3(struct snd_pcm_substream *substream, void **bufs, snd_pcm_uframes_t frames, int in_kernel) |
749 | { | 749 | { |
750 | snd_pcm_runtime_t *runtime = substream->runtime; | 750 | struct snd_pcm_runtime *runtime = substream->runtime; |
751 | int ret; | 751 | int ret; |
752 | while (1) { | 752 | while (1) { |
753 | if (runtime->status->state == SNDRV_PCM_STATE_XRUN || | 753 | if (runtime->status->state == SNDRV_PCM_STATE_XRUN || |
@@ -780,12 +780,12 @@ snd_pcm_sframes_t snd_pcm_oss_readv3(snd_pcm_substream_t *substream, void **bufs | |||
780 | return ret; | 780 | return ret; |
781 | } | 781 | } |
782 | 782 | ||
783 | static ssize_t snd_pcm_oss_write2(snd_pcm_substream_t *substream, const char *buf, size_t bytes, int in_kernel) | 783 | static ssize_t snd_pcm_oss_write2(struct snd_pcm_substream *substream, const char *buf, size_t bytes, int in_kernel) |
784 | { | 784 | { |
785 | snd_pcm_runtime_t *runtime = substream->runtime; | 785 | struct snd_pcm_runtime *runtime = substream->runtime; |
786 | snd_pcm_sframes_t frames, frames1; | 786 | snd_pcm_sframes_t frames, frames1; |
787 | if (runtime->oss.plugin_first) { | 787 | if (runtime->oss.plugin_first) { |
788 | snd_pcm_plugin_channel_t *channels; | 788 | struct snd_pcm_plugin_channel *channels; |
789 | size_t oss_frame_bytes = (runtime->oss.plugin_first->src_width * runtime->oss.plugin_first->src_format.channels) / 8; | 789 | size_t oss_frame_bytes = (runtime->oss.plugin_first->src_width * runtime->oss.plugin_first->src_format.channels) / 8; |
790 | if (!in_kernel) { | 790 | if (!in_kernel) { |
791 | if (copy_from_user(runtime->oss.buffer, (const char __user *)buf, bytes)) | 791 | if (copy_from_user(runtime->oss.buffer, (const char __user *)buf, bytes)) |
@@ -810,11 +810,11 @@ static ssize_t snd_pcm_oss_write2(snd_pcm_substream_t *substream, const char *bu | |||
810 | return bytes; | 810 | return bytes; |
811 | } | 811 | } |
812 | 812 | ||
813 | static ssize_t snd_pcm_oss_write1(snd_pcm_substream_t *substream, const char __user *buf, size_t bytes) | 813 | static ssize_t snd_pcm_oss_write1(struct snd_pcm_substream *substream, const char __user *buf, size_t bytes) |
814 | { | 814 | { |
815 | size_t xfer = 0; | 815 | size_t xfer = 0; |
816 | ssize_t tmp; | 816 | ssize_t tmp; |
817 | snd_pcm_runtime_t *runtime = substream->runtime; | 817 | struct snd_pcm_runtime *runtime = substream->runtime; |
818 | 818 | ||
819 | if (atomic_read(&runtime->mmap_count)) | 819 | if (atomic_read(&runtime->mmap_count)) |
820 | return -ENXIO; | 820 | return -ENXIO; |
@@ -867,13 +867,13 @@ static ssize_t snd_pcm_oss_write1(snd_pcm_substream_t *substream, const char __u | |||
867 | return xfer; | 867 | return xfer; |
868 | } | 868 | } |
869 | 869 | ||
870 | static ssize_t snd_pcm_oss_read2(snd_pcm_substream_t *substream, char *buf, size_t bytes, int in_kernel) | 870 | static ssize_t snd_pcm_oss_read2(struct snd_pcm_substream *substream, char *buf, size_t bytes, int in_kernel) |
871 | { | 871 | { |
872 | snd_pcm_runtime_t *runtime = substream->runtime; | 872 | struct snd_pcm_runtime *runtime = substream->runtime; |
873 | snd_pcm_sframes_t frames, frames1; | 873 | snd_pcm_sframes_t frames, frames1; |
874 | char __user *final_dst = (char __user *)buf; | 874 | char __user *final_dst = (char __user *)buf; |
875 | if (runtime->oss.plugin_first) { | 875 | if (runtime->oss.plugin_first) { |
876 | snd_pcm_plugin_channel_t *channels; | 876 | struct snd_pcm_plugin_channel *channels; |
877 | size_t oss_frame_bytes = (runtime->oss.plugin_last->dst_width * runtime->oss.plugin_last->dst_format.channels) / 8; | 877 | size_t oss_frame_bytes = (runtime->oss.plugin_last->dst_width * runtime->oss.plugin_last->dst_format.channels) / 8; |
878 | if (!in_kernel) | 878 | if (!in_kernel) |
879 | buf = runtime->oss.buffer; | 879 | buf = runtime->oss.buffer; |
@@ -897,11 +897,11 @@ static ssize_t snd_pcm_oss_read2(snd_pcm_substream_t *substream, char *buf, size | |||
897 | return bytes; | 897 | return bytes; |
898 | } | 898 | } |
899 | 899 | ||
900 | static ssize_t snd_pcm_oss_read1(snd_pcm_substream_t *substream, char __user *buf, size_t bytes) | 900 | static ssize_t snd_pcm_oss_read1(struct snd_pcm_substream *substream, char __user *buf, size_t bytes) |
901 | { | 901 | { |
902 | size_t xfer = 0; | 902 | size_t xfer = 0; |
903 | ssize_t tmp; | 903 | ssize_t tmp; |
904 | snd_pcm_runtime_t *runtime = substream->runtime; | 904 | struct snd_pcm_runtime *runtime = substream->runtime; |
905 | 905 | ||
906 | if (atomic_read(&runtime->mmap_count)) | 906 | if (atomic_read(&runtime->mmap_count)) |
907 | return -ENXIO; | 907 | return -ENXIO; |
@@ -941,9 +941,9 @@ static ssize_t snd_pcm_oss_read1(snd_pcm_substream_t *substream, char __user *bu | |||
941 | return xfer; | 941 | return xfer; |
942 | } | 942 | } |
943 | 943 | ||
944 | static int snd_pcm_oss_reset(snd_pcm_oss_file_t *pcm_oss_file) | 944 | static int snd_pcm_oss_reset(struct snd_pcm_oss_file *pcm_oss_file) |
945 | { | 945 | { |
946 | snd_pcm_substream_t *substream; | 946 | struct snd_pcm_substream *substream; |
947 | 947 | ||
948 | substream = pcm_oss_file->streams[SNDRV_PCM_STREAM_PLAYBACK]; | 948 | substream = pcm_oss_file->streams[SNDRV_PCM_STREAM_PLAYBACK]; |
949 | if (substream != NULL) { | 949 | if (substream != NULL) { |
@@ -958,9 +958,9 @@ static int snd_pcm_oss_reset(snd_pcm_oss_file_t *pcm_oss_file) | |||
958 | return 0; | 958 | return 0; |
959 | } | 959 | } |
960 | 960 | ||
961 | static int snd_pcm_oss_post(snd_pcm_oss_file_t *pcm_oss_file) | 961 | static int snd_pcm_oss_post(struct snd_pcm_oss_file *pcm_oss_file) |
962 | { | 962 | { |
963 | snd_pcm_substream_t *substream; | 963 | struct snd_pcm_substream *substream; |
964 | int err; | 964 | int err; |
965 | 965 | ||
966 | substream = pcm_oss_file->streams[SNDRV_PCM_STREAM_PLAYBACK]; | 966 | substream = pcm_oss_file->streams[SNDRV_PCM_STREAM_PLAYBACK]; |
@@ -974,9 +974,9 @@ static int snd_pcm_oss_post(snd_pcm_oss_file_t *pcm_oss_file) | |||
974 | return 0; | 974 | return 0; |
975 | } | 975 | } |
976 | 976 | ||
977 | static int snd_pcm_oss_sync1(snd_pcm_substream_t *substream, size_t size) | 977 | static int snd_pcm_oss_sync1(struct snd_pcm_substream *substream, size_t size) |
978 | { | 978 | { |
979 | snd_pcm_runtime_t *runtime; | 979 | struct snd_pcm_runtime *runtime; |
980 | ssize_t result = 0; | 980 | ssize_t result = 0; |
981 | long res; | 981 | long res; |
982 | wait_queue_t wait; | 982 | wait_queue_t wait; |
@@ -1020,12 +1020,12 @@ static int snd_pcm_oss_sync1(snd_pcm_substream_t *substream, size_t size) | |||
1020 | return result; | 1020 | return result; |
1021 | } | 1021 | } |
1022 | 1022 | ||
1023 | static int snd_pcm_oss_sync(snd_pcm_oss_file_t *pcm_oss_file) | 1023 | static int snd_pcm_oss_sync(struct snd_pcm_oss_file *pcm_oss_file) |
1024 | { | 1024 | { |
1025 | int err = 0; | 1025 | int err = 0; |
1026 | unsigned int saved_f_flags; | 1026 | unsigned int saved_f_flags; |
1027 | snd_pcm_substream_t *substream; | 1027 | struct snd_pcm_substream *substream; |
1028 | snd_pcm_runtime_t *runtime; | 1028 | struct snd_pcm_runtime *runtime; |
1029 | snd_pcm_format_t format; | 1029 | snd_pcm_format_t format; |
1030 | unsigned long width; | 1030 | unsigned long width; |
1031 | size_t size; | 1031 | size_t size; |
@@ -1117,13 +1117,13 @@ static int snd_pcm_oss_sync(snd_pcm_oss_file_t *pcm_oss_file) | |||
1117 | return 0; | 1117 | return 0; |
1118 | } | 1118 | } |
1119 | 1119 | ||
1120 | static int snd_pcm_oss_set_rate(snd_pcm_oss_file_t *pcm_oss_file, int rate) | 1120 | static int snd_pcm_oss_set_rate(struct snd_pcm_oss_file *pcm_oss_file, int rate) |
1121 | { | 1121 | { |
1122 | int idx; | 1122 | int idx; |
1123 | 1123 | ||
1124 | for (idx = 1; idx >= 0; --idx) { | 1124 | for (idx = 1; idx >= 0; --idx) { |
1125 | snd_pcm_substream_t *substream = pcm_oss_file->streams[idx]; | 1125 | struct snd_pcm_substream *substream = pcm_oss_file->streams[idx]; |
1126 | snd_pcm_runtime_t *runtime; | 1126 | struct snd_pcm_runtime *runtime; |
1127 | if (substream == NULL) | 1127 | if (substream == NULL) |
1128 | continue; | 1128 | continue; |
1129 | runtime = substream->runtime; | 1129 | runtime = substream->runtime; |
@@ -1139,9 +1139,9 @@ static int snd_pcm_oss_set_rate(snd_pcm_oss_file_t *pcm_oss_file, int rate) | |||
1139 | return snd_pcm_oss_get_rate(pcm_oss_file); | 1139 | return snd_pcm_oss_get_rate(pcm_oss_file); |
1140 | } | 1140 | } |
1141 | 1141 | ||
1142 | static int snd_pcm_oss_get_rate(snd_pcm_oss_file_t *pcm_oss_file) | 1142 | static int snd_pcm_oss_get_rate(struct snd_pcm_oss_file *pcm_oss_file) |
1143 | { | 1143 | { |
1144 | snd_pcm_substream_t *substream; | 1144 | struct snd_pcm_substream *substream; |
1145 | int err; | 1145 | int err; |
1146 | 1146 | ||
1147 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) | 1147 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) |
@@ -1149,7 +1149,7 @@ static int snd_pcm_oss_get_rate(snd_pcm_oss_file_t *pcm_oss_file) | |||
1149 | return substream->runtime->oss.rate; | 1149 | return substream->runtime->oss.rate; |
1150 | } | 1150 | } |
1151 | 1151 | ||
1152 | static int snd_pcm_oss_set_channels(snd_pcm_oss_file_t *pcm_oss_file, unsigned int channels) | 1152 | static int snd_pcm_oss_set_channels(struct snd_pcm_oss_file *pcm_oss_file, unsigned int channels) |
1153 | { | 1153 | { |
1154 | int idx; | 1154 | int idx; |
1155 | if (channels < 1) | 1155 | if (channels < 1) |
@@ -1157,8 +1157,8 @@ static int snd_pcm_oss_set_channels(snd_pcm_oss_file_t *pcm_oss_file, unsigned i | |||
1157 | if (channels > 128) | 1157 | if (channels > 128) |
1158 | return -EINVAL; | 1158 | return -EINVAL; |
1159 | for (idx = 1; idx >= 0; --idx) { | 1159 | for (idx = 1; idx >= 0; --idx) { |
1160 | snd_pcm_substream_t *substream = pcm_oss_file->streams[idx]; | 1160 | struct snd_pcm_substream *substream = pcm_oss_file->streams[idx]; |
1161 | snd_pcm_runtime_t *runtime; | 1161 | struct snd_pcm_runtime *runtime; |
1162 | if (substream == NULL) | 1162 | if (substream == NULL) |
1163 | continue; | 1163 | continue; |
1164 | runtime = substream->runtime; | 1164 | runtime = substream->runtime; |
@@ -1170,9 +1170,9 @@ static int snd_pcm_oss_set_channels(snd_pcm_oss_file_t *pcm_oss_file, unsigned i | |||
1170 | return snd_pcm_oss_get_channels(pcm_oss_file); | 1170 | return snd_pcm_oss_get_channels(pcm_oss_file); |
1171 | } | 1171 | } |
1172 | 1172 | ||
1173 | static int snd_pcm_oss_get_channels(snd_pcm_oss_file_t *pcm_oss_file) | 1173 | static int snd_pcm_oss_get_channels(struct snd_pcm_oss_file *pcm_oss_file) |
1174 | { | 1174 | { |
1175 | snd_pcm_substream_t *substream; | 1175 | struct snd_pcm_substream *substream; |
1176 | int err; | 1176 | int err; |
1177 | 1177 | ||
1178 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) | 1178 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) |
@@ -1180,9 +1180,9 @@ static int snd_pcm_oss_get_channels(snd_pcm_oss_file_t *pcm_oss_file) | |||
1180 | return substream->runtime->oss.channels; | 1180 | return substream->runtime->oss.channels; |
1181 | } | 1181 | } |
1182 | 1182 | ||
1183 | static int snd_pcm_oss_get_block_size(snd_pcm_oss_file_t *pcm_oss_file) | 1183 | static int snd_pcm_oss_get_block_size(struct snd_pcm_oss_file *pcm_oss_file) |
1184 | { | 1184 | { |
1185 | snd_pcm_substream_t *substream; | 1185 | struct snd_pcm_substream *substream; |
1186 | int err; | 1186 | int err; |
1187 | 1187 | ||
1188 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) | 1188 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) |
@@ -1190,14 +1190,14 @@ static int snd_pcm_oss_get_block_size(snd_pcm_oss_file_t *pcm_oss_file) | |||
1190 | return substream->runtime->oss.period_bytes; | 1190 | return substream->runtime->oss.period_bytes; |
1191 | } | 1191 | } |
1192 | 1192 | ||
1193 | static int snd_pcm_oss_get_formats(snd_pcm_oss_file_t *pcm_oss_file) | 1193 | static int snd_pcm_oss_get_formats(struct snd_pcm_oss_file *pcm_oss_file) |
1194 | { | 1194 | { |
1195 | snd_pcm_substream_t *substream; | 1195 | struct snd_pcm_substream *substream; |
1196 | int err; | 1196 | int err; |
1197 | int direct; | 1197 | int direct; |
1198 | snd_pcm_hw_params_t *params; | 1198 | struct snd_pcm_hw_params *params; |
1199 | unsigned int formats = 0; | 1199 | unsigned int formats = 0; |
1200 | snd_mask_t format_mask; | 1200 | struct snd_mask format_mask; |
1201 | int fmt; | 1201 | int fmt; |
1202 | 1202 | ||
1203 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) | 1203 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) |
@@ -1205,7 +1205,7 @@ static int snd_pcm_oss_get_formats(snd_pcm_oss_file_t *pcm_oss_file) | |||
1205 | if (atomic_read(&substream->runtime->mmap_count)) { | 1205 | if (atomic_read(&substream->runtime->mmap_count)) { |
1206 | direct = 1; | 1206 | direct = 1; |
1207 | } else { | 1207 | } else { |
1208 | snd_pcm_oss_setup_t *setup = substream->oss.setup; | 1208 | struct snd_pcm_oss_setup *setup = substream->oss.setup; |
1209 | direct = (setup != NULL && setup->direct); | 1209 | direct = (setup != NULL && setup->direct); |
1210 | } | 1210 | } |
1211 | if (!direct) | 1211 | if (!direct) |
@@ -1231,7 +1231,7 @@ static int snd_pcm_oss_get_formats(snd_pcm_oss_file_t *pcm_oss_file) | |||
1231 | return formats; | 1231 | return formats; |
1232 | } | 1232 | } |
1233 | 1233 | ||
1234 | static int snd_pcm_oss_set_format(snd_pcm_oss_file_t *pcm_oss_file, int format) | 1234 | static int snd_pcm_oss_set_format(struct snd_pcm_oss_file *pcm_oss_file, int format) |
1235 | { | 1235 | { |
1236 | int formats, idx; | 1236 | int formats, idx; |
1237 | 1237 | ||
@@ -1240,8 +1240,8 @@ static int snd_pcm_oss_set_format(snd_pcm_oss_file_t *pcm_oss_file, int format) | |||
1240 | if (!(formats & format)) | 1240 | if (!(formats & format)) |
1241 | format = AFMT_U8; | 1241 | format = AFMT_U8; |
1242 | for (idx = 1; idx >= 0; --idx) { | 1242 | for (idx = 1; idx >= 0; --idx) { |
1243 | snd_pcm_substream_t *substream = pcm_oss_file->streams[idx]; | 1243 | struct snd_pcm_substream *substream = pcm_oss_file->streams[idx]; |
1244 | snd_pcm_runtime_t *runtime; | 1244 | struct snd_pcm_runtime *runtime; |
1245 | if (substream == NULL) | 1245 | if (substream == NULL) |
1246 | continue; | 1246 | continue; |
1247 | runtime = substream->runtime; | 1247 | runtime = substream->runtime; |
@@ -1254,9 +1254,9 @@ static int snd_pcm_oss_set_format(snd_pcm_oss_file_t *pcm_oss_file, int format) | |||
1254 | return snd_pcm_oss_get_format(pcm_oss_file); | 1254 | return snd_pcm_oss_get_format(pcm_oss_file); |
1255 | } | 1255 | } |
1256 | 1256 | ||
1257 | static int snd_pcm_oss_get_format(snd_pcm_oss_file_t *pcm_oss_file) | 1257 | static int snd_pcm_oss_get_format(struct snd_pcm_oss_file *pcm_oss_file) |
1258 | { | 1258 | { |
1259 | snd_pcm_substream_t *substream; | 1259 | struct snd_pcm_substream *substream; |
1260 | int err; | 1260 | int err; |
1261 | 1261 | ||
1262 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) | 1262 | if ((err = snd_pcm_oss_get_active_substream(pcm_oss_file, &substream)) < 0) |
@@ -1264,9 +1264,9 @@ static int snd_pcm_oss_get_format(snd_pcm_oss_file_t *pcm_oss_file) | |||
1264 | return substream->runtime->oss.format; | 1264 | return substream->runtime->oss.format; |
1265 | } | 1265 | } |
1266 | 1266 | ||
1267 | static int snd_pcm_oss_set_subdivide1(snd_pcm_substream_t *substream, int subdivide) | 1267 | static int snd_pcm_oss_set_subdivide1(struct snd_pcm_substream *substream, int subdivide) |
1268 | { | 1268 | { |
1269 | snd_pcm_runtime_t *runtime; | 1269 | struct snd_pcm_runtime *runtime; |
1270 | 1270 | ||
1271 | if (substream == NULL) | 1271 | if (substream == NULL) |
1272 | return 0; | 1272 | return 0; |
@@ -1287,12 +1287,12 @@ static int snd_pcm_oss_set_subdivide1(snd_pcm_substream_t *substream, int subdiv | |||
1287 | return subdivide; | 1287 | return subdivide; |
1288 | } | 1288 | } |
1289 | 1289 | ||
1290 | static int snd_pcm_oss_set_subdivide(snd_pcm_oss_file_t *pcm_oss_file, int subdivide) | 1290 | static int snd_pcm_oss_set_subdivide(struct snd_pcm_oss_file *pcm_oss_file, int subdivide) |
1291 | { | 1291 | { |
1292 | int err = -EINVAL, idx; | 1292 | int err = -EINVAL, idx; |
1293 | 1293 | ||
1294 | for (idx = 1; idx >= 0; --idx) { | 1294 | for (idx = 1; idx >= 0; --idx) { |
1295 | snd_pcm_substream_t *substream = pcm_oss_file->streams[idx]; | 1295 | struct snd_pcm_substream *substream = pcm_oss_file->streams[idx]; |
1296 | if (substream == NULL) | 1296 | if (substream == NULL) |
1297 | continue; | 1297 | continue; |
1298 | if ((err = snd_pcm_oss_set_subdivide1(substream, subdivide)) < 0) | 1298 | if ((err = snd_pcm_oss_set_subdivide1(substream, subdivide)) < 0) |
@@ -1301,9 +1301,9 @@ static int snd_pcm_oss_set_subdivide(snd_pcm_oss_file_t *pcm_oss_file, int subdi | |||
1301 | return err; | 1301 | return err; |
1302 | } | 1302 | } |
1303 | 1303 | ||
1304 | static int snd_pcm_oss_set_fragment1(snd_pcm_substream_t *substream, unsigned int val) | 1304 | static int snd_pcm_oss_set_fragment1(struct snd_pcm_substream *substream, unsigned int val) |
1305 | { | 1305 | { |
1306 | snd_pcm_runtime_t *runtime; | 1306 | struct snd_pcm_runtime *runtime; |
1307 | 1307 | ||
1308 | if (substream == NULL) | 1308 | if (substream == NULL) |
1309 | return 0; | 1309 | return 0; |
@@ -1320,12 +1320,12 @@ static int snd_pcm_oss_set_fragment1(snd_pcm_substream_t *substream, unsigned in | |||
1320 | return 0; | 1320 | return 0; |
1321 | } | 1321 | } |
1322 | 1322 | ||
1323 | static int snd_pcm_oss_set_fragment(snd_pcm_oss_file_t *pcm_oss_file, unsigned int val) | 1323 | static int snd_pcm_oss_set_fragment(struct snd_pcm_oss_file *pcm_oss_file, unsigned int val) |
1324 | { | 1324 | { |
1325 | int err = -EINVAL, idx; | 1325 | int err = -EINVAL, idx; |
1326 | 1326 | ||
1327 | for (idx = 1; idx >= 0; --idx) { | 1327 | for (idx = 1; idx >= 0; --idx) { |
1328 | snd_pcm_substream_t *substream = pcm_oss_file->streams[idx]; | 1328 | struct snd_pcm_substream *substream = pcm_oss_file->streams[idx]; |
1329 | if (substream == NULL) | 1329 | if (substream == NULL) |
1330 | continue; | 1330 | continue; |
1331 | if ((err = snd_pcm_oss_set_fragment1(substream, val)) < 0) | 1331 | if ((err = snd_pcm_oss_set_fragment1(substream, val)) < 0) |
@@ -1340,7 +1340,7 @@ static int snd_pcm_oss_nonblock(struct file * file) | |||
1340 | return 0; | 1340 | return 0; |
1341 | } | 1341 | } |
1342 | 1342 | ||
1343 | static int snd_pcm_oss_get_caps1(snd_pcm_substream_t *substream, int res) | 1343 | static int snd_pcm_oss_get_caps1(struct snd_pcm_substream *substream, int res) |
1344 | { | 1344 | { |
1345 | 1345 | ||
1346 | if (substream == NULL) { | 1346 | if (substream == NULL) { |
@@ -1356,7 +1356,7 @@ static int snd_pcm_oss_get_caps1(snd_pcm_substream_t *substream, int res) | |||
1356 | /* all ALSA drivers can return actual pointer in ring buffer */ | 1356 | /* all ALSA drivers can return actual pointer in ring buffer */ |
1357 | #if defined(DSP_CAP_REALTIME) && 0 | 1357 | #if defined(DSP_CAP_REALTIME) && 0 |
1358 | { | 1358 | { |
1359 | snd_pcm_runtime_t *runtime = substream->runtime; | 1359 | struct snd_pcm_runtime *runtime = substream->runtime; |
1360 | if (runtime->info & (SNDRV_PCM_INFO_BLOCK_TRANSFER|SNDRV_PCM_INFO_BATCH)) | 1360 | if (runtime->info & (SNDRV_PCM_INFO_BLOCK_TRANSFER|SNDRV_PCM_INFO_BATCH)) |
1361 | res &= ~DSP_CAP_REALTIME; | 1361 | res &= ~DSP_CAP_REALTIME; |
1362 | } | 1362 | } |
@@ -1364,32 +1364,32 @@ static int snd_pcm_oss_get_caps1(snd_pcm_substream_t *substream, int res) | |||
1364 | return res; | 1364 | return res; |
1365 | } | 1365 | } |
1366 | 1366 | ||
1367 | static int snd_pcm_oss_get_caps(snd_pcm_oss_file_t *pcm_oss_file) | 1367 | static int snd_pcm_oss_get_caps(struct snd_pcm_oss_file *pcm_oss_file) |
1368 | { | 1368 | { |
1369 | int result, idx; | 1369 | int result, idx; |
1370 | 1370 | ||
1371 | result = DSP_CAP_TRIGGER | DSP_CAP_MMAP | DSP_CAP_DUPLEX | DSP_CAP_REALTIME; | 1371 | result = DSP_CAP_TRIGGER | DSP_CAP_MMAP | DSP_CAP_DUPLEX | DSP_CAP_REALTIME; |
1372 | for (idx = 0; idx < 2; idx++) { | 1372 | for (idx = 0; idx < 2; idx++) { |
1373 | snd_pcm_substream_t *substream = pcm_oss_file->streams[idx]; | 1373 | struct snd_pcm_substream *substream = pcm_oss_file->streams[idx]; |
1374 | result = snd_pcm_oss_get_caps1(substream, result); | 1374 | result = snd_pcm_oss_get_caps1(substream, result); |
1375 | } | 1375 | } |
1376 | result |= 0x0001; /* revision - same as SB AWE 64 */ | 1376 | result |= 0x0001; /* revision - same as SB AWE 64 */ |
1377 | return result; | 1377 | return result; |
1378 | } | 1378 | } |
1379 | 1379 | ||
1380 | static void snd_pcm_oss_simulate_fill(snd_pcm_substream_t *substream, snd_pcm_uframes_t hw_ptr) | 1380 | static void snd_pcm_oss_simulate_fill(struct snd_pcm_substream *substream, snd_pcm_uframes_t hw_ptr) |
1381 | { | 1381 | { |
1382 | snd_pcm_runtime_t *runtime = substream->runtime; | 1382 | struct snd_pcm_runtime *runtime = substream->runtime; |
1383 | snd_pcm_uframes_t appl_ptr; | 1383 | snd_pcm_uframes_t appl_ptr; |
1384 | appl_ptr = hw_ptr + runtime->buffer_size; | 1384 | appl_ptr = hw_ptr + runtime->buffer_size; |
1385 | appl_ptr %= runtime->boundary; | 1385 | appl_ptr %= runtime->boundary; |
1386 | runtime->control->appl_ptr = appl_ptr; | 1386 | runtime->control->appl_ptr = appl_ptr; |
1387 | } | 1387 | } |
1388 | 1388 | ||
1389 | static int snd_pcm_oss_set_trigger(snd_pcm_oss_file_t *pcm_oss_file, int trigger) | 1389 | static int snd_pcm_oss_set_trigger(struct snd_pcm_oss_file *pcm_oss_file, int trigger) |
1390 | { | 1390 | { |
1391 | snd_pcm_runtime_t *runtime; | 1391 | struct snd_pcm_runtime *runtime; |
1392 | snd_pcm_substream_t *psubstream = NULL, *csubstream = NULL; | 1392 | struct snd_pcm_substream *psubstream = NULL, *csubstream = NULL; |
1393 | int err, cmd; | 1393 | int err, cmd; |
1394 | 1394 | ||
1395 | #ifdef OSS_DEBUG | 1395 | #ifdef OSS_DEBUG |
@@ -1454,9 +1454,9 @@ static int snd_pcm_oss_set_trigger(snd_pcm_oss_file_t *pcm_oss_file, int trigger | |||
1454 | return 0; | 1454 | return 0; |
1455 | } | 1455 | } |
1456 | 1456 | ||
1457 | static int snd_pcm_oss_get_trigger(snd_pcm_oss_file_t *pcm_oss_file) | 1457 | static int snd_pcm_oss_get_trigger(struct snd_pcm_oss_file *pcm_oss_file) |
1458 | { | 1458 | { |
1459 | snd_pcm_substream_t *psubstream = NULL, *csubstream = NULL; | 1459 | struct snd_pcm_substream *psubstream = NULL, *csubstream = NULL; |
1460 | int result = 0; | 1460 | int result = 0; |
1461 | 1461 | ||
1462 | psubstream = pcm_oss_file->streams[SNDRV_PCM_STREAM_PLAYBACK]; | 1462 | psubstream = pcm_oss_file->streams[SNDRV_PCM_STREAM_PLAYBACK]; |
@@ -1468,10 +1468,10 @@ static int snd_pcm_oss_get_trigger(snd_pcm_oss_file_t *pcm_oss_file) | |||
1468 | return result; | 1468 | return result; |
1469 | } | 1469 | } |
1470 | 1470 | ||
1471 | static int snd_pcm_oss_get_odelay(snd_pcm_oss_file_t *pcm_oss_file) | 1471 | static int snd_pcm_oss_get_odelay(struct snd_pcm_oss_file *pcm_oss_file) |
1472 | { | 1472 | { |
1473 | snd_pcm_substream_t *substream; | 1473 | struct snd_pcm_substream *substream; |
1474 | snd_pcm_runtime_t *runtime; | 1474 | struct snd_pcm_runtime *runtime; |
1475 | snd_pcm_sframes_t delay; | 1475 | snd_pcm_sframes_t delay; |
1476 | int err; | 1476 | int err; |
1477 | 1477 | ||
@@ -1491,10 +1491,10 @@ static int snd_pcm_oss_get_odelay(snd_pcm_oss_file_t *pcm_oss_file) | |||
1491 | return snd_pcm_oss_bytes(substream, delay); | 1491 | return snd_pcm_oss_bytes(substream, delay); |
1492 | } | 1492 | } |
1493 | 1493 | ||
1494 | static int snd_pcm_oss_get_ptr(snd_pcm_oss_file_t *pcm_oss_file, int stream, struct count_info __user * _info) | 1494 | static int snd_pcm_oss_get_ptr(struct snd_pcm_oss_file *pcm_oss_file, int stream, struct count_info __user * _info) |
1495 | { | 1495 | { |
1496 | snd_pcm_substream_t *substream; | 1496 | struct snd_pcm_substream *substream; |
1497 | snd_pcm_runtime_t *runtime; | 1497 | struct snd_pcm_runtime *runtime; |
1498 | snd_pcm_sframes_t delay; | 1498 | snd_pcm_sframes_t delay; |
1499 | int fixup; | 1499 | int fixup; |
1500 | struct count_info info; | 1500 | struct count_info info; |
@@ -1543,7 +1543,7 @@ static int snd_pcm_oss_get_ptr(snd_pcm_oss_file_t *pcm_oss_file, int stream, str | |||
1543 | } else { | 1543 | } else { |
1544 | delay = snd_pcm_oss_bytes(substream, delay); | 1544 | delay = snd_pcm_oss_bytes(substream, delay); |
1545 | if (stream == SNDRV_PCM_STREAM_PLAYBACK) { | 1545 | if (stream == SNDRV_PCM_STREAM_PLAYBACK) { |
1546 | snd_pcm_oss_setup_t *setup = substream->oss.setup; | 1546 | struct snd_pcm_oss_setup *setup = substream->oss.setup; |
1547 | if (setup && setup->buggyptr) | 1547 | if (setup && setup->buggyptr) |
1548 | info.blocks = (runtime->oss.buffer_bytes - delay - fixup) / runtime->oss.period_bytes; | 1548 | info.blocks = (runtime->oss.buffer_bytes - delay - fixup) / runtime->oss.period_bytes; |
1549 | else | 1549 | else |
@@ -1560,10 +1560,10 @@ static int snd_pcm_oss_get_ptr(snd_pcm_oss_file_t *pcm_oss_file, int stream, str | |||
1560 | return 0; | 1560 | return 0; |
1561 | } | 1561 | } |
1562 | 1562 | ||
1563 | static int snd_pcm_oss_get_space(snd_pcm_oss_file_t *pcm_oss_file, int stream, struct audio_buf_info __user *_info) | 1563 | static int snd_pcm_oss_get_space(struct snd_pcm_oss_file *pcm_oss_file, int stream, struct audio_buf_info __user *_info) |
1564 | { | 1564 | { |
1565 | snd_pcm_substream_t *substream; | 1565 | struct snd_pcm_substream *substream; |
1566 | snd_pcm_runtime_t *runtime; | 1566 | struct snd_pcm_runtime *runtime; |
1567 | snd_pcm_sframes_t avail; | 1567 | snd_pcm_sframes_t avail; |
1568 | int fixup; | 1568 | int fixup; |
1569 | struct audio_buf_info info; | 1569 | struct audio_buf_info info; |
@@ -1619,17 +1619,17 @@ static int snd_pcm_oss_get_space(snd_pcm_oss_file_t *pcm_oss_file, int stream, s | |||
1619 | return 0; | 1619 | return 0; |
1620 | } | 1620 | } |
1621 | 1621 | ||
1622 | static int snd_pcm_oss_get_mapbuf(snd_pcm_oss_file_t *pcm_oss_file, int stream, struct buffmem_desc __user * _info) | 1622 | static int snd_pcm_oss_get_mapbuf(struct snd_pcm_oss_file *pcm_oss_file, int stream, struct buffmem_desc __user * _info) |
1623 | { | 1623 | { |
1624 | // it won't be probably implemented | 1624 | // it won't be probably implemented |
1625 | // snd_printd("TODO: snd_pcm_oss_get_mapbuf\n"); | 1625 | // snd_printd("TODO: snd_pcm_oss_get_mapbuf\n"); |
1626 | return -EINVAL; | 1626 | return -EINVAL; |
1627 | } | 1627 | } |
1628 | 1628 | ||
1629 | static snd_pcm_oss_setup_t *snd_pcm_oss_look_for_setup(snd_pcm_t *pcm, int stream, const char *task_name) | 1629 | static struct snd_pcm_oss_setup *snd_pcm_oss_look_for_setup(struct snd_pcm *pcm, int stream, const char *task_name) |
1630 | { | 1630 | { |
1631 | const char *ptr, *ptrl; | 1631 | const char *ptr, *ptrl; |
1632 | snd_pcm_oss_setup_t *setup; | 1632 | struct snd_pcm_oss_setup *setup; |
1633 | 1633 | ||
1634 | down(&pcm->streams[stream].oss.setup_mutex); | 1634 | down(&pcm->streams[stream].oss.setup_mutex); |
1635 | for (setup = pcm->streams[stream].oss.setup_list; setup; setup = setup->next) { | 1635 | for (setup = pcm->streams[stream].oss.setup_list; setup; setup = setup->next) { |
@@ -1659,11 +1659,11 @@ static snd_pcm_oss_setup_t *snd_pcm_oss_look_for_setup(snd_pcm_t *pcm, int strea | |||
1659 | return NULL; | 1659 | return NULL; |
1660 | } | 1660 | } |
1661 | 1661 | ||
1662 | static void snd_pcm_oss_init_substream(snd_pcm_substream_t *substream, | 1662 | static void snd_pcm_oss_init_substream(struct snd_pcm_substream *substream, |
1663 | snd_pcm_oss_setup_t *setup, | 1663 | struct snd_pcm_oss_setup *setup, |
1664 | int minor) | 1664 | int minor) |
1665 | { | 1665 | { |
1666 | snd_pcm_runtime_t *runtime; | 1666 | struct snd_pcm_runtime *runtime; |
1667 | 1667 | ||
1668 | substream->oss.oss = 1; | 1668 | substream->oss.oss = 1; |
1669 | substream->oss.setup = setup; | 1669 | substream->oss.setup = setup; |
@@ -1687,9 +1687,9 @@ static void snd_pcm_oss_init_substream(snd_pcm_substream_t *substream, | |||
1687 | runtime->oss.subdivision = 0; | 1687 | runtime->oss.subdivision = 0; |
1688 | } | 1688 | } |
1689 | 1689 | ||
1690 | static void snd_pcm_oss_release_substream(snd_pcm_substream_t *substream) | 1690 | static void snd_pcm_oss_release_substream(struct snd_pcm_substream *substream) |
1691 | { | 1691 | { |
1692 | snd_pcm_runtime_t *runtime; | 1692 | struct snd_pcm_runtime *runtime; |
1693 | runtime = substream->runtime; | 1693 | runtime = substream->runtime; |
1694 | vfree(runtime->oss.buffer); | 1694 | vfree(runtime->oss.buffer); |
1695 | snd_pcm_oss_plugin_clear(substream); | 1695 | snd_pcm_oss_plugin_clear(substream); |
@@ -1697,13 +1697,13 @@ static void snd_pcm_oss_release_substream(snd_pcm_substream_t *substream) | |||
1697 | substream->oss.oss = 0; | 1697 | substream->oss.oss = 0; |
1698 | } | 1698 | } |
1699 | 1699 | ||
1700 | static int snd_pcm_oss_release_file(snd_pcm_oss_file_t *pcm_oss_file) | 1700 | static int snd_pcm_oss_release_file(struct snd_pcm_oss_file *pcm_oss_file) |
1701 | { | 1701 | { |
1702 | int cidx; | 1702 | int cidx; |
1703 | snd_assert(pcm_oss_file != NULL, return -ENXIO); | 1703 | snd_assert(pcm_oss_file != NULL, return -ENXIO); |
1704 | for (cidx = 0; cidx < 2; ++cidx) { | 1704 | for (cidx = 0; cidx < 2; ++cidx) { |
1705 | snd_pcm_substream_t *substream = pcm_oss_file->streams[cidx]; | 1705 | struct snd_pcm_substream *substream = pcm_oss_file->streams[cidx]; |
1706 | snd_pcm_runtime_t *runtime; | 1706 | struct snd_pcm_runtime *runtime; |
1707 | if (substream == NULL) | 1707 | if (substream == NULL) |
1708 | continue; | 1708 | continue; |
1709 | runtime = substream->runtime; | 1709 | runtime = substream->runtime; |
@@ -1726,15 +1726,15 @@ static int snd_pcm_oss_release_file(snd_pcm_oss_file_t *pcm_oss_file) | |||
1726 | } | 1726 | } |
1727 | 1727 | ||
1728 | static int snd_pcm_oss_open_file(struct file *file, | 1728 | static int snd_pcm_oss_open_file(struct file *file, |
1729 | snd_pcm_t *pcm, | 1729 | struct snd_pcm *pcm, |
1730 | snd_pcm_oss_file_t **rpcm_oss_file, | 1730 | struct snd_pcm_oss_file **rpcm_oss_file, |
1731 | int minor, | 1731 | int minor, |
1732 | snd_pcm_oss_setup_t *psetup, | 1732 | struct snd_pcm_oss_setup *psetup, |
1733 | snd_pcm_oss_setup_t *csetup) | 1733 | struct snd_pcm_oss_setup *csetup) |
1734 | { | 1734 | { |
1735 | int err = 0; | 1735 | int err = 0; |
1736 | snd_pcm_oss_file_t *pcm_oss_file; | 1736 | struct snd_pcm_oss_file *pcm_oss_file; |
1737 | snd_pcm_substream_t *psubstream = NULL, *csubstream = NULL; | 1737 | struct snd_pcm_substream *psubstream = NULL, *csubstream = NULL; |
1738 | unsigned int f_mode = file->f_mode; | 1738 | unsigned int f_mode = file->f_mode; |
1739 | 1739 | ||
1740 | snd_assert(rpcm_oss_file != NULL, return -EINVAL); | 1740 | snd_assert(rpcm_oss_file != NULL, return -EINVAL); |
@@ -1839,9 +1839,9 @@ static int snd_pcm_oss_open(struct inode *inode, struct file *file) | |||
1839 | int device; | 1839 | int device; |
1840 | int err; | 1840 | int err; |
1841 | char task_name[32]; | 1841 | char task_name[32]; |
1842 | snd_pcm_t *pcm; | 1842 | struct snd_pcm *pcm; |
1843 | snd_pcm_oss_file_t *pcm_oss_file; | 1843 | struct snd_pcm_oss_file *pcm_oss_file; |
1844 | snd_pcm_oss_setup_t *psetup = NULL, *csetup = NULL; | 1844 | struct snd_pcm_oss_setup *psetup = NULL, *csetup = NULL; |
1845 | int nonblock; | 1845 | int nonblock; |
1846 | wait_queue_t wait; | 1846 | wait_queue_t wait; |
1847 | 1847 | ||
@@ -1925,9 +1925,9 @@ static int snd_pcm_oss_open(struct inode *inode, struct file *file) | |||
1925 | 1925 | ||
1926 | static int snd_pcm_oss_release(struct inode *inode, struct file *file) | 1926 | static int snd_pcm_oss_release(struct inode *inode, struct file *file) |
1927 | { | 1927 | { |
1928 | snd_pcm_t *pcm; | 1928 | struct snd_pcm *pcm; |
1929 | snd_pcm_substream_t *substream; | 1929 | struct snd_pcm_substream *substream; |
1930 | snd_pcm_oss_file_t *pcm_oss_file; | 1930 | struct snd_pcm_oss_file *pcm_oss_file; |
1931 | 1931 | ||
1932 | pcm_oss_file = file->private_data; | 1932 | pcm_oss_file = file->private_data; |
1933 | substream = pcm_oss_file->streams[SNDRV_PCM_STREAM_PLAYBACK]; | 1933 | substream = pcm_oss_file->streams[SNDRV_PCM_STREAM_PLAYBACK]; |
@@ -1947,7 +1947,7 @@ static int snd_pcm_oss_release(struct inode *inode, struct file *file) | |||
1947 | 1947 | ||
1948 | static long snd_pcm_oss_ioctl(struct file *file, unsigned int cmd, unsigned long arg) | 1948 | static long snd_pcm_oss_ioctl(struct file *file, unsigned int cmd, unsigned long arg) |
1949 | { | 1949 | { |
1950 | snd_pcm_oss_file_t *pcm_oss_file; | 1950 | struct snd_pcm_oss_file *pcm_oss_file; |
1951 | int __user *p = (int __user *)arg; | 1951 | int __user *p = (int __user *)arg; |
1952 | int res; | 1952 | int res; |
1953 | 1953 | ||
@@ -1958,7 +1958,7 @@ static long snd_pcm_oss_ioctl(struct file *file, unsigned int cmd, unsigned long | |||
1958 | return put_user(1, p); | 1958 | return put_user(1, p); |
1959 | #if defined(CONFIG_SND_MIXER_OSS) || (defined(MODULE) && defined(CONFIG_SND_MIXER_OSS_MODULE)) | 1959 | #if defined(CONFIG_SND_MIXER_OSS) || (defined(MODULE) && defined(CONFIG_SND_MIXER_OSS_MODULE)) |
1960 | if (((cmd >> 8) & 0xff) == 'M') { /* mixer ioctl - for OSS compatibility */ | 1960 | if (((cmd >> 8) & 0xff) == 'M') { /* mixer ioctl - for OSS compatibility */ |
1961 | snd_pcm_substream_t *substream; | 1961 | struct snd_pcm_substream *substream; |
1962 | int idx; | 1962 | int idx; |
1963 | for (idx = 0; idx < 2; ++idx) { | 1963 | for (idx = 0; idx < 2; ++idx) { |
1964 | substream = pcm_oss_file->streams[idx]; | 1964 | substream = pcm_oss_file->streams[idx]; |
@@ -2113,8 +2113,8 @@ static long snd_pcm_oss_ioctl(struct file *file, unsigned int cmd, unsigned long | |||
2113 | 2113 | ||
2114 | static ssize_t snd_pcm_oss_read(struct file *file, char __user *buf, size_t count, loff_t *offset) | 2114 | static ssize_t snd_pcm_oss_read(struct file *file, char __user *buf, size_t count, loff_t *offset) |
2115 | { | 2115 | { |
2116 | snd_pcm_oss_file_t *pcm_oss_file; | 2116 | struct snd_pcm_oss_file *pcm_oss_file; |
2117 | snd_pcm_substream_t *substream; | 2117 | struct snd_pcm_substream *substream; |
2118 | 2118 | ||
2119 | pcm_oss_file = file->private_data; | 2119 | pcm_oss_file = file->private_data; |
2120 | substream = pcm_oss_file->streams[SNDRV_PCM_STREAM_CAPTURE]; | 2120 | substream = pcm_oss_file->streams[SNDRV_PCM_STREAM_CAPTURE]; |
@@ -2133,8 +2133,8 @@ static ssize_t snd_pcm_oss_read(struct file *file, char __user *buf, size_t coun | |||
2133 | 2133 | ||
2134 | static ssize_t snd_pcm_oss_write(struct file *file, const char __user *buf, size_t count, loff_t *offset) | 2134 | static ssize_t snd_pcm_oss_write(struct file *file, const char __user *buf, size_t count, loff_t *offset) |
2135 | { | 2135 | { |
2136 | snd_pcm_oss_file_t *pcm_oss_file; | 2136 | struct snd_pcm_oss_file *pcm_oss_file; |
2137 | snd_pcm_substream_t *substream; | 2137 | struct snd_pcm_substream *substream; |
2138 | long result; | 2138 | long result; |
2139 | 2139 | ||
2140 | pcm_oss_file = file->private_data; | 2140 | pcm_oss_file = file->private_data; |
@@ -2150,18 +2150,18 @@ static ssize_t snd_pcm_oss_write(struct file *file, const char __user *buf, size | |||
2150 | return result; | 2150 | return result; |
2151 | } | 2151 | } |
2152 | 2152 | ||
2153 | static int snd_pcm_oss_playback_ready(snd_pcm_substream_t *substream) | 2153 | static int snd_pcm_oss_playback_ready(struct snd_pcm_substream *substream) |
2154 | { | 2154 | { |
2155 | snd_pcm_runtime_t *runtime = substream->runtime; | 2155 | struct snd_pcm_runtime *runtime = substream->runtime; |
2156 | if (atomic_read(&runtime->mmap_count)) | 2156 | if (atomic_read(&runtime->mmap_count)) |
2157 | return runtime->oss.prev_hw_ptr_interrupt != runtime->hw_ptr_interrupt; | 2157 | return runtime->oss.prev_hw_ptr_interrupt != runtime->hw_ptr_interrupt; |
2158 | else | 2158 | else |
2159 | return snd_pcm_playback_avail(runtime) >= runtime->oss.period_frames; | 2159 | return snd_pcm_playback_avail(runtime) >= runtime->oss.period_frames; |
2160 | } | 2160 | } |
2161 | 2161 | ||
2162 | static int snd_pcm_oss_capture_ready(snd_pcm_substream_t *substream) | 2162 | static int snd_pcm_oss_capture_ready(struct snd_pcm_substream *substream) |
2163 | { | 2163 | { |
2164 | snd_pcm_runtime_t *runtime = substream->runtime; | 2164 | struct snd_pcm_runtime *runtime = substream->runtime; |
2165 | if (atomic_read(&runtime->mmap_count)) | 2165 | if (atomic_read(&runtime->mmap_count)) |
2166 | return runtime->oss.prev_hw_ptr_interrupt != runtime->hw_ptr_interrupt; | 2166 | return runtime->oss.prev_hw_ptr_interrupt != runtime->hw_ptr_interrupt; |
2167 | else | 2167 | else |
@@ -2170,9 +2170,9 @@ static int snd_pcm_oss_capture_ready(snd_pcm_substream_t *substream) | |||
2170 | 2170 | ||
2171 | static unsigned int snd_pcm_oss_poll(struct file *file, poll_table * wait) | 2171 | static unsigned int snd_pcm_oss_poll(struct file *file, poll_table * wait) |
2172 | { | 2172 | { |
2173 | snd_pcm_oss_file_t *pcm_oss_file; | 2173 | struct snd_pcm_oss_file *pcm_oss_file; |
2174 | unsigned int mask; | 2174 | unsigned int mask; |
2175 | snd_pcm_substream_t *psubstream = NULL, *csubstream = NULL; | 2175 | struct snd_pcm_substream *psubstream = NULL, *csubstream = NULL; |
2176 | 2176 | ||
2177 | pcm_oss_file = file->private_data; | 2177 | pcm_oss_file = file->private_data; |
2178 | 2178 | ||
@@ -2181,7 +2181,7 @@ static unsigned int snd_pcm_oss_poll(struct file *file, poll_table * wait) | |||
2181 | 2181 | ||
2182 | mask = 0; | 2182 | mask = 0; |
2183 | if (psubstream != NULL) { | 2183 | if (psubstream != NULL) { |
2184 | snd_pcm_runtime_t *runtime = psubstream->runtime; | 2184 | struct snd_pcm_runtime *runtime = psubstream->runtime; |
2185 | poll_wait(file, &runtime->sleep, wait); | 2185 | poll_wait(file, &runtime->sleep, wait); |
2186 | snd_pcm_stream_lock_irq(psubstream); | 2186 | snd_pcm_stream_lock_irq(psubstream); |
2187 | if (runtime->status->state != SNDRV_PCM_STATE_DRAINING && | 2187 | if (runtime->status->state != SNDRV_PCM_STATE_DRAINING && |
@@ -2191,8 +2191,8 @@ static unsigned int snd_pcm_oss_poll(struct file *file, poll_table * wait) | |||
2191 | snd_pcm_stream_unlock_irq(psubstream); | 2191 | snd_pcm_stream_unlock_irq(psubstream); |
2192 | } | 2192 | } |
2193 | if (csubstream != NULL) { | 2193 | if (csubstream != NULL) { |
2194 | snd_pcm_runtime_t *runtime = csubstream->runtime; | 2194 | struct snd_pcm_runtime *runtime = csubstream->runtime; |
2195 | enum sndrv_pcm_state ostate; | 2195 | snd_pcm_state_t ostate; |
2196 | poll_wait(file, &runtime->sleep, wait); | 2196 | poll_wait(file, &runtime->sleep, wait); |
2197 | snd_pcm_stream_lock_irq(csubstream); | 2197 | snd_pcm_stream_lock_irq(csubstream); |
2198 | if ((ostate = runtime->status->state) != SNDRV_PCM_STATE_RUNNING || | 2198 | if ((ostate = runtime->status->state) != SNDRV_PCM_STATE_RUNNING || |
@@ -2200,7 +2200,7 @@ static unsigned int snd_pcm_oss_poll(struct file *file, poll_table * wait) | |||
2200 | mask |= POLLIN | POLLRDNORM; | 2200 | mask |= POLLIN | POLLRDNORM; |
2201 | snd_pcm_stream_unlock_irq(csubstream); | 2201 | snd_pcm_stream_unlock_irq(csubstream); |
2202 | if (ostate != SNDRV_PCM_STATE_RUNNING && runtime->oss.trigger) { | 2202 | if (ostate != SNDRV_PCM_STATE_RUNNING && runtime->oss.trigger) { |
2203 | snd_pcm_oss_file_t ofile; | 2203 | struct snd_pcm_oss_file ofile; |
2204 | memset(&ofile, 0, sizeof(ofile)); | 2204 | memset(&ofile, 0, sizeof(ofile)); |
2205 | ofile.streams[SNDRV_PCM_STREAM_CAPTURE] = pcm_oss_file->streams[SNDRV_PCM_STREAM_CAPTURE]; | 2205 | ofile.streams[SNDRV_PCM_STREAM_CAPTURE] = pcm_oss_file->streams[SNDRV_PCM_STREAM_CAPTURE]; |
2206 | runtime->oss.trigger = 0; | 2206 | runtime->oss.trigger = 0; |
@@ -2213,9 +2213,9 @@ static unsigned int snd_pcm_oss_poll(struct file *file, poll_table * wait) | |||
2213 | 2213 | ||
2214 | static int snd_pcm_oss_mmap(struct file *file, struct vm_area_struct *area) | 2214 | static int snd_pcm_oss_mmap(struct file *file, struct vm_area_struct *area) |
2215 | { | 2215 | { |
2216 | snd_pcm_oss_file_t *pcm_oss_file; | 2216 | struct snd_pcm_oss_file *pcm_oss_file; |
2217 | snd_pcm_substream_t *substream = NULL; | 2217 | struct snd_pcm_substream *substream = NULL; |
2218 | snd_pcm_runtime_t *runtime; | 2218 | struct snd_pcm_runtime *runtime; |
2219 | int err; | 2219 | int err; |
2220 | 2220 | ||
2221 | #ifdef OSS_DEBUG | 2221 | #ifdef OSS_DEBUG |
@@ -2279,11 +2279,11 @@ static int snd_pcm_oss_mmap(struct file *file, struct vm_area_struct *area) | |||
2279 | * /proc interface | 2279 | * /proc interface |
2280 | */ | 2280 | */ |
2281 | 2281 | ||
2282 | static void snd_pcm_oss_proc_read(snd_info_entry_t *entry, | 2282 | static void snd_pcm_oss_proc_read(struct snd_info_entry *entry, |
2283 | snd_info_buffer_t * buffer) | 2283 | struct snd_info_buffer *buffer) |
2284 | { | 2284 | { |
2285 | snd_pcm_str_t *pstr = (snd_pcm_str_t *)entry->private_data; | 2285 | struct snd_pcm_str *pstr = entry->private_data; |
2286 | snd_pcm_oss_setup_t *setup = pstr->oss.setup_list; | 2286 | struct snd_pcm_oss_setup *setup = pstr->oss.setup_list; |
2287 | down(&pstr->oss.setup_mutex); | 2287 | down(&pstr->oss.setup_mutex); |
2288 | while (setup) { | 2288 | while (setup) { |
2289 | snd_iprintf(buffer, "%s %u %u%s%s%s%s%s%s\n", | 2289 | snd_iprintf(buffer, "%s %u %u%s%s%s%s%s%s\n", |
@@ -2301,11 +2301,11 @@ static void snd_pcm_oss_proc_read(snd_info_entry_t *entry, | |||
2301 | up(&pstr->oss.setup_mutex); | 2301 | up(&pstr->oss.setup_mutex); |
2302 | } | 2302 | } |
2303 | 2303 | ||
2304 | static void snd_pcm_oss_proc_free_setup_list(snd_pcm_str_t * pstr) | 2304 | static void snd_pcm_oss_proc_free_setup_list(struct snd_pcm_str * pstr) |
2305 | { | 2305 | { |
2306 | unsigned int idx; | 2306 | unsigned int idx; |
2307 | snd_pcm_substream_t *substream; | 2307 | struct snd_pcm_substream *substream; |
2308 | snd_pcm_oss_setup_t *setup, *setupn; | 2308 | struct snd_pcm_oss_setup *setup, *setupn; |
2309 | 2309 | ||
2310 | for (idx = 0, substream = pstr->substream; | 2310 | for (idx = 0, substream = pstr->substream; |
2311 | idx < pstr->substream_count; idx++, substream = substream->next) | 2311 | idx < pstr->substream_count; idx++, substream = substream->next) |
@@ -2319,13 +2319,13 @@ static void snd_pcm_oss_proc_free_setup_list(snd_pcm_str_t * pstr) | |||
2319 | pstr->oss.setup_list = NULL; | 2319 | pstr->oss.setup_list = NULL; |
2320 | } | 2320 | } |
2321 | 2321 | ||
2322 | static void snd_pcm_oss_proc_write(snd_info_entry_t *entry, | 2322 | static void snd_pcm_oss_proc_write(struct snd_info_entry *entry, |
2323 | snd_info_buffer_t * buffer) | 2323 | struct snd_info_buffer *buffer) |
2324 | { | 2324 | { |
2325 | snd_pcm_str_t *pstr = (snd_pcm_str_t *)entry->private_data; | 2325 | struct snd_pcm_str *pstr = entry->private_data; |
2326 | char line[128], str[32], task_name[32], *ptr; | 2326 | char line[128], str[32], task_name[32], *ptr; |
2327 | int idx1; | 2327 | int idx1; |
2328 | snd_pcm_oss_setup_t *setup, *setup1, template; | 2328 | struct snd_pcm_oss_setup *setup, *setup1, template; |
2329 | 2329 | ||
2330 | while (!snd_info_get_line(buffer, line, sizeof(line))) { | 2330 | while (!snd_info_get_line(buffer, line, sizeof(line))) { |
2331 | down(&pstr->oss.setup_mutex); | 2331 | down(&pstr->oss.setup_mutex); |
@@ -2370,7 +2370,7 @@ static void snd_pcm_oss_proc_write(snd_info_entry_t *entry, | |||
2370 | } | 2370 | } |
2371 | } while (*str); | 2371 | } while (*str); |
2372 | if (setup == NULL) { | 2372 | if (setup == NULL) { |
2373 | setup = (snd_pcm_oss_setup_t *) kmalloc(sizeof(snd_pcm_oss_setup_t), GFP_KERNEL); | 2373 | setup = kmalloc(sizeof(struct snd_pcm_oss_setup), GFP_KERNEL); |
2374 | if (setup) { | 2374 | if (setup) { |
2375 | if (pstr->oss.setup_list == NULL) { | 2375 | if (pstr->oss.setup_list == NULL) { |
2376 | pstr->oss.setup_list = setup; | 2376 | pstr->oss.setup_list = setup; |
@@ -2389,12 +2389,12 @@ static void snd_pcm_oss_proc_write(snd_info_entry_t *entry, | |||
2389 | } | 2389 | } |
2390 | } | 2390 | } |
2391 | 2391 | ||
2392 | static void snd_pcm_oss_proc_init(snd_pcm_t *pcm) | 2392 | static void snd_pcm_oss_proc_init(struct snd_pcm *pcm) |
2393 | { | 2393 | { |
2394 | int stream; | 2394 | int stream; |
2395 | for (stream = 0; stream < 2; ++stream) { | 2395 | for (stream = 0; stream < 2; ++stream) { |
2396 | snd_info_entry_t *entry; | 2396 | struct snd_info_entry *entry; |
2397 | snd_pcm_str_t *pstr = &pcm->streams[stream]; | 2397 | struct snd_pcm_str *pstr = &pcm->streams[stream]; |
2398 | if (pstr->substream_count == 0) | 2398 | if (pstr->substream_count == 0) |
2399 | continue; | 2399 | continue; |
2400 | if ((entry = snd_info_create_card_entry(pcm->card, "oss", pstr->proc_root)) != NULL) { | 2400 | if ((entry = snd_info_create_card_entry(pcm->card, "oss", pstr->proc_root)) != NULL) { |
@@ -2414,11 +2414,11 @@ static void snd_pcm_oss_proc_init(snd_pcm_t *pcm) | |||
2414 | } | 2414 | } |
2415 | } | 2415 | } |
2416 | 2416 | ||
2417 | static void snd_pcm_oss_proc_done(snd_pcm_t *pcm) | 2417 | static void snd_pcm_oss_proc_done(struct snd_pcm *pcm) |
2418 | { | 2418 | { |
2419 | int stream; | 2419 | int stream; |
2420 | for (stream = 0; stream < 2; ++stream) { | 2420 | for (stream = 0; stream < 2; ++stream) { |
2421 | snd_pcm_str_t *pstr = &pcm->streams[stream]; | 2421 | struct snd_pcm_str *pstr = &pcm->streams[stream]; |
2422 | if (pstr->oss.proc_entry) { | 2422 | if (pstr->oss.proc_entry) { |
2423 | snd_info_unregister(pstr->oss.proc_entry); | 2423 | snd_info_unregister(pstr->oss.proc_entry); |
2424 | pstr->oss.proc_entry = NULL; | 2424 | pstr->oss.proc_entry = NULL; |
@@ -2444,13 +2444,13 @@ static struct file_operations snd_pcm_oss_f_reg = | |||
2444 | .mmap = snd_pcm_oss_mmap, | 2444 | .mmap = snd_pcm_oss_mmap, |
2445 | }; | 2445 | }; |
2446 | 2446 | ||
2447 | static snd_minor_t snd_pcm_oss_reg = | 2447 | static struct snd_minor snd_pcm_oss_reg = |
2448 | { | 2448 | { |
2449 | .comment = "digital audio", | 2449 | .comment = "digital audio", |
2450 | .f_ops = &snd_pcm_oss_f_reg, | 2450 | .f_ops = &snd_pcm_oss_f_reg, |
2451 | }; | 2451 | }; |
2452 | 2452 | ||
2453 | static void register_oss_dsp(snd_pcm_t *pcm, int index) | 2453 | static void register_oss_dsp(struct snd_pcm *pcm, int index) |
2454 | { | 2454 | { |
2455 | char name[128]; | 2455 | char name[128]; |
2456 | sprintf(name, "dsp%i%i", pcm->card->number, pcm->device); | 2456 | sprintf(name, "dsp%i%i", pcm->card->number, pcm->device); |
@@ -2462,7 +2462,7 @@ static void register_oss_dsp(snd_pcm_t *pcm, int index) | |||
2462 | } | 2462 | } |
2463 | } | 2463 | } |
2464 | 2464 | ||
2465 | static int snd_pcm_oss_register_minor(snd_pcm_t * pcm) | 2465 | static int snd_pcm_oss_register_minor(struct snd_pcm *pcm) |
2466 | { | 2466 | { |
2467 | pcm->oss.reg = 0; | 2467 | pcm->oss.reg = 0; |
2468 | if (dsp_map[pcm->card->number] == (int)pcm->device) { | 2468 | if (dsp_map[pcm->card->number] == (int)pcm->device) { |
@@ -2493,7 +2493,7 @@ static int snd_pcm_oss_register_minor(snd_pcm_t * pcm) | |||
2493 | return 0; | 2493 | return 0; |
2494 | } | 2494 | } |
2495 | 2495 | ||
2496 | static int snd_pcm_oss_disconnect_minor(snd_pcm_t * pcm) | 2496 | static int snd_pcm_oss_disconnect_minor(struct snd_pcm *pcm) |
2497 | { | 2497 | { |
2498 | if (pcm->oss.reg) { | 2498 | if (pcm->oss.reg) { |
2499 | if (pcm->oss.reg_mask & 1) { | 2499 | if (pcm->oss.reg_mask & 1) { |
@@ -2510,7 +2510,7 @@ static int snd_pcm_oss_disconnect_minor(snd_pcm_t * pcm) | |||
2510 | return 0; | 2510 | return 0; |
2511 | } | 2511 | } |
2512 | 2512 | ||
2513 | static int snd_pcm_oss_unregister_minor(snd_pcm_t * pcm) | 2513 | static int snd_pcm_oss_unregister_minor(struct snd_pcm *pcm) |
2514 | { | 2514 | { |
2515 | snd_pcm_oss_disconnect_minor(pcm); | 2515 | snd_pcm_oss_disconnect_minor(pcm); |
2516 | if (pcm->oss.reg) { | 2516 | if (pcm->oss.reg) { |
@@ -2525,7 +2525,7 @@ static int snd_pcm_oss_unregister_minor(snd_pcm_t * pcm) | |||
2525 | return 0; | 2525 | return 0; |
2526 | } | 2526 | } |
2527 | 2527 | ||
2528 | static snd_pcm_notify_t snd_pcm_oss_notify = | 2528 | static struct snd_pcm_notify snd_pcm_oss_notify = |
2529 | { | 2529 | { |
2530 | .n_register = snd_pcm_oss_register_minor, | 2530 | .n_register = snd_pcm_oss_register_minor, |
2531 | .n_disconnect = snd_pcm_oss_disconnect_minor, | 2531 | .n_disconnect = snd_pcm_oss_disconnect_minor, |
diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c index 312ae1f2bfc3..7e8676880dde 100644 --- a/sound/core/oss/pcm_plugin.c +++ b/sound/core/oss/pcm_plugin.c | |||
@@ -36,7 +36,7 @@ | |||
36 | #define snd_pcm_plug_first(plug) ((plug)->runtime->oss.plugin_first) | 36 | #define snd_pcm_plug_first(plug) ((plug)->runtime->oss.plugin_first) |
37 | #define snd_pcm_plug_last(plug) ((plug)->runtime->oss.plugin_last) | 37 | #define snd_pcm_plug_last(plug) ((plug)->runtime->oss.plugin_last) |
38 | 38 | ||
39 | static int snd_pcm_plugin_src_channels_mask(snd_pcm_plugin_t *plugin, | 39 | static int snd_pcm_plugin_src_channels_mask(struct snd_pcm_plugin *plugin, |
40 | unsigned long *dst_vmask, | 40 | unsigned long *dst_vmask, |
41 | unsigned long **src_vmask) | 41 | unsigned long **src_vmask) |
42 | { | 42 | { |
@@ -46,7 +46,7 @@ static int snd_pcm_plugin_src_channels_mask(snd_pcm_plugin_t *plugin, | |||
46 | return 0; | 46 | return 0; |
47 | } | 47 | } |
48 | 48 | ||
49 | static int snd_pcm_plugin_dst_channels_mask(snd_pcm_plugin_t *plugin, | 49 | static int snd_pcm_plugin_dst_channels_mask(struct snd_pcm_plugin *plugin, |
50 | unsigned long *src_vmask, | 50 | unsigned long *src_vmask, |
51 | unsigned long **dst_vmask) | 51 | unsigned long **dst_vmask) |
52 | { | 52 | { |
@@ -67,13 +67,13 @@ static int rate_match(unsigned int src_rate, unsigned int dst_rate) | |||
67 | return dst_rate >= low && dst_rate <= high; | 67 | return dst_rate >= low && dst_rate <= high; |
68 | } | 68 | } |
69 | 69 | ||
70 | static int snd_pcm_plugin_alloc(snd_pcm_plugin_t *plugin, snd_pcm_uframes_t frames) | 70 | static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t frames) |
71 | { | 71 | { |
72 | snd_pcm_plugin_format_t *format; | 72 | struct snd_pcm_plugin_format *format; |
73 | ssize_t width; | 73 | ssize_t width; |
74 | size_t size; | 74 | size_t size; |
75 | unsigned int channel; | 75 | unsigned int channel; |
76 | snd_pcm_plugin_channel_t *c; | 76 | struct snd_pcm_plugin_channel *c; |
77 | 77 | ||
78 | if (plugin->stream == SNDRV_PCM_STREAM_PLAYBACK) { | 78 | if (plugin->stream == SNDRV_PCM_STREAM_PLAYBACK) { |
79 | format = &plugin->src_format; | 79 | format = &plugin->src_format; |
@@ -120,12 +120,12 @@ static int snd_pcm_plugin_alloc(snd_pcm_plugin_t *plugin, snd_pcm_uframes_t fram | |||
120 | return 0; | 120 | return 0; |
121 | } | 121 | } |
122 | 122 | ||
123 | int snd_pcm_plug_alloc(snd_pcm_plug_t *plug, snd_pcm_uframes_t frames) | 123 | int snd_pcm_plug_alloc(struct snd_pcm_substream *plug, snd_pcm_uframes_t frames) |
124 | { | 124 | { |
125 | int err; | 125 | int err; |
126 | snd_assert(snd_pcm_plug_first(plug) != NULL, return -ENXIO); | 126 | snd_assert(snd_pcm_plug_first(plug) != NULL, return -ENXIO); |
127 | if (snd_pcm_plug_stream(plug) == SNDRV_PCM_STREAM_PLAYBACK) { | 127 | if (snd_pcm_plug_stream(plug) == SNDRV_PCM_STREAM_PLAYBACK) { |
128 | snd_pcm_plugin_t *plugin = snd_pcm_plug_first(plug); | 128 | struct snd_pcm_plugin *plugin = snd_pcm_plug_first(plug); |
129 | while (plugin->next) { | 129 | while (plugin->next) { |
130 | if (plugin->dst_frames) | 130 | if (plugin->dst_frames) |
131 | frames = plugin->dst_frames(plugin, frames); | 131 | frames = plugin->dst_frames(plugin, frames); |
@@ -136,7 +136,7 @@ int snd_pcm_plug_alloc(snd_pcm_plug_t *plug, snd_pcm_uframes_t frames) | |||
136 | return err; | 136 | return err; |
137 | } | 137 | } |
138 | } else { | 138 | } else { |
139 | snd_pcm_plugin_t *plugin = snd_pcm_plug_last(plug); | 139 | struct snd_pcm_plugin *plugin = snd_pcm_plug_last(plug); |
140 | while (plugin->prev) { | 140 | while (plugin->prev) { |
141 | if (plugin->src_frames) | 141 | if (plugin->src_frames) |
142 | frames = plugin->src_frames(plugin, frames); | 142 | frames = plugin->src_frames(plugin, frames); |
@@ -151,22 +151,22 @@ int snd_pcm_plug_alloc(snd_pcm_plug_t *plug, snd_pcm_uframes_t frames) | |||
151 | } | 151 | } |
152 | 152 | ||
153 | 153 | ||
154 | snd_pcm_sframes_t snd_pcm_plugin_client_channels(snd_pcm_plugin_t *plugin, | 154 | snd_pcm_sframes_t snd_pcm_plugin_client_channels(struct snd_pcm_plugin *plugin, |
155 | snd_pcm_uframes_t frames, | 155 | snd_pcm_uframes_t frames, |
156 | snd_pcm_plugin_channel_t **channels) | 156 | struct snd_pcm_plugin_channel **channels) |
157 | { | 157 | { |
158 | *channels = plugin->buf_channels; | 158 | *channels = plugin->buf_channels; |
159 | return frames; | 159 | return frames; |
160 | } | 160 | } |
161 | 161 | ||
162 | int snd_pcm_plugin_build(snd_pcm_plug_t *plug, | 162 | int snd_pcm_plugin_build(struct snd_pcm_substream *plug, |
163 | const char *name, | 163 | const char *name, |
164 | snd_pcm_plugin_format_t *src_format, | 164 | struct snd_pcm_plugin_format *src_format, |
165 | snd_pcm_plugin_format_t *dst_format, | 165 | struct snd_pcm_plugin_format *dst_format, |
166 | size_t extra, | 166 | size_t extra, |
167 | snd_pcm_plugin_t **ret) | 167 | struct snd_pcm_plugin **ret) |
168 | { | 168 | { |
169 | snd_pcm_plugin_t *plugin; | 169 | struct snd_pcm_plugin *plugin; |
170 | unsigned int channels; | 170 | unsigned int channels; |
171 | 171 | ||
172 | snd_assert(plug != NULL, return -ENXIO); | 172 | snd_assert(plug != NULL, return -ENXIO); |
@@ -210,7 +210,7 @@ int snd_pcm_plugin_build(snd_pcm_plug_t *plug, | |||
210 | return 0; | 210 | return 0; |
211 | } | 211 | } |
212 | 212 | ||
213 | int snd_pcm_plugin_free(snd_pcm_plugin_t *plugin) | 213 | int snd_pcm_plugin_free(struct snd_pcm_plugin *plugin) |
214 | { | 214 | { |
215 | if (! plugin) | 215 | if (! plugin) |
216 | return 0; | 216 | return 0; |
@@ -224,9 +224,9 @@ int snd_pcm_plugin_free(snd_pcm_plugin_t *plugin) | |||
224 | return 0; | 224 | return 0; |
225 | } | 225 | } |
226 | 226 | ||
227 | snd_pcm_sframes_t snd_pcm_plug_client_size(snd_pcm_plug_t *plug, snd_pcm_uframes_t drv_frames) | 227 | snd_pcm_sframes_t snd_pcm_plug_client_size(struct snd_pcm_substream *plug, snd_pcm_uframes_t drv_frames) |
228 | { | 228 | { |
229 | snd_pcm_plugin_t *plugin, *plugin_prev, *plugin_next; | 229 | struct snd_pcm_plugin *plugin, *plugin_prev, *plugin_next; |
230 | int stream = snd_pcm_plug_stream(plug); | 230 | int stream = snd_pcm_plug_stream(plug); |
231 | 231 | ||
232 | snd_assert(plug != NULL, return -ENXIO); | 232 | snd_assert(plug != NULL, return -ENXIO); |
@@ -253,9 +253,9 @@ snd_pcm_sframes_t snd_pcm_plug_client_size(snd_pcm_plug_t *plug, snd_pcm_uframes | |||
253 | return drv_frames; | 253 | return drv_frames; |
254 | } | 254 | } |
255 | 255 | ||
256 | snd_pcm_sframes_t snd_pcm_plug_slave_size(snd_pcm_plug_t *plug, snd_pcm_uframes_t clt_frames) | 256 | snd_pcm_sframes_t snd_pcm_plug_slave_size(struct snd_pcm_substream *plug, snd_pcm_uframes_t clt_frames) |
257 | { | 257 | { |
258 | snd_pcm_plugin_t *plugin, *plugin_prev, *plugin_next; | 258 | struct snd_pcm_plugin *plugin, *plugin_prev, *plugin_next; |
259 | snd_pcm_sframes_t frames; | 259 | snd_pcm_sframes_t frames; |
260 | int stream = snd_pcm_plug_stream(plug); | 260 | int stream = snd_pcm_plug_stream(plug); |
261 | 261 | ||
@@ -290,9 +290,9 @@ snd_pcm_sframes_t snd_pcm_plug_slave_size(snd_pcm_plug_t *plug, snd_pcm_uframes_ | |||
290 | return frames; | 290 | return frames; |
291 | } | 291 | } |
292 | 292 | ||
293 | static int snd_pcm_plug_formats(snd_mask_t *mask, int format) | 293 | static int snd_pcm_plug_formats(struct snd_mask *mask, int format) |
294 | { | 294 | { |
295 | snd_mask_t formats = *mask; | 295 | struct snd_mask formats = *mask; |
296 | u64 linfmts = (SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S8 | | 296 | u64 linfmts = (SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S8 | |
297 | SNDRV_PCM_FMTBIT_U16_LE | SNDRV_PCM_FMTBIT_S16_LE | | 297 | SNDRV_PCM_FMTBIT_U16_LE | SNDRV_PCM_FMTBIT_S16_LE | |
298 | SNDRV_PCM_FMTBIT_U16_BE | SNDRV_PCM_FMTBIT_S16_BE | | 298 | SNDRV_PCM_FMTBIT_U16_BE | SNDRV_PCM_FMTBIT_S16_BE | |
@@ -326,7 +326,7 @@ static int preferred_formats[] = { | |||
326 | SNDRV_PCM_FORMAT_U8 | 326 | SNDRV_PCM_FORMAT_U8 |
327 | }; | 327 | }; |
328 | 328 | ||
329 | int snd_pcm_plug_slave_format(int format, snd_mask_t *format_mask) | 329 | int snd_pcm_plug_slave_format(int format, struct snd_mask *format_mask) |
330 | { | 330 | { |
331 | if (snd_mask_test(format_mask, format)) | 331 | if (snd_mask_test(format_mask, format)) |
332 | return format; | 332 | return format; |
@@ -376,15 +376,15 @@ int snd_pcm_plug_slave_format(int format, snd_mask_t *format_mask) | |||
376 | } | 376 | } |
377 | } | 377 | } |
378 | 378 | ||
379 | int snd_pcm_plug_format_plugins(snd_pcm_plug_t *plug, | 379 | int snd_pcm_plug_format_plugins(struct snd_pcm_substream *plug, |
380 | snd_pcm_hw_params_t *params, | 380 | struct snd_pcm_hw_params *params, |
381 | snd_pcm_hw_params_t *slave_params) | 381 | struct snd_pcm_hw_params *slave_params) |
382 | { | 382 | { |
383 | snd_pcm_plugin_format_t tmpformat; | 383 | struct snd_pcm_plugin_format tmpformat; |
384 | snd_pcm_plugin_format_t dstformat; | 384 | struct snd_pcm_plugin_format dstformat; |
385 | snd_pcm_plugin_format_t srcformat; | 385 | struct snd_pcm_plugin_format srcformat; |
386 | int src_access, dst_access; | 386 | int src_access, dst_access; |
387 | snd_pcm_plugin_t *plugin = NULL; | 387 | struct snd_pcm_plugin *plugin = NULL; |
388 | int err; | 388 | int err; |
389 | int stream = snd_pcm_plug_stream(plug); | 389 | int stream = snd_pcm_plug_stream(plug); |
390 | int slave_interleaved = (params_channels(slave_params) == 1 || | 390 | int slave_interleaved = (params_channels(slave_params) == 1 || |
@@ -462,7 +462,7 @@ int snd_pcm_plug_format_plugins(snd_pcm_plug_t *plug, | |||
462 | if (srcformat.channels > dstformat.channels) { | 462 | if (srcformat.channels > dstformat.channels) { |
463 | int sv = srcformat.channels; | 463 | int sv = srcformat.channels; |
464 | int dv = dstformat.channels; | 464 | int dv = dstformat.channels; |
465 | route_ttable_entry_t *ttable = kcalloc(dv * sv, sizeof(*ttable), GFP_KERNEL); | 465 | int *ttable = kcalloc(dv * sv, sizeof(*ttable), GFP_KERNEL); |
466 | if (ttable == NULL) | 466 | if (ttable == NULL) |
467 | return -ENOMEM; | 467 | return -ENOMEM; |
468 | #if 1 | 468 | #if 1 |
@@ -525,7 +525,7 @@ int snd_pcm_plug_format_plugins(snd_pcm_plug_t *plug, | |||
525 | if (srcformat.channels < dstformat.channels) { | 525 | if (srcformat.channels < dstformat.channels) { |
526 | int sv = srcformat.channels; | 526 | int sv = srcformat.channels; |
527 | int dv = dstformat.channels; | 527 | int dv = dstformat.channels; |
528 | route_ttable_entry_t *ttable = kcalloc(dv * sv, sizeof(*ttable), GFP_KERNEL); | 528 | int *ttable = kcalloc(dv * sv, sizeof(*ttable), GFP_KERNEL); |
529 | if (ttable == NULL) | 529 | if (ttable == NULL) |
530 | return -ENOMEM; | 530 | return -ENOMEM; |
531 | #if 0 | 531 | #if 0 |
@@ -614,14 +614,14 @@ int snd_pcm_plug_format_plugins(snd_pcm_plug_t *plug, | |||
614 | return 0; | 614 | return 0; |
615 | } | 615 | } |
616 | 616 | ||
617 | snd_pcm_sframes_t snd_pcm_plug_client_channels_buf(snd_pcm_plug_t *plug, | 617 | snd_pcm_sframes_t snd_pcm_plug_client_channels_buf(struct snd_pcm_substream *plug, |
618 | char *buf, | 618 | char *buf, |
619 | snd_pcm_uframes_t count, | 619 | snd_pcm_uframes_t count, |
620 | snd_pcm_plugin_channel_t **channels) | 620 | struct snd_pcm_plugin_channel **channels) |
621 | { | 621 | { |
622 | snd_pcm_plugin_t *plugin; | 622 | struct snd_pcm_plugin *plugin; |
623 | snd_pcm_plugin_channel_t *v; | 623 | struct snd_pcm_plugin_channel *v; |
624 | snd_pcm_plugin_format_t *format; | 624 | struct snd_pcm_plugin_format *format; |
625 | int width, nchannels, channel; | 625 | int width, nchannels, channel; |
626 | int stream = snd_pcm_plug_stream(plug); | 626 | int stream = snd_pcm_plug_stream(plug); |
627 | 627 | ||
@@ -650,10 +650,10 @@ snd_pcm_sframes_t snd_pcm_plug_client_channels_buf(snd_pcm_plug_t *plug, | |||
650 | return count; | 650 | return count; |
651 | } | 651 | } |
652 | 652 | ||
653 | static int snd_pcm_plug_playback_channels_mask(snd_pcm_plug_t *plug, | 653 | static int snd_pcm_plug_playback_channels_mask(struct snd_pcm_substream *plug, |
654 | unsigned long *client_vmask) | 654 | unsigned long *client_vmask) |
655 | { | 655 | { |
656 | snd_pcm_plugin_t *plugin = snd_pcm_plug_last(plug); | 656 | struct snd_pcm_plugin *plugin = snd_pcm_plug_last(plug); |
657 | if (plugin == NULL) { | 657 | if (plugin == NULL) { |
658 | return 0; | 658 | return 0; |
659 | } else { | 659 | } else { |
@@ -678,10 +678,10 @@ static int snd_pcm_plug_playback_channels_mask(snd_pcm_plug_t *plug, | |||
678 | } | 678 | } |
679 | } | 679 | } |
680 | 680 | ||
681 | static int snd_pcm_plug_playback_disable_useless_channels(snd_pcm_plug_t *plug, | 681 | static int snd_pcm_plug_playback_disable_useless_channels(struct snd_pcm_substream *plug, |
682 | snd_pcm_plugin_channel_t *src_channels) | 682 | struct snd_pcm_plugin_channel *src_channels) |
683 | { | 683 | { |
684 | snd_pcm_plugin_t *plugin = snd_pcm_plug_first(plug); | 684 | struct snd_pcm_plugin *plugin = snd_pcm_plug_first(plug); |
685 | unsigned int nchannels = plugin->src_format.channels; | 685 | unsigned int nchannels = plugin->src_format.channels; |
686 | DECLARE_BITMAP(bs, nchannels); | 686 | DECLARE_BITMAP(bs, nchannels); |
687 | unsigned long *srcmask = bs; | 687 | unsigned long *srcmask = bs; |
@@ -703,11 +703,11 @@ static int snd_pcm_plug_playback_disable_useless_channels(snd_pcm_plug_t *plug, | |||
703 | return 0; | 703 | return 0; |
704 | } | 704 | } |
705 | 705 | ||
706 | static int snd_pcm_plug_capture_disable_useless_channels(snd_pcm_plug_t *plug, | 706 | static int snd_pcm_plug_capture_disable_useless_channels(struct snd_pcm_substream *plug, |
707 | snd_pcm_plugin_channel_t *src_channels, | 707 | struct snd_pcm_plugin_channel *src_channels, |
708 | snd_pcm_plugin_channel_t *client_channels) | 708 | struct snd_pcm_plugin_channel *client_channels) |
709 | { | 709 | { |
710 | snd_pcm_plugin_t *plugin = snd_pcm_plug_last(plug); | 710 | struct snd_pcm_plugin *plugin = snd_pcm_plug_last(plug); |
711 | unsigned int nchannels = plugin->dst_format.channels; | 711 | unsigned int nchannels = plugin->dst_format.channels; |
712 | DECLARE_BITMAP(bs, nchannels); | 712 | DECLARE_BITMAP(bs, nchannels); |
713 | unsigned long *dstmask = bs; | 713 | unsigned long *dstmask = bs; |
@@ -736,10 +736,10 @@ static int snd_pcm_plug_capture_disable_useless_channels(snd_pcm_plug_t *plug, | |||
736 | return 0; | 736 | return 0; |
737 | } | 737 | } |
738 | 738 | ||
739 | snd_pcm_sframes_t snd_pcm_plug_write_transfer(snd_pcm_plug_t *plug, snd_pcm_plugin_channel_t *src_channels, snd_pcm_uframes_t size) | 739 | snd_pcm_sframes_t snd_pcm_plug_write_transfer(struct snd_pcm_substream *plug, struct snd_pcm_plugin_channel *src_channels, snd_pcm_uframes_t size) |
740 | { | 740 | { |
741 | snd_pcm_plugin_t *plugin, *next; | 741 | struct snd_pcm_plugin *plugin, *next; |
742 | snd_pcm_plugin_channel_t *dst_channels; | 742 | struct snd_pcm_plugin_channel *dst_channels; |
743 | int err; | 743 | int err; |
744 | snd_pcm_sframes_t frames = size; | 744 | snd_pcm_sframes_t frames = size; |
745 | 745 | ||
@@ -771,10 +771,10 @@ snd_pcm_sframes_t snd_pcm_plug_write_transfer(snd_pcm_plug_t *plug, snd_pcm_plug | |||
771 | return snd_pcm_plug_client_size(plug, frames); | 771 | return snd_pcm_plug_client_size(plug, frames); |
772 | } | 772 | } |
773 | 773 | ||
774 | snd_pcm_sframes_t snd_pcm_plug_read_transfer(snd_pcm_plug_t *plug, snd_pcm_plugin_channel_t *dst_channels_final, snd_pcm_uframes_t size) | 774 | snd_pcm_sframes_t snd_pcm_plug_read_transfer(struct snd_pcm_substream *plug, struct snd_pcm_plugin_channel *dst_channels_final, snd_pcm_uframes_t size) |
775 | { | 775 | { |
776 | snd_pcm_plugin_t *plugin, *next; | 776 | struct snd_pcm_plugin *plugin, *next; |
777 | snd_pcm_plugin_channel_t *src_channels, *dst_channels; | 777 | struct snd_pcm_plugin_channel *src_channels, *dst_channels; |
778 | snd_pcm_sframes_t frames = size; | 778 | snd_pcm_sframes_t frames = size; |
779 | int err; | 779 | int err; |
780 | 780 | ||
@@ -806,7 +806,7 @@ snd_pcm_sframes_t snd_pcm_plug_read_transfer(snd_pcm_plug_t *plug, snd_pcm_plugi | |||
806 | return frames; | 806 | return frames; |
807 | } | 807 | } |
808 | 808 | ||
809 | int snd_pcm_area_silence(const snd_pcm_channel_area_t *dst_area, size_t dst_offset, | 809 | int snd_pcm_area_silence(const struct snd_pcm_channel_area *dst_area, size_t dst_offset, |
810 | size_t samples, int format) | 810 | size_t samples, int format) |
811 | { | 811 | { |
812 | /* FIXME: sub byte resolution and odd dst_offset */ | 812 | /* FIXME: sub byte resolution and odd dst_offset */ |
@@ -852,8 +852,8 @@ int snd_pcm_area_silence(const snd_pcm_channel_area_t *dst_area, size_t dst_offs | |||
852 | return 0; | 852 | return 0; |
853 | } | 853 | } |
854 | 854 | ||
855 | int snd_pcm_area_copy(const snd_pcm_channel_area_t *src_area, size_t src_offset, | 855 | int snd_pcm_area_copy(const struct snd_pcm_channel_area *src_area, size_t src_offset, |
856 | const snd_pcm_channel_area_t *dst_area, size_t dst_offset, | 856 | const struct snd_pcm_channel_area *dst_area, size_t dst_offset, |
857 | size_t samples, int format) | 857 | size_t samples, int format) |
858 | { | 858 | { |
859 | /* FIXME: sub byte resolution and odd dst_offset */ | 859 | /* FIXME: sub byte resolution and odd dst_offset */ |
diff --git a/sound/core/oss/pcm_plugin.h b/sound/core/oss/pcm_plugin.h index 69a43172142c..29198da615cd 100644 --- a/sound/core/oss/pcm_plugin.h +++ b/sound/core/oss/pcm_plugin.h | |||
@@ -29,147 +29,157 @@ static inline unsigned long *bitmap_alloc(unsigned int nbits) | |||
29 | return kmalloc(BITS_TO_LONGS(nbits), GFP_KERNEL); | 29 | return kmalloc(BITS_TO_LONGS(nbits), GFP_KERNEL); |
30 | } | 30 | } |
31 | 31 | ||
32 | #define snd_pcm_plug_t snd_pcm_substream_t | ||
33 | #define snd_pcm_plug_stream(plug) ((plug)->stream) | 32 | #define snd_pcm_plug_stream(plug) ((plug)->stream) |
34 | 33 | ||
35 | typedef enum { | 34 | enum snd_pcm_plugin_action { |
36 | INIT = 0, | 35 | INIT = 0, |
37 | PREPARE = 1, | 36 | PREPARE = 1, |
38 | } snd_pcm_plugin_action_t; | 37 | }; |
39 | 38 | ||
40 | typedef struct _snd_pcm_channel_area { | 39 | struct snd_pcm_channel_area { |
41 | void *addr; /* base address of channel samples */ | 40 | void *addr; /* base address of channel samples */ |
42 | unsigned int first; /* offset to first sample in bits */ | 41 | unsigned int first; /* offset to first sample in bits */ |
43 | unsigned int step; /* samples distance in bits */ | 42 | unsigned int step; /* samples distance in bits */ |
44 | } snd_pcm_channel_area_t; | 43 | }; |
45 | 44 | ||
46 | typedef struct _snd_pcm_plugin_channel { | 45 | struct snd_pcm_plugin_channel { |
47 | void *aptr; /* pointer to the allocated area */ | 46 | void *aptr; /* pointer to the allocated area */ |
48 | snd_pcm_channel_area_t area; | 47 | struct snd_pcm_channel_area area; |
49 | snd_pcm_uframes_t frames; /* allocated frames */ | 48 | snd_pcm_uframes_t frames; /* allocated frames */ |
50 | unsigned int enabled:1; /* channel need to be processed */ | 49 | unsigned int enabled:1; /* channel need to be processed */ |
51 | unsigned int wanted:1; /* channel is wanted */ | 50 | unsigned int wanted:1; /* channel is wanted */ |
52 | } snd_pcm_plugin_channel_t; | 51 | }; |
53 | 52 | ||
54 | typedef struct _snd_pcm_plugin_format { | 53 | struct snd_pcm_plugin_format { |
55 | int format; | 54 | int format; |
56 | unsigned int rate; | 55 | unsigned int rate; |
57 | unsigned int channels; | 56 | unsigned int channels; |
58 | } snd_pcm_plugin_format_t; | 57 | }; |
59 | 58 | ||
60 | struct _snd_pcm_plugin { | 59 | struct snd_pcm_plugin { |
61 | const char *name; /* plug-in name */ | 60 | const char *name; /* plug-in name */ |
62 | int stream; | 61 | int stream; |
63 | snd_pcm_plugin_format_t src_format; /* source format */ | 62 | struct snd_pcm_plugin_format src_format; /* source format */ |
64 | snd_pcm_plugin_format_t dst_format; /* destination format */ | 63 | struct snd_pcm_plugin_format dst_format; /* destination format */ |
65 | int src_width; /* sample width in bits */ | 64 | int src_width; /* sample width in bits */ |
66 | int dst_width; /* sample width in bits */ | 65 | int dst_width; /* sample width in bits */ |
67 | int access; | 66 | int access; |
68 | snd_pcm_sframes_t (*src_frames)(snd_pcm_plugin_t *plugin, snd_pcm_uframes_t dst_frames); | 67 | snd_pcm_sframes_t (*src_frames)(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t dst_frames); |
69 | snd_pcm_sframes_t (*dst_frames)(snd_pcm_plugin_t *plugin, snd_pcm_uframes_t src_frames); | 68 | snd_pcm_sframes_t (*dst_frames)(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t src_frames); |
70 | snd_pcm_sframes_t (*client_channels)(snd_pcm_plugin_t *plugin, | 69 | snd_pcm_sframes_t (*client_channels)(struct snd_pcm_plugin *plugin, |
71 | snd_pcm_uframes_t frames, | 70 | snd_pcm_uframes_t frames, |
72 | snd_pcm_plugin_channel_t **channels); | 71 | struct snd_pcm_plugin_channel **channels); |
73 | int (*src_channels_mask)(snd_pcm_plugin_t *plugin, | 72 | int (*src_channels_mask)(struct snd_pcm_plugin *plugin, |
74 | unsigned long *dst_vmask, | 73 | unsigned long *dst_vmask, |
75 | unsigned long **src_vmask); | 74 | unsigned long **src_vmask); |
76 | int (*dst_channels_mask)(snd_pcm_plugin_t *plugin, | 75 | int (*dst_channels_mask)(struct snd_pcm_plugin *plugin, |
77 | unsigned long *src_vmask, | 76 | unsigned long *src_vmask, |
78 | unsigned long **dst_vmask); | 77 | unsigned long **dst_vmask); |
79 | snd_pcm_sframes_t (*transfer)(snd_pcm_plugin_t *plugin, | 78 | snd_pcm_sframes_t (*transfer)(struct snd_pcm_plugin *plugin, |
80 | const snd_pcm_plugin_channel_t *src_channels, | 79 | const struct snd_pcm_plugin_channel *src_channels, |
81 | snd_pcm_plugin_channel_t *dst_channels, | 80 | struct snd_pcm_plugin_channel *dst_channels, |
82 | snd_pcm_uframes_t frames); | 81 | snd_pcm_uframes_t frames); |
83 | int (*action)(snd_pcm_plugin_t *plugin, | 82 | int (*action)(struct snd_pcm_plugin *plugin, |
84 | snd_pcm_plugin_action_t action, | 83 | enum snd_pcm_plugin_action action, |
85 | unsigned long data); | 84 | unsigned long data); |
86 | snd_pcm_plugin_t *prev; | 85 | struct snd_pcm_plugin *prev; |
87 | snd_pcm_plugin_t *next; | 86 | struct snd_pcm_plugin *next; |
88 | snd_pcm_plug_t *plug; | 87 | struct snd_pcm_substream *plug; |
89 | void *private_data; | 88 | void *private_data; |
90 | void (*private_free)(snd_pcm_plugin_t *plugin); | 89 | void (*private_free)(struct snd_pcm_plugin *plugin); |
91 | char *buf; | 90 | char *buf; |
92 | snd_pcm_uframes_t buf_frames; | 91 | snd_pcm_uframes_t buf_frames; |
93 | snd_pcm_plugin_channel_t *buf_channels; | 92 | struct snd_pcm_plugin_channel *buf_channels; |
94 | unsigned long *src_vmask; | 93 | unsigned long *src_vmask; |
95 | unsigned long *dst_vmask; | 94 | unsigned long *dst_vmask; |
96 | char extra_data[0]; | 95 | char extra_data[0]; |
97 | }; | 96 | }; |
98 | 97 | ||
99 | int snd_pcm_plugin_build(snd_pcm_plug_t *handle, | 98 | int snd_pcm_plugin_build(struct snd_pcm_substream *handle, |
100 | const char *name, | 99 | const char *name, |
101 | snd_pcm_plugin_format_t *src_format, | 100 | struct snd_pcm_plugin_format *src_format, |
102 | snd_pcm_plugin_format_t *dst_format, | 101 | struct snd_pcm_plugin_format *dst_format, |
103 | size_t extra, | 102 | size_t extra, |
104 | snd_pcm_plugin_t **ret); | 103 | struct snd_pcm_plugin **ret); |
105 | int snd_pcm_plugin_free(snd_pcm_plugin_t *plugin); | 104 | int snd_pcm_plugin_free(struct snd_pcm_plugin *plugin); |
106 | int snd_pcm_plugin_clear(snd_pcm_plugin_t **first); | 105 | int snd_pcm_plugin_clear(struct snd_pcm_plugin **first); |
107 | int snd_pcm_plug_alloc(snd_pcm_plug_t *plug, snd_pcm_uframes_t frames); | 106 | int snd_pcm_plug_alloc(struct snd_pcm_substream *plug, snd_pcm_uframes_t frames); |
108 | snd_pcm_sframes_t snd_pcm_plug_client_size(snd_pcm_plug_t *handle, snd_pcm_uframes_t drv_size); | 107 | snd_pcm_sframes_t snd_pcm_plug_client_size(struct snd_pcm_substream *handle, snd_pcm_uframes_t drv_size); |
109 | snd_pcm_sframes_t snd_pcm_plug_slave_size(snd_pcm_plug_t *handle, snd_pcm_uframes_t clt_size); | 108 | snd_pcm_sframes_t snd_pcm_plug_slave_size(struct snd_pcm_substream *handle, snd_pcm_uframes_t clt_size); |
110 | 109 | ||
111 | #define FULL ROUTE_PLUGIN_RESOLUTION | 110 | #define FULL ROUTE_PLUGIN_RESOLUTION |
112 | #define HALF ROUTE_PLUGIN_RESOLUTION / 2 | 111 | #define HALF ROUTE_PLUGIN_RESOLUTION / 2 |
113 | typedef int route_ttable_entry_t; | 112 | |
114 | 113 | int snd_pcm_plugin_build_io(struct snd_pcm_substream *handle, | |
115 | int snd_pcm_plugin_build_io(snd_pcm_plug_t *handle, | 114 | struct snd_pcm_hw_params *params, |
116 | snd_pcm_hw_params_t *params, | 115 | struct snd_pcm_plugin **r_plugin); |
117 | snd_pcm_plugin_t **r_plugin); | 116 | int snd_pcm_plugin_build_linear(struct snd_pcm_substream *handle, |
118 | int snd_pcm_plugin_build_linear(snd_pcm_plug_t *handle, | 117 | struct snd_pcm_plugin_format *src_format, |
119 | snd_pcm_plugin_format_t *src_format, | 118 | struct snd_pcm_plugin_format *dst_format, |
120 | snd_pcm_plugin_format_t *dst_format, | 119 | struct snd_pcm_plugin **r_plugin); |
121 | snd_pcm_plugin_t **r_plugin); | 120 | int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *handle, |
122 | int snd_pcm_plugin_build_mulaw(snd_pcm_plug_t *handle, | 121 | struct snd_pcm_plugin_format *src_format, |
123 | snd_pcm_plugin_format_t *src_format, | 122 | struct snd_pcm_plugin_format *dst_format, |
124 | snd_pcm_plugin_format_t *dst_format, | 123 | struct snd_pcm_plugin **r_plugin); |
125 | snd_pcm_plugin_t **r_plugin); | 124 | int snd_pcm_plugin_build_rate(struct snd_pcm_substream *handle, |
126 | int snd_pcm_plugin_build_rate(snd_pcm_plug_t *handle, | 125 | struct snd_pcm_plugin_format *src_format, |
127 | snd_pcm_plugin_format_t *src_format, | 126 | struct snd_pcm_plugin_format *dst_format, |
128 | snd_pcm_plugin_format_t *dst_format, | 127 | struct snd_pcm_plugin **r_plugin); |
129 | snd_pcm_plugin_t **r_plugin); | 128 | int snd_pcm_plugin_build_route(struct snd_pcm_substream *handle, |
130 | int snd_pcm_plugin_build_route(snd_pcm_plug_t *handle, | 129 | struct snd_pcm_plugin_format *src_format, |
131 | snd_pcm_plugin_format_t *src_format, | 130 | struct snd_pcm_plugin_format *dst_format, |
132 | snd_pcm_plugin_format_t *dst_format, | 131 | int *ttable, |
133 | route_ttable_entry_t *ttable, | 132 | struct snd_pcm_plugin **r_plugin); |
134 | snd_pcm_plugin_t **r_plugin); | 133 | int snd_pcm_plugin_build_copy(struct snd_pcm_substream *handle, |
135 | int snd_pcm_plugin_build_copy(snd_pcm_plug_t *handle, | 134 | struct snd_pcm_plugin_format *src_format, |
136 | snd_pcm_plugin_format_t *src_format, | 135 | struct snd_pcm_plugin_format *dst_format, |
137 | snd_pcm_plugin_format_t *dst_format, | 136 | struct snd_pcm_plugin **r_plugin); |
138 | snd_pcm_plugin_t **r_plugin); | 137 | |
139 | 138 | int snd_pcm_plug_format_plugins(struct snd_pcm_substream *substream, | |
140 | int snd_pcm_plug_format_plugins(snd_pcm_plug_t *substream, | 139 | struct snd_pcm_hw_params *params, |
141 | snd_pcm_hw_params_t *params, | 140 | struct snd_pcm_hw_params *slave_params); |
142 | snd_pcm_hw_params_t *slave_params); | 141 | |
143 | 142 | int snd_pcm_plug_slave_format(int format, struct snd_mask *format_mask); | |
144 | int snd_pcm_plug_slave_format(int format, snd_mask_t *format_mask); | 143 | |
145 | 144 | int snd_pcm_plugin_append(struct snd_pcm_plugin *plugin); | |
146 | int snd_pcm_plugin_append(snd_pcm_plugin_t *plugin); | 145 | |
147 | 146 | snd_pcm_sframes_t snd_pcm_plug_write_transfer(struct snd_pcm_substream *handle, | |
148 | snd_pcm_sframes_t snd_pcm_plug_write_transfer(snd_pcm_plug_t *handle, snd_pcm_plugin_channel_t *src_channels, snd_pcm_uframes_t size); | 147 | struct snd_pcm_plugin_channel *src_channels, |
149 | snd_pcm_sframes_t snd_pcm_plug_read_transfer(snd_pcm_plug_t *handle, snd_pcm_plugin_channel_t *dst_channels_final, snd_pcm_uframes_t size); | 148 | snd_pcm_uframes_t size); |
150 | 149 | snd_pcm_sframes_t snd_pcm_plug_read_transfer(struct snd_pcm_substream *handle, | |
151 | snd_pcm_sframes_t snd_pcm_plug_client_channels_buf(snd_pcm_plug_t *handle, | 150 | struct snd_pcm_plugin_channel *dst_channels_final, |
152 | char *buf, snd_pcm_uframes_t count, | 151 | snd_pcm_uframes_t size); |
153 | snd_pcm_plugin_channel_t **channels); | 152 | |
154 | 153 | snd_pcm_sframes_t snd_pcm_plug_client_channels_buf(struct snd_pcm_substream *handle, | |
155 | snd_pcm_sframes_t snd_pcm_plugin_client_channels(snd_pcm_plugin_t *plugin, | 154 | char *buf, snd_pcm_uframes_t count, |
156 | snd_pcm_uframes_t frames, | 155 | struct snd_pcm_plugin_channel **channels); |
157 | snd_pcm_plugin_channel_t **channels); | 156 | |
158 | 157 | snd_pcm_sframes_t snd_pcm_plugin_client_channels(struct snd_pcm_plugin *plugin, | |
159 | int snd_pcm_area_silence(const snd_pcm_channel_area_t *dst_channel, size_t dst_offset, | 158 | snd_pcm_uframes_t frames, |
159 | struct snd_pcm_plugin_channel **channels); | ||
160 | |||
161 | int snd_pcm_area_silence(const struct snd_pcm_channel_area *dst_channel, | ||
162 | size_t dst_offset, | ||
160 | size_t samples, int format); | 163 | size_t samples, int format); |
161 | int snd_pcm_area_copy(const snd_pcm_channel_area_t *src_channel, size_t src_offset, | 164 | int snd_pcm_area_copy(const struct snd_pcm_channel_area *src_channel, |
162 | const snd_pcm_channel_area_t *dst_channel, size_t dst_offset, | 165 | size_t src_offset, |
166 | const struct snd_pcm_channel_area *dst_channel, | ||
167 | size_t dst_offset, | ||
163 | size_t samples, int format); | 168 | size_t samples, int format); |
164 | 169 | ||
165 | void *snd_pcm_plug_buf_alloc(snd_pcm_plug_t *plug, snd_pcm_uframes_t size); | 170 | void *snd_pcm_plug_buf_alloc(struct snd_pcm_substream *plug, snd_pcm_uframes_t size); |
166 | void snd_pcm_plug_buf_unlock(snd_pcm_plug_t *plug, void *ptr); | 171 | void snd_pcm_plug_buf_unlock(struct snd_pcm_substream *plug, void *ptr); |
167 | snd_pcm_sframes_t snd_pcm_oss_write3(snd_pcm_substream_t *substream, const char *ptr, snd_pcm_uframes_t size, int in_kernel); | 172 | snd_pcm_sframes_t snd_pcm_oss_write3(struct snd_pcm_substream *substream, |
168 | snd_pcm_sframes_t snd_pcm_oss_read3(snd_pcm_substream_t *substream, char *ptr, snd_pcm_uframes_t size, int in_kernel); | 173 | const char *ptr, snd_pcm_uframes_t size, |
169 | snd_pcm_sframes_t snd_pcm_oss_writev3(snd_pcm_substream_t *substream, void **bufs, snd_pcm_uframes_t frames, int in_kernel); | 174 | int in_kernel); |
170 | snd_pcm_sframes_t snd_pcm_oss_readv3(snd_pcm_substream_t *substream, void **bufs, snd_pcm_uframes_t frames, int in_kernel); | 175 | snd_pcm_sframes_t snd_pcm_oss_read3(struct snd_pcm_substream *substream, |
171 | 176 | char *ptr, snd_pcm_uframes_t size, int in_kernel); | |
172 | 177 | snd_pcm_sframes_t snd_pcm_oss_writev3(struct snd_pcm_substream *substream, | |
178 | void **bufs, snd_pcm_uframes_t frames, | ||
179 | int in_kernel); | ||
180 | snd_pcm_sframes_t snd_pcm_oss_readv3(struct snd_pcm_substream *substream, | ||
181 | void **bufs, snd_pcm_uframes_t frames, | ||
182 | int in_kernel); | ||
173 | 183 | ||
174 | #define ROUTE_PLUGIN_RESOLUTION 16 | 184 | #define ROUTE_PLUGIN_RESOLUTION 16 |
175 | 185 | ||
@@ -177,8 +187,8 @@ int getput_index(int format); | |||
177 | int copy_index(int format); | 187 | int copy_index(int format); |
178 | int conv_index(int src_format, int dst_format); | 188 | int conv_index(int src_format, int dst_format); |
179 | 189 | ||
180 | void zero_channel(snd_pcm_plugin_t *plugin, | 190 | void zero_channel(struct snd_pcm_plugin *plugin, |
181 | const snd_pcm_plugin_channel_t *dst_channel, | 191 | const struct snd_pcm_plugin_channel *dst_channel, |
182 | size_t samples); | 192 | size_t samples); |
183 | 193 | ||
184 | #ifdef PLUGIN_DEBUG | 194 | #ifdef PLUGIN_DEBUG |
diff --git a/sound/core/oss/rate.c b/sound/core/oss/rate.c index 7e325ca58706..4854cef6fb4f 100644 --- a/sound/core/oss/rate.c +++ b/sound/core/oss/rate.c | |||
@@ -33,29 +33,29 @@ | |||
33 | * Basic rate conversion plugin | 33 | * Basic rate conversion plugin |
34 | */ | 34 | */ |
35 | 35 | ||
36 | typedef struct { | 36 | struct rate_channel { |
37 | signed short last_S1; | 37 | signed short last_S1; |
38 | signed short last_S2; | 38 | signed short last_S2; |
39 | } rate_channel_t; | 39 | }; |
40 | 40 | ||
41 | typedef void (*rate_f)(snd_pcm_plugin_t *plugin, | 41 | typedef void (*rate_f)(struct snd_pcm_plugin *plugin, |
42 | const snd_pcm_plugin_channel_t *src_channels, | 42 | const struct snd_pcm_plugin_channel *src_channels, |
43 | snd_pcm_plugin_channel_t *dst_channels, | 43 | struct snd_pcm_plugin_channel *dst_channels, |
44 | int src_frames, int dst_frames); | 44 | int src_frames, int dst_frames); |
45 | 45 | ||
46 | typedef struct rate_private_data { | 46 | struct rate_priv { |
47 | unsigned int pitch; | 47 | unsigned int pitch; |
48 | unsigned int pos; | 48 | unsigned int pos; |
49 | rate_f func; | 49 | rate_f func; |
50 | int get, put; | 50 | int get, put; |
51 | snd_pcm_sframes_t old_src_frames, old_dst_frames; | 51 | snd_pcm_sframes_t old_src_frames, old_dst_frames; |
52 | rate_channel_t channels[0]; | 52 | struct rate_channel channels[0]; |
53 | } rate_t; | 53 | }; |
54 | 54 | ||
55 | static void rate_init(snd_pcm_plugin_t *plugin) | 55 | static void rate_init(struct snd_pcm_plugin *plugin) |
56 | { | 56 | { |
57 | unsigned int channel; | 57 | unsigned int channel; |
58 | rate_t *data = (rate_t *)plugin->extra_data; | 58 | struct rate_priv *data = (struct rate_priv *)plugin->extra_data; |
59 | data->pos = 0; | 59 | data->pos = 0; |
60 | for (channel = 0; channel < plugin->src_format.channels; channel++) { | 60 | for (channel = 0; channel < plugin->src_format.channels; channel++) { |
61 | data->channels[channel].last_S1 = 0; | 61 | data->channels[channel].last_S1 = 0; |
@@ -63,9 +63,9 @@ static void rate_init(snd_pcm_plugin_t *plugin) | |||
63 | } | 63 | } |
64 | } | 64 | } |
65 | 65 | ||
66 | static void resample_expand(snd_pcm_plugin_t *plugin, | 66 | static void resample_expand(struct snd_pcm_plugin *plugin, |
67 | const snd_pcm_plugin_channel_t *src_channels, | 67 | const struct snd_pcm_plugin_channel *src_channels, |
68 | snd_pcm_plugin_channel_t *dst_channels, | 68 | struct snd_pcm_plugin_channel *dst_channels, |
69 | int src_frames, int dst_frames) | 69 | int src_frames, int dst_frames) |
70 | { | 70 | { |
71 | unsigned int pos = 0; | 71 | unsigned int pos = 0; |
@@ -75,8 +75,8 @@ static void resample_expand(snd_pcm_plugin_t *plugin, | |||
75 | unsigned int channel; | 75 | unsigned int channel; |
76 | int src_step, dst_step; | 76 | int src_step, dst_step; |
77 | int src_frames1, dst_frames1; | 77 | int src_frames1, dst_frames1; |
78 | rate_t *data = (rate_t *)plugin->extra_data; | 78 | struct rate_priv *data = (struct rate_priv *)plugin->extra_data; |
79 | rate_channel_t *rchannels = data->channels; | 79 | struct rate_channel *rchannels = data->channels; |
80 | 80 | ||
81 | #define GET_S16_LABELS | 81 | #define GET_S16_LABELS |
82 | #define PUT_S16_LABELS | 82 | #define PUT_S16_LABELS |
@@ -139,9 +139,9 @@ static void resample_expand(snd_pcm_plugin_t *plugin, | |||
139 | data->pos = pos; | 139 | data->pos = pos; |
140 | } | 140 | } |
141 | 141 | ||
142 | static void resample_shrink(snd_pcm_plugin_t *plugin, | 142 | static void resample_shrink(struct snd_pcm_plugin *plugin, |
143 | const snd_pcm_plugin_channel_t *src_channels, | 143 | const struct snd_pcm_plugin_channel *src_channels, |
144 | snd_pcm_plugin_channel_t *dst_channels, | 144 | struct snd_pcm_plugin_channel *dst_channels, |
145 | int src_frames, int dst_frames) | 145 | int src_frames, int dst_frames) |
146 | { | 146 | { |
147 | unsigned int pos = 0; | 147 | unsigned int pos = 0; |
@@ -151,8 +151,8 @@ static void resample_shrink(snd_pcm_plugin_t *plugin, | |||
151 | unsigned int channel; | 151 | unsigned int channel; |
152 | int src_step, dst_step; | 152 | int src_step, dst_step; |
153 | int src_frames1, dst_frames1; | 153 | int src_frames1, dst_frames1; |
154 | rate_t *data = (rate_t *)plugin->extra_data; | 154 | struct rate_priv *data = (struct rate_priv *)plugin->extra_data; |
155 | rate_channel_t *rchannels = data->channels; | 155 | struct rate_channel *rchannels = data->channels; |
156 | 156 | ||
157 | #define GET_S16_LABELS | 157 | #define GET_S16_LABELS |
158 | #define PUT_S16_LABELS | 158 | #define PUT_S16_LABELS |
@@ -216,15 +216,15 @@ static void resample_shrink(snd_pcm_plugin_t *plugin, | |||
216 | data->pos = pos; | 216 | data->pos = pos; |
217 | } | 217 | } |
218 | 218 | ||
219 | static snd_pcm_sframes_t rate_src_frames(snd_pcm_plugin_t *plugin, snd_pcm_uframes_t frames) | 219 | static snd_pcm_sframes_t rate_src_frames(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t frames) |
220 | { | 220 | { |
221 | rate_t *data; | 221 | struct rate_priv *data; |
222 | snd_pcm_sframes_t res; | 222 | snd_pcm_sframes_t res; |
223 | 223 | ||
224 | snd_assert(plugin != NULL, return -ENXIO); | 224 | snd_assert(plugin != NULL, return -ENXIO); |
225 | if (frames == 0) | 225 | if (frames == 0) |
226 | return 0; | 226 | return 0; |
227 | data = (rate_t *)plugin->extra_data; | 227 | data = (struct rate_priv *)plugin->extra_data; |
228 | if (plugin->src_format.rate < plugin->dst_format.rate) { | 228 | if (plugin->src_format.rate < plugin->dst_format.rate) { |
229 | res = (((frames * data->pitch) + (BITS/2)) >> SHIFT); | 229 | res = (((frames * data->pitch) + (BITS/2)) >> SHIFT); |
230 | } else { | 230 | } else { |
@@ -248,15 +248,15 @@ static snd_pcm_sframes_t rate_src_frames(snd_pcm_plugin_t *plugin, snd_pcm_ufram | |||
248 | return res; | 248 | return res; |
249 | } | 249 | } |
250 | 250 | ||
251 | static snd_pcm_sframes_t rate_dst_frames(snd_pcm_plugin_t *plugin, snd_pcm_uframes_t frames) | 251 | static snd_pcm_sframes_t rate_dst_frames(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t frames) |
252 | { | 252 | { |
253 | rate_t *data; | 253 | struct rate_priv *data; |
254 | snd_pcm_sframes_t res; | 254 | snd_pcm_sframes_t res; |
255 | 255 | ||
256 | snd_assert(plugin != NULL, return -ENXIO); | 256 | snd_assert(plugin != NULL, return -ENXIO); |
257 | if (frames == 0) | 257 | if (frames == 0) |
258 | return 0; | 258 | return 0; |
259 | data = (rate_t *)plugin->extra_data; | 259 | data = (struct rate_priv *)plugin->extra_data; |
260 | if (plugin->src_format.rate < plugin->dst_format.rate) { | 260 | if (plugin->src_format.rate < plugin->dst_format.rate) { |
261 | res = (((frames << SHIFT) + (data->pitch / 2)) / data->pitch); | 261 | res = (((frames << SHIFT) + (data->pitch / 2)) / data->pitch); |
262 | } else { | 262 | } else { |
@@ -280,13 +280,13 @@ static snd_pcm_sframes_t rate_dst_frames(snd_pcm_plugin_t *plugin, snd_pcm_ufram | |||
280 | return res; | 280 | return res; |
281 | } | 281 | } |
282 | 282 | ||
283 | static snd_pcm_sframes_t rate_transfer(snd_pcm_plugin_t *plugin, | 283 | static snd_pcm_sframes_t rate_transfer(struct snd_pcm_plugin *plugin, |
284 | const snd_pcm_plugin_channel_t *src_channels, | 284 | const struct snd_pcm_plugin_channel *src_channels, |
285 | snd_pcm_plugin_channel_t *dst_channels, | 285 | struct snd_pcm_plugin_channel *dst_channels, |
286 | snd_pcm_uframes_t frames) | 286 | snd_pcm_uframes_t frames) |
287 | { | 287 | { |
288 | snd_pcm_uframes_t dst_frames; | 288 | snd_pcm_uframes_t dst_frames; |
289 | rate_t *data; | 289 | struct rate_priv *data; |
290 | 290 | ||
291 | snd_assert(plugin != NULL && src_channels != NULL && dst_channels != NULL, return -ENXIO); | 291 | snd_assert(plugin != NULL && src_channels != NULL && dst_channels != NULL, return -ENXIO); |
292 | if (frames == 0) | 292 | if (frames == 0) |
@@ -308,13 +308,13 @@ static snd_pcm_sframes_t rate_transfer(snd_pcm_plugin_t *plugin, | |||
308 | dst_frames = rate_dst_frames(plugin, frames); | 308 | dst_frames = rate_dst_frames(plugin, frames); |
309 | if (dst_frames > dst_channels[0].frames) | 309 | if (dst_frames > dst_channels[0].frames) |
310 | dst_frames = dst_channels[0].frames; | 310 | dst_frames = dst_channels[0].frames; |
311 | data = (rate_t *)plugin->extra_data; | 311 | data = (struct rate_priv *)plugin->extra_data; |
312 | data->func(plugin, src_channels, dst_channels, frames, dst_frames); | 312 | data->func(plugin, src_channels, dst_channels, frames, dst_frames); |
313 | return dst_frames; | 313 | return dst_frames; |
314 | } | 314 | } |
315 | 315 | ||
316 | static int rate_action(snd_pcm_plugin_t *plugin, | 316 | static int rate_action(struct snd_pcm_plugin *plugin, |
317 | snd_pcm_plugin_action_t action, | 317 | enum snd_pcm_plugin_action action, |
318 | unsigned long udata) | 318 | unsigned long udata) |
319 | { | 319 | { |
320 | snd_assert(plugin != NULL, return -ENXIO); | 320 | snd_assert(plugin != NULL, return -ENXIO); |
@@ -329,14 +329,14 @@ static int rate_action(snd_pcm_plugin_t *plugin, | |||
329 | return 0; /* silenty ignore other actions */ | 329 | return 0; /* silenty ignore other actions */ |
330 | } | 330 | } |
331 | 331 | ||
332 | int snd_pcm_plugin_build_rate(snd_pcm_plug_t *plug, | 332 | int snd_pcm_plugin_build_rate(struct snd_pcm_substream *plug, |
333 | snd_pcm_plugin_format_t *src_format, | 333 | struct snd_pcm_plugin_format *src_format, |
334 | snd_pcm_plugin_format_t *dst_format, | 334 | struct snd_pcm_plugin_format *dst_format, |
335 | snd_pcm_plugin_t **r_plugin) | 335 | struct snd_pcm_plugin **r_plugin) |
336 | { | 336 | { |
337 | int err; | 337 | int err; |
338 | rate_t *data; | 338 | struct rate_priv *data; |
339 | snd_pcm_plugin_t *plugin; | 339 | struct snd_pcm_plugin *plugin; |
340 | 340 | ||
341 | snd_assert(r_plugin != NULL, return -ENXIO); | 341 | snd_assert(r_plugin != NULL, return -ENXIO); |
342 | *r_plugin = NULL; | 342 | *r_plugin = NULL; |
@@ -349,11 +349,12 @@ int snd_pcm_plugin_build_rate(snd_pcm_plug_t *plug, | |||
349 | 349 | ||
350 | err = snd_pcm_plugin_build(plug, "rate conversion", | 350 | err = snd_pcm_plugin_build(plug, "rate conversion", |
351 | src_format, dst_format, | 351 | src_format, dst_format, |
352 | sizeof(rate_t) + src_format->channels * sizeof(rate_channel_t), | 352 | sizeof(struct rate_priv) + |
353 | src_format->channels * sizeof(struct rate_channel), | ||
353 | &plugin); | 354 | &plugin); |
354 | if (err < 0) | 355 | if (err < 0) |
355 | return err; | 356 | return err; |
356 | data = (rate_t *)plugin->extra_data; | 357 | data = (struct rate_priv *)plugin->extra_data; |
357 | data->get = getput_index(src_format->format); | 358 | data->get = getput_index(src_format->format); |
358 | snd_assert(data->get >= 0 && data->get < 4*2*2, return -EINVAL); | 359 | snd_assert(data->get >= 0 && data->get < 4*2*2, return -EINVAL); |
359 | data->put = getput_index(dst_format->format); | 360 | data->put = getput_index(dst_format->format); |
diff --git a/sound/core/oss/route.c b/sound/core/oss/route.c index 7519aed757cd..726c5caa3fdb 100644 --- a/sound/core/oss/route.c +++ b/sound/core/oss/route.c | |||
@@ -35,61 +35,62 @@ | |||
35 | #error "Add some code here" | 35 | #error "Add some code here" |
36 | #endif | 36 | #endif |
37 | 37 | ||
38 | typedef struct ttable_dst ttable_dst_t; | 38 | struct ttable_dst; |
39 | typedef struct route_private_data route_t; | ||
40 | 39 | ||
41 | typedef void (*route_channel_f)(snd_pcm_plugin_t *plugin, | 40 | typedef void (*route_channel_f)(struct snd_pcm_plugin *plugin, |
42 | const snd_pcm_plugin_channel_t *src_channels, | 41 | const struct snd_pcm_plugin_channel *src_channels, |
43 | snd_pcm_plugin_channel_t *dst_channel, | 42 | struct snd_pcm_plugin_channel *dst_channel, |
44 | ttable_dst_t* ttable, snd_pcm_uframes_t frames); | 43 | struct ttable_dst *ttable, snd_pcm_uframes_t frames); |
45 | 44 | ||
46 | typedef struct { | 45 | struct ttable_src { |
47 | int channel; | 46 | int channel; |
48 | int as_int; | 47 | int as_int; |
49 | } ttable_src_t; | 48 | }; |
50 | 49 | ||
51 | struct ttable_dst { | 50 | struct ttable_dst { |
52 | int att; /* Attenuated */ | 51 | int att; /* Attenuated */ |
53 | unsigned int nsrcs; | 52 | unsigned int nsrcs; |
54 | ttable_src_t* srcs; | 53 | struct ttable_src *srcs; |
55 | route_channel_f func; | 54 | route_channel_f func; |
56 | }; | 55 | }; |
57 | 56 | ||
58 | struct route_private_data { | 57 | struct route_priv { |
59 | enum {R_UINT32=0, R_UINT64=1} sum_type; | 58 | enum {R_UINT32=0, R_UINT64=1} sum_type; |
60 | int get, put; | 59 | int get, put; |
61 | int conv; | 60 | int conv; |
62 | int src_sample_size; | 61 | int src_sample_size; |
63 | ttable_dst_t ttable[0]; | 62 | struct ttable_dst ttable[0]; |
64 | }; | 63 | }; |
65 | 64 | ||
66 | typedef union { | 65 | union sum { |
67 | u_int32_t as_uint32; | 66 | u_int32_t as_uint32; |
68 | u_int64_t as_uint64; | 67 | u_int64_t as_uint64; |
69 | } sum_t; | 68 | }; |
70 | 69 | ||
71 | 70 | ||
72 | static void route_to_channel_from_zero(snd_pcm_plugin_t *plugin, | 71 | static void route_to_channel_from_zero(struct snd_pcm_plugin *plugin, |
73 | const snd_pcm_plugin_channel_t *src_channels, | 72 | const struct snd_pcm_plugin_channel *src_channels, |
74 | snd_pcm_plugin_channel_t *dst_channel, | 73 | struct snd_pcm_plugin_channel *dst_channel, |
75 | ttable_dst_t* ttable, snd_pcm_uframes_t frames) | 74 | struct ttable_dst *ttable, |
75 | snd_pcm_uframes_t frames) | ||
76 | { | 76 | { |
77 | if (dst_channel->wanted) | 77 | if (dst_channel->wanted) |
78 | snd_pcm_area_silence(&dst_channel->area, 0, frames, plugin->dst_format.format); | 78 | snd_pcm_area_silence(&dst_channel->area, 0, frames, plugin->dst_format.format); |
79 | dst_channel->enabled = 0; | 79 | dst_channel->enabled = 0; |
80 | } | 80 | } |
81 | 81 | ||
82 | static void route_to_channel_from_one(snd_pcm_plugin_t *plugin, | 82 | static void route_to_channel_from_one(struct snd_pcm_plugin *plugin, |
83 | const snd_pcm_plugin_channel_t *src_channels, | 83 | const struct snd_pcm_plugin_channel *src_channels, |
84 | snd_pcm_plugin_channel_t *dst_channel, | 84 | struct snd_pcm_plugin_channel *dst_channel, |
85 | ttable_dst_t* ttable, snd_pcm_uframes_t frames) | 85 | struct ttable_dst *ttable, |
86 | snd_pcm_uframes_t frames) | ||
86 | { | 87 | { |
87 | #define CONV_LABELS | 88 | #define CONV_LABELS |
88 | #include "plugin_ops.h" | 89 | #include "plugin_ops.h" |
89 | #undef CONV_LABELS | 90 | #undef CONV_LABELS |
90 | route_t *data = (route_t *)plugin->extra_data; | 91 | struct route_priv *data = (struct route_priv *)plugin->extra_data; |
91 | void *conv; | 92 | void *conv; |
92 | const snd_pcm_plugin_channel_t *src_channel = NULL; | 93 | const struct snd_pcm_plugin_channel *src_channel = NULL; |
93 | unsigned int srcidx; | 94 | unsigned int srcidx; |
94 | char *src, *dst; | 95 | char *src, *dst; |
95 | int src_step, dst_step; | 96 | int src_step, dst_step; |
@@ -120,10 +121,10 @@ static void route_to_channel_from_one(snd_pcm_plugin_t *plugin, | |||
120 | } | 121 | } |
121 | } | 122 | } |
122 | 123 | ||
123 | static void route_to_channel(snd_pcm_plugin_t *plugin, | 124 | static void route_to_channel(struct snd_pcm_plugin *plugin, |
124 | const snd_pcm_plugin_channel_t *src_channels, | 125 | const struct snd_pcm_plugin_channel *src_channels, |
125 | snd_pcm_plugin_channel_t *dst_channel, | 126 | struct snd_pcm_plugin_channel *dst_channel, |
126 | ttable_dst_t* ttable, snd_pcm_uframes_t frames) | 127 | struct ttable_dst *ttable, snd_pcm_uframes_t frames) |
127 | { | 128 | { |
128 | #define GET_U_LABELS | 129 | #define GET_U_LABELS |
129 | #define PUT_U32_LABELS | 130 | #define PUT_U32_LABELS |
@@ -153,18 +154,18 @@ static void route_to_channel(snd_pcm_plugin_t *plugin, | |||
153 | &&norm_int64_16_att, | 154 | &&norm_int64_16_att, |
154 | &&norm_int64_24_att, | 155 | &&norm_int64_24_att, |
155 | }; | 156 | }; |
156 | route_t *data = (route_t *)plugin->extra_data; | 157 | struct route_priv *data = (struct route_priv *)plugin->extra_data; |
157 | void *zero, *get, *add, *norm, *put_u32; | 158 | void *zero, *get, *add, *norm, *put_u32; |
158 | int nsrcs = ttable->nsrcs; | 159 | int nsrcs = ttable->nsrcs; |
159 | char *dst; | 160 | char *dst; |
160 | int dst_step; | 161 | int dst_step; |
161 | char *srcs[nsrcs]; | 162 | char *srcs[nsrcs]; |
162 | int src_steps[nsrcs]; | 163 | int src_steps[nsrcs]; |
163 | ttable_src_t src_tt[nsrcs]; | 164 | struct ttable_src src_tt[nsrcs]; |
164 | u_int32_t sample = 0; | 165 | u_int32_t sample = 0; |
165 | int srcidx, srcidx1 = 0; | 166 | int srcidx, srcidx1 = 0; |
166 | for (srcidx = 0; srcidx < nsrcs; ++srcidx) { | 167 | for (srcidx = 0; srcidx < nsrcs; ++srcidx) { |
167 | const snd_pcm_plugin_channel_t *src_channel = &src_channels[ttable->srcs[srcidx].channel]; | 168 | const struct snd_pcm_plugin_channel *src_channel = &src_channels[ttable->srcs[srcidx].channel]; |
168 | if (!src_channel->enabled) | 169 | if (!src_channel->enabled) |
169 | continue; | 170 | continue; |
170 | srcs[srcidx1] = src_channel->area.addr + src_channel->area.first / 8; | 171 | srcs[srcidx1] = src_channel->area.addr + src_channel->area.first / 8; |
@@ -191,8 +192,8 @@ static void route_to_channel(snd_pcm_plugin_t *plugin, | |||
191 | dst_step = dst_channel->area.step / 8; | 192 | dst_step = dst_channel->area.step / 8; |
192 | 193 | ||
193 | while (frames-- > 0) { | 194 | while (frames-- > 0) { |
194 | ttable_src_t *ttp = src_tt; | 195 | struct ttable_src *ttp = src_tt; |
195 | sum_t sum; | 196 | union sum sum; |
196 | 197 | ||
197 | /* Zero sum */ | 198 | /* Zero sum */ |
198 | goto *zero; | 199 | goto *zero; |
@@ -297,20 +298,20 @@ static void route_to_channel(snd_pcm_plugin_t *plugin, | |||
297 | } | 298 | } |
298 | } | 299 | } |
299 | 300 | ||
300 | static int route_src_channels_mask(snd_pcm_plugin_t *plugin, | 301 | static int route_src_channels_mask(struct snd_pcm_plugin *plugin, |
301 | unsigned long *dst_vmask, | 302 | unsigned long *dst_vmask, |
302 | unsigned long **src_vmask) | 303 | unsigned long **src_vmask) |
303 | { | 304 | { |
304 | route_t *data = (route_t *)plugin->extra_data; | 305 | struct route_priv *data = (struct route_priv *)plugin->extra_data; |
305 | int schannels = plugin->src_format.channels; | 306 | int schannels = plugin->src_format.channels; |
306 | int dchannels = plugin->dst_format.channels; | 307 | int dchannels = plugin->dst_format.channels; |
307 | unsigned long *vmask = plugin->src_vmask; | 308 | unsigned long *vmask = plugin->src_vmask; |
308 | int channel; | 309 | int channel; |
309 | ttable_dst_t *dp = data->ttable; | 310 | struct ttable_dst *dp = data->ttable; |
310 | bitmap_zero(vmask, schannels); | 311 | bitmap_zero(vmask, schannels); |
311 | for (channel = 0; channel < dchannels; channel++, dp++) { | 312 | for (channel = 0; channel < dchannels; channel++, dp++) { |
312 | unsigned int src; | 313 | unsigned int src; |
313 | ttable_src_t *sp; | 314 | struct ttable_src *sp; |
314 | if (!test_bit(channel, dst_vmask)) | 315 | if (!test_bit(channel, dst_vmask)) |
315 | continue; | 316 | continue; |
316 | sp = dp->srcs; | 317 | sp = dp->srcs; |
@@ -321,19 +322,19 @@ static int route_src_channels_mask(snd_pcm_plugin_t *plugin, | |||
321 | return 0; | 322 | return 0; |
322 | } | 323 | } |
323 | 324 | ||
324 | static int route_dst_channels_mask(snd_pcm_plugin_t *plugin, | 325 | static int route_dst_channels_mask(struct snd_pcm_plugin *plugin, |
325 | unsigned long *src_vmask, | 326 | unsigned long *src_vmask, |
326 | unsigned long **dst_vmask) | 327 | unsigned long **dst_vmask) |
327 | { | 328 | { |
328 | route_t *data = (route_t *)plugin->extra_data; | 329 | struct route_priv *data = (struct route_priv *)plugin->extra_data; |
329 | int dchannels = plugin->dst_format.channels; | 330 | int dchannels = plugin->dst_format.channels; |
330 | unsigned long *vmask = plugin->dst_vmask; | 331 | unsigned long *vmask = plugin->dst_vmask; |
331 | int channel; | 332 | int channel; |
332 | ttable_dst_t *dp = data->ttable; | 333 | struct ttable_dst *dp = data->ttable; |
333 | bitmap_zero(vmask, dchannels); | 334 | bitmap_zero(vmask, dchannels); |
334 | for (channel = 0; channel < dchannels; channel++, dp++) { | 335 | for (channel = 0; channel < dchannels; channel++, dp++) { |
335 | unsigned int src; | 336 | unsigned int src; |
336 | ttable_src_t *sp; | 337 | struct ttable_src *sp; |
337 | sp = dp->srcs; | 338 | sp = dp->srcs; |
338 | for (src = 0; src < dp->nsrcs; src++, sp++) { | 339 | for (src = 0; src < dp->nsrcs; src++, sp++) { |
339 | if (test_bit(sp->channel, src_vmask)) { | 340 | if (test_bit(sp->channel, src_vmask)) { |
@@ -346,33 +347,33 @@ static int route_dst_channels_mask(snd_pcm_plugin_t *plugin, | |||
346 | return 0; | 347 | return 0; |
347 | } | 348 | } |
348 | 349 | ||
349 | static void route_free(snd_pcm_plugin_t *plugin) | 350 | static void route_free(struct snd_pcm_plugin *plugin) |
350 | { | 351 | { |
351 | route_t *data = (route_t *)plugin->extra_data; | 352 | struct route_priv *data = (struct route_priv *)plugin->extra_data; |
352 | unsigned int dst_channel; | 353 | unsigned int dst_channel; |
353 | for (dst_channel = 0; dst_channel < plugin->dst_format.channels; ++dst_channel) { | 354 | for (dst_channel = 0; dst_channel < plugin->dst_format.channels; ++dst_channel) { |
354 | kfree(data->ttable[dst_channel].srcs); | 355 | kfree(data->ttable[dst_channel].srcs); |
355 | } | 356 | } |
356 | } | 357 | } |
357 | 358 | ||
358 | static int route_load_ttable(snd_pcm_plugin_t *plugin, | 359 | static int route_load_ttable(struct snd_pcm_plugin *plugin, |
359 | const route_ttable_entry_t* src_ttable) | 360 | const int *src_ttable) |
360 | { | 361 | { |
361 | route_t *data; | 362 | struct route_priv *data; |
362 | unsigned int src_channel, dst_channel; | 363 | unsigned int src_channel, dst_channel; |
363 | const route_ttable_entry_t *sptr; | 364 | const int *sptr; |
364 | ttable_dst_t *dptr; | 365 | struct ttable_dst *dptr; |
365 | if (src_ttable == NULL) | 366 | if (src_ttable == NULL) |
366 | return 0; | 367 | return 0; |
367 | data = (route_t *)plugin->extra_data; | 368 | data = (struct route_priv *)plugin->extra_data; |
368 | dptr = data->ttable; | 369 | dptr = data->ttable; |
369 | sptr = src_ttable; | 370 | sptr = src_ttable; |
370 | plugin->private_free = route_free; | 371 | plugin->private_free = route_free; |
371 | for (dst_channel = 0; dst_channel < plugin->dst_format.channels; ++dst_channel) { | 372 | for (dst_channel = 0; dst_channel < plugin->dst_format.channels; ++dst_channel) { |
372 | route_ttable_entry_t t = 0; | 373 | int t = 0; |
373 | int att = 0; | 374 | int att = 0; |
374 | int nsrcs = 0; | 375 | int nsrcs = 0; |
375 | ttable_src_t srcs[plugin->src_format.channels]; | 376 | struct ttable_src srcs[plugin->src_format.channels]; |
376 | for (src_channel = 0; src_channel < plugin->src_format.channels; ++src_channel) { | 377 | for (src_channel = 0; src_channel < plugin->src_format.channels; ++src_channel) { |
377 | snd_assert(*sptr >= 0 || *sptr <= FULL, return -ENXIO); | 378 | snd_assert(*sptr >= 0 || *sptr <= FULL, return -ENXIO); |
378 | if (*sptr != 0) { | 379 | if (*sptr != 0) { |
@@ -405,21 +406,21 @@ static int route_load_ttable(snd_pcm_plugin_t *plugin, | |||
405 | return 0; | 406 | return 0; |
406 | } | 407 | } |
407 | 408 | ||
408 | static snd_pcm_sframes_t route_transfer(snd_pcm_plugin_t *plugin, | 409 | static snd_pcm_sframes_t route_transfer(struct snd_pcm_plugin *plugin, |
409 | const snd_pcm_plugin_channel_t *src_channels, | 410 | const struct snd_pcm_plugin_channel *src_channels, |
410 | snd_pcm_plugin_channel_t *dst_channels, | 411 | struct snd_pcm_plugin_channel *dst_channels, |
411 | snd_pcm_uframes_t frames) | 412 | snd_pcm_uframes_t frames) |
412 | { | 413 | { |
413 | route_t *data; | 414 | struct route_priv *data; |
414 | int src_nchannels, dst_nchannels; | 415 | int src_nchannels, dst_nchannels; |
415 | int dst_channel; | 416 | int dst_channel; |
416 | ttable_dst_t *ttp; | 417 | struct ttable_dst *ttp; |
417 | snd_pcm_plugin_channel_t *dvp; | 418 | struct snd_pcm_plugin_channel *dvp; |
418 | 419 | ||
419 | snd_assert(plugin != NULL && src_channels != NULL && dst_channels != NULL, return -ENXIO); | 420 | snd_assert(plugin != NULL && src_channels != NULL && dst_channels != NULL, return -ENXIO); |
420 | if (frames == 0) | 421 | if (frames == 0) |
421 | return 0; | 422 | return 0; |
422 | data = (route_t *)plugin->extra_data; | 423 | data = (struct route_priv *)plugin->extra_data; |
423 | 424 | ||
424 | src_nchannels = plugin->src_format.channels; | 425 | src_nchannels = plugin->src_format.channels; |
425 | dst_nchannels = plugin->dst_format.channels; | 426 | dst_nchannels = plugin->dst_format.channels; |
@@ -469,14 +470,14 @@ int getput_index(int format) | |||
469 | return width * 4 + endian * 2 + sign; | 470 | return width * 4 + endian * 2 + sign; |
470 | } | 471 | } |
471 | 472 | ||
472 | int snd_pcm_plugin_build_route(snd_pcm_plug_t *plug, | 473 | int snd_pcm_plugin_build_route(struct snd_pcm_substream *plug, |
473 | snd_pcm_plugin_format_t *src_format, | 474 | struct snd_pcm_plugin_format *src_format, |
474 | snd_pcm_plugin_format_t *dst_format, | 475 | struct snd_pcm_plugin_format *dst_format, |
475 | route_ttable_entry_t *ttable, | 476 | int *ttable, |
476 | snd_pcm_plugin_t **r_plugin) | 477 | struct snd_pcm_plugin **r_plugin) |
477 | { | 478 | { |
478 | route_t *data; | 479 | struct route_priv *data; |
479 | snd_pcm_plugin_t *plugin; | 480 | struct snd_pcm_plugin *plugin; |
480 | int err; | 481 | int err; |
481 | 482 | ||
482 | snd_assert(r_plugin != NULL, return -ENXIO); | 483 | snd_assert(r_plugin != NULL, return -ENXIO); |
@@ -488,12 +489,13 @@ int snd_pcm_plugin_build_route(snd_pcm_plug_t *plug, | |||
488 | 489 | ||
489 | err = snd_pcm_plugin_build(plug, "attenuated route conversion", | 490 | err = snd_pcm_plugin_build(plug, "attenuated route conversion", |
490 | src_format, dst_format, | 491 | src_format, dst_format, |
491 | sizeof(route_t) + sizeof(data->ttable[0]) * dst_format->channels, | 492 | sizeof(struct route_priv) + |
493 | sizeof(data->ttable[0]) * dst_format->channels, | ||
492 | &plugin); | 494 | &plugin); |
493 | if (err < 0) | 495 | if (err < 0) |
494 | return err; | 496 | return err; |
495 | 497 | ||
496 | data = (route_t *) plugin->extra_data; | 498 | data = (struct route_priv *)plugin->extra_data; |
497 | 499 | ||
498 | data->get = getput_index(src_format->format); | 500 | data->get = getput_index(src_format->format); |
499 | snd_assert(data->get >= 0 && data->get < 4*2*2, return -EINVAL); | 501 | snd_assert(data->get >= 0 && data->get < 4*2*2, return -EINVAL); |