blob: cafd415e21e20a17f25b9f8736166dfbee07cf5a [file] [log] [blame]
Thomas Gleixner1a59d1b82019-05-27 08:55:05 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * Copyright (c) 1999 by Uros Bizjak <uros@kss-loka.si>
4 * Takashi Iwai <tiwai@suse.de>
5 *
6 * SB16ASP/AWE32 CSP control
Linus Torvalds1da177e2005-04-16 15:20:36 -07007 */
David Howells674e95c2012-10-09 09:49:13 +01008#ifndef __SOUND_SB16_CSP_H
9#define __SOUND_SB16_CSP_H
Linus Torvalds1da177e2005-04-16 15:20:36 -070010
David Howellsa1ce3922012-10-02 18:01:25 +010011#include <sound/sb.h>
12#include <sound/hwdep.h>
Clemens Ladischde66d532006-11-06 09:18:34 +010013#include <linux/firmware.h>
David Howells674e95c2012-10-09 09:49:13 +010014#include <uapi/sound/sb16_csp.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070015
Takashi Iwai029d64b2005-11-17 14:34:36 +010016struct snd_sb_csp;
Linus Torvalds1da177e2005-04-16 15:20:36 -070017
Clemens Ladischde66d532006-11-06 09:18:34 +010018/* indices for the known CSP programs */
19enum {
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
Linus Torvalds1da177e2005-04-16 15:20:36 -070029/*
30 * CSP operators
31 */
Takashi Iwai029d64b2005-11-17 14:34:36 +010032struct snd_sb_csp_ops {
33 int (*csp_use) (struct snd_sb_csp * p);
34 int (*csp_unuse) (struct snd_sb_csp * p);
Takashi Iwaie5d37652018-07-25 23:19:44 +020035 int (*csp_autoload) (struct snd_sb_csp * p, snd_pcm_format_t pcm_sfmt, int play_rec_mode);
Takashi Iwai029d64b2005-11-17 14:34:36 +010036 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};
Linus Torvalds1da177e2005-04-16 15:20:36 -070040
41/*
42 * CSP private data
43 */
44struct snd_sb_csp {
Takashi Iwai029d64b2005-11-17 14:34:36 +010045 struct snd_sb *chip; /* SB16 DSP */
Linus Torvalds1da177e2005-04-16 15:20:36 -070046 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
Takashi Iwai029d64b2005-11-17 14:34:36 +010059 struct snd_sb_csp_ops ops; /* operators */
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
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
Takashi Iwai029d64b2005-11-17 14:34:36 +010067 struct snd_kcontrol *qsound_switch;
68 struct snd_kcontrol *qsound_space;
Linus Torvalds1da177e2005-04-16 15:20:36 -070069
Ingo Molnar8b7547f2006-01-16 16:33:08 +010070 struct mutex access_mutex; /* locking */
Clemens Ladischde66d532006-11-06 09:18:34 +010071
72 const struct firmware *csp_programs[CSP_PROGRAM_COUNT];
Linus Torvalds1da177e2005-04-16 15:20:36 -070073};
74
Takashi Iwai029d64b2005-11-17 14:34:36 +010075int snd_sb_csp_new(struct snd_sb *chip, int device, struct snd_hwdep ** rhwdep);
Linus Torvalds1da177e2005-04-16 15:20:36 -070076#endif /* __SOUND_SB16_CSP */