Commit | Line | Data |
---|---|---|
1a59d1b8 | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
1da177e4 LT |
2 | /* |
3 | * Copyright (c) 1999 by Uros Bizjak <uros@kss-loka.si> | |
4 | * Takashi Iwai <tiwai@suse.de> | |
5 | * | |
6 | * SB16ASP/AWE32 CSP control | |
1da177e4 | 7 | */ |
674e95ca DH |
8 | #ifndef __SOUND_SB16_CSP_H |
9 | #define __SOUND_SB16_CSP_H | |
1da177e4 | 10 | |
a1ce3928 DH |
11 | #include <sound/sb.h> |
12 | #include <sound/hwdep.h> | |
de66d53e | 13 | #include <linux/firmware.h> |
674e95ca | 14 | #include <uapi/sound/sb16_csp.h> |
1da177e4 | 15 | |
029d64b0 | 16 | struct snd_sb_csp; |
1da177e4 | 17 | |
de66d53e CL |
18 | /* indices for the known CSP programs */ |
19 | enum { | |
20 | CSP_PROGRAM_MULAW, | |
21 | CSP_PROGRAM_ALAW, | |
22 | CSP_PROGRAM_ADPCM_INIT, | |
23 | CSP_PROGRAM_ADPCM_PLAYBACK, | |
24 | CSP_PROGRAM_ADPCM_CAPTURE, | |
25 | ||
26 | CSP_PROGRAM_COUNT | |
27 | }; | |
28 | ||
1da177e4 LT |
29 | /* |
30 | * CSP operators | |
31 | */ | |
029d64b0 TI |
32 | struct snd_sb_csp_ops { |
33 | int (*csp_use) (struct snd_sb_csp * p); | |
34 | int (*csp_unuse) (struct snd_sb_csp * p); | |
e5d3765b | 35 | int (*csp_autoload) (struct snd_sb_csp * p, snd_pcm_format_t pcm_sfmt, int play_rec_mode); |
029d64b0 TI |
36 | int (*csp_start) (struct snd_sb_csp * p, int sample_width, int channels); |
37 | int (*csp_stop) (struct snd_sb_csp * p); | |
38 | int (*csp_qsound_transfer) (struct snd_sb_csp * p); | |
39 | }; | |
1da177e4 LT |
40 | |
41 | /* | |
42 | * CSP private data | |
43 | */ | |
44 | struct snd_sb_csp { | |
029d64b0 | 45 | struct snd_sb *chip; /* SB16 DSP */ |
1da177e4 LT |
46 | int used; /* usage flag - exclusive */ |
47 | char codec_name[16]; /* name of codec */ | |
48 | unsigned short func_nr; /* function number */ | |
49 | unsigned int acc_format; /* accepted PCM formats */ | |
50 | int acc_channels; /* accepted channels */ | |
51 | int acc_width; /* accepted sample width */ | |
52 | int acc_rates; /* accepted sample rates */ | |
53 | int mode; /* MODE */ | |
54 | int run_channels; /* current CSP channels */ | |
55 | int run_width; /* current sample width */ | |
56 | int version; /* CSP version (0x10 - 0x1f) */ | |
57 | int running; /* running state */ | |
58 | ||
029d64b0 | 59 | struct snd_sb_csp_ops ops; /* operators */ |
1da177e4 LT |
60 | |
61 | spinlock_t q_lock; /* locking */ | |
62 | int q_enabled; /* enabled flag */ | |
63 | int qpos_left; /* left position */ | |
64 | int qpos_right; /* right position */ | |
65 | int qpos_changed; /* position changed flag */ | |
66 | ||
029d64b0 TI |
67 | struct snd_kcontrol *qsound_switch; |
68 | struct snd_kcontrol *qsound_space; | |
1da177e4 | 69 | |
8b7547f9 | 70 | struct mutex access_mutex; /* locking */ |
de66d53e CL |
71 | |
72 | const struct firmware *csp_programs[CSP_PROGRAM_COUNT]; | |
1da177e4 LT |
73 | }; |
74 | ||
029d64b0 | 75 | int snd_sb_csp_new(struct snd_sb *chip, int device, struct snd_hwdep ** rhwdep); |
1da177e4 | 76 | #endif /* __SOUND_SB16_CSP */ |