uda1341reg.h revision 1.1.4.2 1 1.1.4.2 mrg /*-
2 1.1.4.2 mrg * Copyright (c) 2012 The NetBSD Foundation, Inc.
3 1.1.4.2 mrg * All rights reserved.
4 1.1.4.2 mrg *
5 1.1.4.2 mrg * This code is derived from software contributed to The NetBSD Foundation
6 1.1.4.2 mrg * by Paul Fleischer <paul (at) xpg.dk>
7 1.1.4.2 mrg *
8 1.1.4.2 mrg * Redistribution and use in source and binary forms, with or without
9 1.1.4.2 mrg * modification, are permitted provided that the following conditions
10 1.1.4.2 mrg * are met:
11 1.1.4.2 mrg * 1. Redistributions of source code must retain the above copyright
12 1.1.4.2 mrg * notice, this list of conditions and the following disclaimer.
13 1.1.4.2 mrg * 2. Redistributions in binary form must reproduce the above copyright
14 1.1.4.2 mrg * notice, this list of conditions and the following disclaimer in the
15 1.1.4.2 mrg * documentation and/or other materials provided with the distribution.
16 1.1.4.2 mrg *
17 1.1.4.2 mrg * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
18 1.1.4.2 mrg * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19 1.1.4.2 mrg * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20 1.1.4.2 mrg * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
21 1.1.4.2 mrg * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 1.1.4.2 mrg * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 1.1.4.2 mrg * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 1.1.4.2 mrg * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 1.1.4.2 mrg * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 1.1.4.2 mrg * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 1.1.4.2 mrg * POSSIBILITY OF SUCH DAMAGE.
28 1.1.4.2 mrg */
29 1.1.4.2 mrg #ifndef _DEV_IC_UDA1341REG_H_
30 1.1.4.2 mrg #define _DEV_IC_UDA1341REG_H_
31 1.1.4.2 mrg
32 1.1.4.2 mrg #define UDA1341_L3_ADDR_DEVICE 0x14 /* Address of the UDA1341 on the L3 bus */
33 1.1.4.2 mrg #define UDA1341_L3_ADDR_DATA0 0x00
34 1.1.4.2 mrg #define UDA1341_L3_ADDR_DATA1 0x01
35 1.1.4.2 mrg #define UDA1341_L3_ADDR_STATUS 0x02
36 1.1.4.2 mrg
37 1.1.4.2 mrg /* Status address has two "banks", 0 and 1.
38 1.1.4.2 mrg The bank is selected as bit 7 of the data written.
39 1.1.4.2 mrg */
40 1.1.4.2 mrg #define UDA1341_L3_STATUS0 (0<<7)
41 1.1.4.2 mrg #define UDA1341_L3_STATUS1 (1<<7)
42 1.1.4.2 mrg
43 1.1.4.2 mrg /** Status bank 0 **/
44 1.1.4.2 mrg #define UDA1341_L3_STATUS0_RST (1<<6)
45 1.1.4.2 mrg
46 1.1.4.2 mrg /* System clock selection (bit 4 and 5) */
47 1.1.4.2 mrg #define UDA1341_L3_STATUS0_SC_512 (0<<4)
48 1.1.4.2 mrg #define UDA1341_L3_STATUS0_SC_384 (1<<4)
49 1.1.4.2 mrg #define UDA1341_L3_STATUS0_SC_256 (2<<4)
50 1.1.4.2 mrg #define UDA1341_L3_STATUS0_SC_NA (3<<4)
51 1.1.4.2 mrg #define UDA1341_L3_STATUS0_SC_SHIFT 4
52 1.1.4.2 mrg
53 1.1.4.2 mrg /* Interface format (bit 1, 2, 3)*/
54 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_I2S (0<<1)
55 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_LSB16 (1<<1)
56 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_LSB18 (2<<1)
57 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_LSB20 (3<<1)
58 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_MSB (4<<1)
59 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_LSB16_MSB (5<<1)
60 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_LSB18_MSB (6<<1)
61 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_LSB20_MSB (7<<1)
62 1.1.4.2 mrg #define UDA1341_L3_STATUS0_IF_SHIFT 1
63 1.1.4.2 mrg
64 1.1.4.2 mrg /* DC-Filtering */
65 1.1.4.2 mrg #define UDA1341_L3_STATUS0_DC_FILTERING (1<<0)
66 1.1.4.2 mrg
67 1.1.4.2 mrg /** Status bank 1**/
68 1.1.4.2 mrg
69 1.1.4.2 mrg /* Output and Input Gain*/
70 1.1.4.2 mrg #define UDA1341_L3_STATUS1_OGS_6DB (1<<6)
71 1.1.4.2 mrg #define UDA1341_L3_STATUS1_IGS_6DB (1<<5)
72 1.1.4.2 mrg
73 1.1.4.2 mrg /* DAC and ADC polarity inversion */
74 1.1.4.2 mrg #define UDA1341_L3_STATUS1_PAD_INV (1<<4)
75 1.1.4.2 mrg #define UDA1341_L3_STATUS1_PDA_INV (1<<3)
76 1.1.4.2 mrg
77 1.1.4.2 mrg /* Double speed playback */
78 1.1.4.2 mrg #define UDA1341_L3_STATUS1_DS (1<<2)
79 1.1.4.2 mrg
80 1.1.4.2 mrg /* Power Control */
81 1.1.4.2 mrg #define UDA1341_L3_STATUS1_PC_ADC (1<<1)
82 1.1.4.2 mrg #define UDA1341_L3_STATUS1_PC_DAC (1<<0)
83 1.1.4.2 mrg
84 1.1.4.2 mrg /*** DATA0 ***/
85 1.1.4.2 mrg /*
86 1.1.4.2 mrg * Data0 has five banks: three for direct control, and two for extended access.
87 1.1.4.2 mrg */
88 1.1.4.2 mrg #define UDA1341_L3_DATA0_VOLUME (0<<6)
89 1.1.4.2 mrg #define UDA1341_L3_DATA0_VOLUME_MASK (0x3F)
90 1.1.4.2 mrg
91 1.1.4.2 mrg #define UDA1341_L3_DATA0_BASS_TREBLE (1<<6)
92 1.1.4.2 mrg #define UDA1341_L3_DATA0_BASS_SHIFT 2
93 1.1.4.2 mrg #define UDA1341_L3_DATA0_BASS_MASK 0x3C
94 1.1.4.2 mrg #define UDA1341_L3_DATA0_TREBLE_SHIFT 0
95 1.1.4.2 mrg #define UDA1341_L3_DATA0_TREBLE_MASK 0x03
96 1.1.4.2 mrg
97 1.1.4.2 mrg #define UDA1341_L3_DATA0_SOUNDC (2<<6)
98 1.1.4.2 mrg #define UDA1341_L3_DATA0_SOUNDC_DE_MASK (0x18)
99 1.1.4.2 mrg #define UDA1341_L3_DATA0_SOUNDC_DE_SHIFT 3
100 1.1.4.2 mrg #define UDA1341_L3_DATA0_SOUNDC_MUTE (1<<2)
101 1.1.4.2 mrg #define UDA1341_L3_DATA0_SOUNDC_MODE_MASK (0x03)
102 1.1.4.2 mrg
103 1.1.4.2 mrg #define UDA1341_L3_DATA0_EA ((3<<6)|0<<5)
104 1.1.4.2 mrg #define UDA1341_L3_DATA0_ED ((3<<6)|1<<5)
105 1.1.4.2 mrg
106 1.1.4.2 mrg #define UDA1341_L3_DATA0_MA_MASK (0x1F)
107 1.1.4.2 mrg #define UDA1341_L3_DATA0_MB_MASK (0x1F)
108 1.1.4.2 mrg
109 1.1.4.2 mrg #define UDA1341_L3_DATA0_MS_MASK (0x1C)
110 1.1.4.2 mrg #define UDA1341_L3_DATA0_MS_SHIFT 2
111 1.1.4.2 mrg
112 1.1.4.2 mrg #define UDA1341_L3_DATA0_MM_MASK (0x03)
113 1.1.4.2 mrg
114 1.1.4.2 mrg #define UDA1341_L3_DATA0_AGC_SHIFT 4
115 1.1.4.2 mrg #define UDA1341_L3_DATA0_AGC_MASK (0x10)
116 1.1.4.2 mrg
117 1.1.4.2 mrg #define UDA1341_L3_DATA0_IG_LOW_MASK (0x03)
118 1.1.4.2 mrg #define UDA1341_L3_DATA0_IG_HIGH_MASK (0x1F)
119 1.1.4.2 mrg
120 1.1.4.2 mrg #define UDA1341_L3_DATA0_AL_MASK (0x03)
121 1.1.4.2 mrg #endif
122