blob: 65ddfa3cac1fb67a7db48216edd4cfbacf90669e [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __SOUND_AK4XXX_ADDA_H
2#define __SOUND_AK4XXX_ADDA_H
3
4/*
5 * ALSA driver for AK4524 / AK4528 / AK4529 / AK4355 / AK4381
6 * AD and DA converters
7 *
8 * Copyright (c) 2000 Jaroslav Kysela <perex@suse.cz>
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23 *
24 */
25
26#ifndef AK4XXX_MAX_CHIPS
27#define AK4XXX_MAX_CHIPS 4
28#endif
29
Takashi Iwaidc4cafb2005-11-17 14:19:28 +010030struct snd_akm4xxx;
Linus Torvalds1da177e2005-04-16 15:20:36 -070031
32struct snd_ak4xxx_ops {
Takashi Iwaidc4cafb2005-11-17 14:19:28 +010033 void (*lock)(struct snd_akm4xxx *ak, int chip);
34 void (*unlock)(struct snd_akm4xxx *ak, int chip);
Takashi Iwaicb9d24e2006-06-27 17:49:12 +020035 void (*write)(struct snd_akm4xxx *ak, int chip, unsigned char reg,
36 unsigned char val);
Takashi Iwaidc4cafb2005-11-17 14:19:28 +010037 void (*set_rate_val)(struct snd_akm4xxx *ak, unsigned int rate);
Linus Torvalds1da177e2005-04-16 15:20:36 -070038};
39
40#define AK4XXX_IMAGE_SIZE (AK4XXX_MAX_CHIPS * 16) /* 64 bytes */
41
42struct snd_akm4xxx {
Takashi Iwaidc4cafb2005-11-17 14:19:28 +010043 struct snd_card *card;
Takashi Iwaicb9d24e2006-06-27 17:49:12 +020044 unsigned int num_adcs; /* AK4524 or AK4528 ADCs */
45 unsigned int num_dacs; /* AK4524 or AK4528 DACs */
46 unsigned char images[AK4XXX_IMAGE_SIZE]; /* saved register image */
47 unsigned char ipga_gain[AK4XXX_MAX_CHIPS][2]; /* saved register image
48 * for IPGA (AK4528)
49 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070050 unsigned long private_value[AK4XXX_MAX_CHIPS]; /* helper for driver */
51 void *private_data[AK4XXX_MAX_CHIPS]; /* helper for driver */
52 /* template should fill the following fields */
Takashi Iwaicb9d24e2006-06-27 17:49:12 +020053 unsigned int idx_offset; /* control index offset */
Linus Torvalds1da177e2005-04-16 15:20:36 -070054 enum {
55 SND_AK4524, SND_AK4528, SND_AK4529,
Jochen Voss683fe152006-08-08 21:12:44 +020056 SND_AK4355, SND_AK4358, SND_AK4381,
57 SND_AK5365
Linus Torvalds1da177e2005-04-16 15:20:36 -070058 } type;
Takashi Iwaicb9d24e2006-06-27 17:49:12 +020059 unsigned int *num_stereo; /* array of combined counts
60 * for the mixer
61 */
62 char **channel_names; /* array of mixer channel names */
Linus Torvalds1da177e2005-04-16 15:20:36 -070063 struct snd_ak4xxx_ops ops;
64};
65
Takashi Iwaicb9d24e2006-06-27 17:49:12 +020066void snd_akm4xxx_write(struct snd_akm4xxx *ak, int chip, unsigned char reg,
67 unsigned char val);
Takashi Iwaidc4cafb2005-11-17 14:19:28 +010068void snd_akm4xxx_reset(struct snd_akm4xxx *ak, int state);
69void snd_akm4xxx_init(struct snd_akm4xxx *ak);
70int snd_akm4xxx_build_controls(struct snd_akm4xxx *ak);
Linus Torvalds1da177e2005-04-16 15:20:36 -070071
Takashi Iwaicb9d24e2006-06-27 17:49:12 +020072#define snd_akm4xxx_get(ak,chip,reg) \
73 (ak)->images[(chip) * 16 + (reg)]
74#define snd_akm4xxx_set(ak,chip,reg,val) \
75 ((ak)->images[(chip) * 16 + (reg)] = (val))
76#define snd_akm4xxx_get_ipga(ak,chip,reg) \
77 (ak)->ipga_gain[chip][(reg)-4]
78#define snd_akm4xxx_set_ipga(ak,chip,reg,val) \
79 ((ak)->ipga_gain[chip][(reg)-4] = (val))
Linus Torvalds1da177e2005-04-16 15:20:36 -070080
81#endif /* __SOUND_AK4XXX_ADDA_H */