1 #ifndef __SOUND_PCM_PARAMS_H
2 #define __SOUND_PCM_PARAMS_H
6 * Copyright (c) by Abramo Bagnara <abramo@alsa-project.org>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25 int snd_pcm_hw_param_first(struct snd_pcm_substream
*pcm
,
26 struct snd_pcm_hw_params
*params
,
27 snd_pcm_hw_param_t var
, int *dir
);
28 int snd_pcm_hw_param_last(struct snd_pcm_substream
*pcm
,
29 struct snd_pcm_hw_params
*params
,
30 snd_pcm_hw_param_t var
, int *dir
);
31 int snd_pcm_hw_param_value(const struct snd_pcm_hw_params
*params
,
32 snd_pcm_hw_param_t var
, int *dir
);
34 #define SNDRV_MASK_BITS 64 /* we use so far 64bits only */
35 #define SNDRV_MASK_SIZE (SNDRV_MASK_BITS / 32)
36 #define MASK_OFS(i) ((i) >> 5)
37 #define MASK_BIT(i) (1U << ((i) & 31))
39 static inline unsigned int ld2(u_int32_t v
)
64 static inline size_t snd_mask_sizeof(void)
66 return sizeof(struct snd_mask
);
69 static inline void snd_mask_none(struct snd_mask
*mask
)
71 memset(mask
, 0, sizeof(*mask
));
74 static inline void snd_mask_any(struct snd_mask
*mask
)
76 memset(mask
, 0xff, SNDRV_MASK_SIZE
* sizeof(u_int32_t
));
79 static inline int snd_mask_empty(const struct snd_mask
*mask
)
82 for (i
= 0; i
< SNDRV_MASK_SIZE
; i
++)
88 static inline unsigned int snd_mask_min(const struct snd_mask
*mask
)
91 for (i
= 0; i
< SNDRV_MASK_SIZE
; i
++) {
93 return ffs(mask
->bits
[i
]) - 1 + (i
<< 5);
98 static inline unsigned int snd_mask_max(const struct snd_mask
*mask
)
101 for (i
= SNDRV_MASK_SIZE
- 1; i
>= 0; i
--) {
103 return ld2(mask
->bits
[i
]) + (i
<< 5);
108 static inline void snd_mask_set(struct snd_mask
*mask
, unsigned int val
)
110 mask
->bits
[MASK_OFS(val
)] |= MASK_BIT(val
);
113 static inline void snd_mask_reset(struct snd_mask
*mask
, unsigned int val
)
115 mask
->bits
[MASK_OFS(val
)] &= ~MASK_BIT(val
);
118 static inline void snd_mask_set_range(struct snd_mask
*mask
,
119 unsigned int from
, unsigned int to
)
122 for (i
= from
; i
<= to
; i
++)
123 mask
->bits
[MASK_OFS(i
)] |= MASK_BIT(i
);
126 static inline void snd_mask_reset_range(struct snd_mask
*mask
,
127 unsigned int from
, unsigned int to
)
130 for (i
= from
; i
<= to
; i
++)
131 mask
->bits
[MASK_OFS(i
)] &= ~MASK_BIT(i
);
134 static inline void snd_mask_leave(struct snd_mask
*mask
, unsigned int val
)
137 v
= mask
->bits
[MASK_OFS(val
)] & MASK_BIT(val
);
139 mask
->bits
[MASK_OFS(val
)] = v
;
142 static inline void snd_mask_intersect(struct snd_mask
*mask
,
143 const struct snd_mask
*v
)
146 for (i
= 0; i
< SNDRV_MASK_SIZE
; i
++)
147 mask
->bits
[i
] &= v
->bits
[i
];
150 static inline int snd_mask_eq(const struct snd_mask
*mask
,
151 const struct snd_mask
*v
)
153 return ! memcmp(mask
, v
, SNDRV_MASK_SIZE
* sizeof(u_int32_t
));
156 static inline void snd_mask_copy(struct snd_mask
*mask
,
157 const struct snd_mask
*v
)
162 static inline int snd_mask_test(const struct snd_mask
*mask
, unsigned int val
)
164 return mask
->bits
[MASK_OFS(val
)] & MASK_BIT(val
);
167 static inline int snd_mask_single(const struct snd_mask
*mask
)
170 for (i
= 0; i
< SNDRV_MASK_SIZE
; i
++) {
173 if (mask
->bits
[i
] & (mask
->bits
[i
] - 1))
182 static inline int snd_mask_refine(struct snd_mask
*mask
,
183 const struct snd_mask
*v
)
186 snd_mask_copy(&old
, mask
);
187 snd_mask_intersect(mask
, v
);
188 if (snd_mask_empty(mask
))
190 return !snd_mask_eq(mask
, &old
);
193 static inline int snd_mask_refine_first(struct snd_mask
*mask
)
195 if (snd_mask_single(mask
))
197 snd_mask_leave(mask
, snd_mask_min(mask
));
201 static inline int snd_mask_refine_last(struct snd_mask
*mask
)
203 if (snd_mask_single(mask
))
205 snd_mask_leave(mask
, snd_mask_max(mask
));
209 static inline int snd_mask_refine_min(struct snd_mask
*mask
, unsigned int val
)
211 if (snd_mask_min(mask
) >= val
)
213 snd_mask_reset_range(mask
, 0, val
- 1);
214 if (snd_mask_empty(mask
))
219 static inline int snd_mask_refine_max(struct snd_mask
*mask
, unsigned int val
)
221 if (snd_mask_max(mask
) <= val
)
223 snd_mask_reset_range(mask
, val
+ 1, SNDRV_MASK_BITS
);
224 if (snd_mask_empty(mask
))
229 static inline int snd_mask_refine_set(struct snd_mask
*mask
, unsigned int val
)
232 changed
= !snd_mask_single(mask
);
233 snd_mask_leave(mask
, val
);
234 if (snd_mask_empty(mask
))
239 static inline int snd_mask_value(const struct snd_mask
*mask
)
241 return snd_mask_min(mask
);
244 static inline void snd_interval_any(struct snd_interval
*i
)
254 static inline void snd_interval_none(struct snd_interval
*i
)
259 static inline int snd_interval_checkempty(const struct snd_interval
*i
)
261 return (i
->min
> i
->max
||
262 (i
->min
== i
->max
&& (i
->openmin
|| i
->openmax
)));
265 static inline int snd_interval_empty(const struct snd_interval
*i
)
270 static inline int snd_interval_single(const struct snd_interval
*i
)
272 return (i
->min
== i
->max
||
273 (i
->min
+ 1 == i
->max
&& i
->openmax
));
276 static inline int snd_interval_value(const struct snd_interval
*i
)
281 static inline int snd_interval_min(const struct snd_interval
*i
)
286 static inline int snd_interval_max(const struct snd_interval
*i
)
295 static inline int snd_interval_test(const struct snd_interval
*i
, unsigned int val
)
297 return !((i
->min
> val
|| (i
->min
== val
&& i
->openmin
) ||
298 i
->max
< val
|| (i
->max
== val
&& i
->openmax
)));
301 static inline void snd_interval_copy(struct snd_interval
*d
, const struct snd_interval
*s
)
306 static inline int snd_interval_setinteger(struct snd_interval
*i
)
310 if (i
->openmin
&& i
->openmax
&& i
->min
== i
->max
)
316 static inline int snd_interval_eq(const struct snd_interval
*i1
, const struct snd_interval
*i2
)
322 return i1
->min
== i2
->min
&& i1
->openmin
== i2
->openmin
&&
323 i1
->max
== i2
->max
&& i1
->openmax
== i2
->openmax
;
326 static inline unsigned int add(unsigned int a
, unsigned int b
)
328 if (a
>= UINT_MAX
- b
)
333 static inline unsigned int sub(unsigned int a
, unsigned int b
)
340 #define params_access(p) ((__force snd_pcm_access_t)\
341 snd_mask_min(hw_param_mask_c((p), SNDRV_PCM_HW_PARAM_ACCESS)))
342 #define params_format(p) ((__force snd_pcm_format_t)\
343 snd_mask_min(hw_param_mask_c((p), SNDRV_PCM_HW_PARAM_FORMAT)))
344 #define params_subformat(p) \
345 snd_mask_min(hw_param_mask_c((p), SNDRV_PCM_HW_PARAM_SUBFORMAT))
347 static inline unsigned int
348 params_period_bytes(const struct snd_pcm_hw_params
*p
)
350 return (params_period_size(p
) *
351 snd_pcm_format_physical_width(params_format(p
)) *
352 params_channels(p
)) / 8;
355 #endif /* __SOUND_PCM_PARAMS_H */