ucb1200reg.h revision 1.3 1 1.3 uch /* $NetBSD: ucb1200reg.h,v 1.3 2000/02/27 16:37:51 uch Exp $ */
2 1.1 uch
3 1.1 uch /*
4 1.1 uch * Copyright (c) 2000, by UCHIYAMA Yasushi
5 1.1 uch * All rights reserved.
6 1.1 uch *
7 1.1 uch * Redistribution and use in source and binary forms, with or without
8 1.1 uch * modification, are permitted provided that the following conditions
9 1.1 uch * are met:
10 1.1 uch * 1. Redistributions of source code must retain the above copyright
11 1.1 uch * notice, this list of conditions and the following disclaimer.
12 1.1 uch * 2. The name of the developer may NOT be used to endorse or promote products
13 1.1 uch * derived from this software without specific prior written permission.
14 1.1 uch *
15 1.1 uch * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16 1.1 uch * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 1.1 uch * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 1.1 uch * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19 1.1 uch * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 1.1 uch * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21 1.1 uch * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 1.1 uch * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 1.1 uch * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24 1.1 uch * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25 1.1 uch * SUCH DAMAGE.
26 1.1 uch *
27 1.1 uch */
28 1.1 uch
29 1.1 uch /*
30 1.1 uch * PHILIPS UCB1200 Advanced modem/audio analog front-end
31 1.1 uch */
32 1.1 uch
33 1.1 uch /* Internal register. access via SIB */
34 1.1 uch #define UCB1200_IO_DATA_REG 0
35 1.1 uch #define UCB1200_IO_DIR_REG 1
36 1.1 uch #define UCB1200_POSINTEN_REG 2
37 1.1 uch #define UCB1200_NEGINTEN_REG 3
38 1.1 uch #define UCB1200_INTSTAT_REG 4
39 1.1 uch #define UCB1200_TELECOMCTRLA_REG 5
40 1.1 uch #define UCB1200_TELECOMCTRLB_REG 6
41 1.1 uch #define UCB1200_AUDIOCTRLA_REG 7
42 1.1 uch #define UCB1200_AUDIOCTRLB_REG 8
43 1.1 uch #define UCB1200_TSCTRL_REG 9
44 1.1 uch #define UCB1200_ADCCTRL_REG 10
45 1.1 uch #define UCB1200_ADCDATA_REG 11
46 1.1 uch #define UCB1200_ID_REG 12
47 1.1 uch #define UCB1200_MODE_REG 13
48 1.1 uch #define UCB1200_RESERVED_REG 14
49 1.1 uch #define UCB1200_NULL_REG 15 /* always returns 0xffff */
50 1.1 uch
51 1.1 uch /*
52 1.2 uch * I/O port data register
53 1.2 uch */
54 1.3 uch #define UCB1200_IOPORT_MAX 10
55 1.2 uch #define UCB1200_IO_DATA_SPEAKER 0x100 /* XXX general? */
56 1.2 uch
57 1.2 uch /*
58 1.2 uch * Telecom control register A
59 1.2 uch */
60 1.2 uch #define UCB1200_TELECOMCTRLA_DIV_MIN 16
61 1.2 uch #define UCB1200_TELECOMCTRLA_DIV_MAX 127
62 1.2 uch #define UCB1200_TELECOMCTRLA_DIV_SHIFT 0
63 1.2 uch #define UCB1200_TELECOMCTRLA_DIV_MASK 0x7f
64 1.2 uch #define UCB1200_TELECOMCTRLA_DIV(cr) \
65 1.2 uch (((cr) >> UCB1200_TELECOMCTRLA_DIV_SHIFT) & \
66 1.2 uch UCB1200_TELECOMCTRLA_DIV_MASK)
67 1.2 uch #define UCB1200_TELECOMCTRLA_DIV_SET(cr, val) \
68 1.2 uch ((cr) | (((val) << UCB1200_TELECOMCTRLA_DIV_SHIFT) & \
69 1.2 uch (UCB1200_TELECOMCTRLA_DIV_MASK << UCB1200_TELECOMCTRLA_DIV_SHIFT)))
70 1.2 uch
71 1.2 uch #define UCB1200_TELECOMCTRLA_LOOP 0x0080
72 1.2 uch
73 1.2 uch /*
74 1.2 uch * Telecom control register B
75 1.2 uch */
76 1.2 uch #define UCB1200_TELECOMCTRLB_VBF 0x0008
77 1.2 uch #define UCB1200_TELECOMCTRLB_CLIPSTATCLR 0x0010
78 1.2 uch #define UCB1200_TELECOMCTRLB_ATT 0x0040
79 1.2 uch #define UCB1200_TELECOMCTRLB_STS 0x0800
80 1.2 uch #define UCB1200_TELECOMCTRLB_MUTE 0x2000
81 1.2 uch #define UCB1200_TELECOMCTRLB_INEN 0x4000
82 1.2 uch #define UCB1200_TELECOMCTRLB_OUTEN 0x8000
83 1.2 uch
84 1.2 uch /*
85 1.2 uch * Audio control register A
86 1.2 uch */
87 1.2 uch #define UCB1200_AUDIOCTRLA_DIV_MIN 6
88 1.2 uch #define UCB1200_AUDIOCTRLA_DIV_MAX 127
89 1.2 uch #define UCB1200_AUDIOCTRLA_DIV_SHIFT 0
90 1.2 uch #define UCB1200_AUDIOCTRLA_DIV_MASK 0x7f
91 1.2 uch #define UCB1200_AUDIOCTRLA_DIV(cr) \
92 1.2 uch (((cr) >> UCB1200_AUDIOCTRLA_DIV_SHIFT) & \
93 1.2 uch UCB1200_AUDIOCTRLA_DIV_MASK)
94 1.2 uch #define UCB1200_AUDIOCTRLA_DIV_SET(cr, val) \
95 1.2 uch ((cr) | (((val) << UCB1200_AUDIOCTRLA_DIV_SHIFT) & \
96 1.2 uch (UCB1200_AUDIOCTRLA_DIV_MASK << UCB1200_AUDIOCTRLA_DIV_SHIFT)))
97 1.2 uch
98 1.2 uch #define UCB1200_AUDIOCTRLA_GAIN_SHIFT 7
99 1.2 uch #define UCB1200_AUDIOCTRLA_GAIN_MASK 0x1f
100 1.2 uch #define UCB1200_AUDIOCTRLA_GAIN(cr) \
101 1.2 uch (((cr) >> UCB1200_AUDIOCTRLA_GAIN_SHIFT) & \
102 1.2 uch UCB1200_AUDIOCTRLA_GAIN_MASK)
103 1.2 uch #define UCB1200_AUDIOCTRLA_GAIN_SET(cr, val) \
104 1.2 uch ((cr) | (((val) << UCB1200_AUDIOCTRLA_GAIN_SHIFT) & \
105 1.2 uch (UCB1200_AUDIOCTRLA_GAIN_MASK << UCB1200_AUDIOCTRLA_GAIN_SHIFT)))
106 1.2 uch
107 1.2 uch /*
108 1.2 uch * Audio control register B
109 1.2 uch */
110 1.2 uch #define UCB1200_AUDIOCTRLB_ATT_MIN 0
111 1.2 uch #define UCB1200_AUDIOCTRLB_ATT_MAX 0x1f
112 1.2 uch #define UCB1200_AUDIOCTRLB_ATT_SHIFT 0
113 1.2 uch #define UCB1200_AUDIOCTRLB_ATT_MASK 0x1f
114 1.2 uch #define UCB1200_AUDIOCTRLB_ATT(cr) \
115 1.2 uch (((cr) >> UCB1200_AUDIOCTRLB_ATT_SHIFT) & \
116 1.2 uch UCB1200_AUDIOCTRLB_ATT_MASK)
117 1.2 uch #define UCB1200_AUDIOCTRLB_ATT_SET(cr, val) \
118 1.2 uch ((cr) | (((val) << UCB1200_AUDIOCTRLB_ATT_SHIFT) & \
119 1.2 uch (UCB1200_AUDIOCTRLB_ATT_MASK << UCB1200_AUDIOCTRLB_ATT_SHIFT)))
120 1.2 uch
121 1.2 uch #define UCB1200_AUDIOCTRLB_CLIPSTATCLR 0x0040
122 1.2 uch #define UCB1200_AUDIOCTRLB_LOOP 0x0100
123 1.2 uch #define UCB1200_AUDIOCTRLB_MUTE 0x2000
124 1.2 uch #define UCB1200_AUDIOCTRLB_INEN 0x4000
125 1.2 uch #define UCB1200_AUDIOCTRLB_OUTEN 0x8000
126 1.2 uch
127 1.2 uch /*
128 1.1 uch * Touch screen control register
129 1.1 uch */
130 1.1 uch #define UCB1200_TSCTRL_MXLOW 0x00002000
131 1.1 uch #define UCB1200_TSCTRL_PXLOW 0x00001000
132 1.1 uch #define UCB1200_TSCTRL_BIAS 0x00000800
133 1.1 uch
134 1.1 uch #define UCB1200_TSCTRL_MODE_SHIFT 8
135 1.1 uch #define UCB1200_TSCTRL_MODE_MASK 0x7f
136 1.1 uch #define UCB1200_TSCTRL_MODE(cr) \
137 1.1 uch (((cr) >> UCB1200_TSCTRL_MODE_SHIFT) & \
138 1.1 uch UCB1200_TSCTRL_MODE_MASK)
139 1.1 uch #define UCB1200_TSCTRL_MODE_INTERRUPT 0
140 1.1 uch #define UCB1200_TSCTRL_MODE_PRESSURE (1 << UCB1200_TSCTRL_MODE_SHIFT)
141 1.1 uch #define UCB1200_TSCTRL_MODE_POSITION0 (2 << UCB1200_TSCTRL_MODE_SHIFT)
142 1.1 uch #define UCB1200_TSCTRL_MODE_POSITION1 (3 << UCB1200_TSCTRL_MODE_SHIFT)
143 1.1 uch
144 1.1 uch #define UCB1200_TSCTRL_PYGND 0x00000080
145 1.1 uch #define UCB1200_TSCTRL_MYGND 0x00000040
146 1.1 uch #define UCB1200_TSCTRL_PXGND 0x00000020
147 1.1 uch #define UCB1200_TSCTRL_MXGND 0x00000010
148 1.1 uch #define UCB1200_TSCTRL_PYPWR 0x00000008
149 1.1 uch #define UCB1200_TSCTRL_MYPWR 0x00000004
150 1.1 uch #define UCB1200_TSCTRL_PXPWR 0x00000002
151 1.1 uch #define UCB1200_TSCTRL_MXPWR 0x00000001
152 1.1 uch
153 1.1 uch /* touch screen modes */
154 1.1 uch #define UCB1200_TSCTRL_YPOSITION \
155 1.1 uch (UCB1200_TSCTRL_PXPWR | UCB1200_TSCTRL_MXGND | \
156 1.1 uch UCB1200_TSCTRL_MODE_POSITION0 | UCB1200_TSCTRL_BIAS)
157 1.1 uch #define UCB1200_TSCTRL_XPOSITION \
158 1.1 uch (UCB1200_TSCTRL_PYPWR | UCB1200_TSCTRL_MYGND | \
159 1.1 uch UCB1200_TSCTRL_MODE_POSITION0 | UCB1200_TSCTRL_BIAS)
160 1.1 uch #define UCB1200_TSCTRL_PRESSURE \
161 1.1 uch (UCB1200_TSCTRL_PXPWR | UCB1200_TSCTRL_MXPWR | \
162 1.1 uch UCB1200_TSCTRL_PYGND | UCB1200_TSCTRL_MYGND | \
163 1.1 uch UCB1200_TSCTRL_MODE_PRESSURE | UCB1200_TSCTRL_BIAS)
164 1.1 uch #define UCB1200_TSCTRL_INTERRUPT \
165 1.1 uch (UCB1200_TSCTRL_PXPWR | UCB1200_TSCTRL_MXPWR | \
166 1.1 uch UCB1200_TSCTRL_PYGND | UCB1200_TSCTRL_MYGND | \
167 1.1 uch UCB1200_TSCTRL_MODE_INTERRUPT)
168 1.1 uch
169 1.1 uch #define UCB1200_TSCTRL_PRESSURE1
170 1.1 uch #define UCB1200_TSCTRL_PRESSURE2
171 1.1 uch #define UCB1200_TSCTRL_PRESSURE3
172 1.1 uch #define UCB1200_TSCTRL_PRESSURE4
173 1.1 uch #define UCB1200_TSCTRL_PRESSURE5
174 1.1 uch #define UCB1200_TSCTRL_XRESISTANCE
175 1.1 uch #define UCB1200_TSCTRL_YRESISTANCE
176 1.1 uch
177 1.1 uch /*
178 1.1 uch * ADC control register
179 1.1 uch */
180 1.1 uch #define UCB1200_ADCCTRL_ENABLE 0x8000
181 1.1 uch #define UCB1200_ADCCTRL_START 0x0080
182 1.1 uch #define UCB1200_ADCCTRL_EXTREF 0x0020
183 1.1 uch
184 1.1 uch #define UCB1200_ADCCTRL_INPUT_SHIFT 2
185 1.1 uch #define UCB1200_ADCCTRL_INPUT_MASK 0x7
186 1.1 uch #define UCB1200_ADCCTRL_INPUT_SET(cr, val) \
187 1.1 uch ((cr) | (((val) << UCB1200_ADCCTRL_INPUT_SHIFT) & \
188 1.1 uch (UCB1200_ADCCTRL_INPUT_MASK << UCB1200_ADCCTRL_INPUT_SHIFT)))
189 1.1 uch #define UCB1200_ADCCTRL_INPUT_TSPX 0x0
190 1.1 uch #define UCB1200_ADCCTRL_INPUT_TSMX 0x1
191 1.1 uch #define UCB1200_ADCCTRL_INPUT_TSPY 0x2
192 1.1 uch #define UCB1200_ADCCTRL_INPUT_TSMY 0x3
193 1.1 uch #define UCB1200_ADCCTRL_INPUT_AD0 0x4
194 1.1 uch #define UCB1200_ADCCTRL_INPUT_AD1 0x5
195 1.1 uch #define UCB1200_ADCCTRL_INPUT_AD2 0x6
196 1.1 uch #define UCB1200_ADCCTRL_INPUT_AD3 0x7
197 1.1 uch
198 1.1 uch #define UCB1200_ADCCTRL_VREFBYP 0x0002
199 1.1 uch #define UCB1200_ADCCTRL_SYNCMODE 0x0001
200 1.1 uch
201 1.1 uch /*
202 1.1 uch * ADC data register
203 1.1 uch */
204 1.1 uch #define UCB1200_ADCDATA_INPROGRESS 0x8000
205 1.1 uch
206 1.1 uch #define UCB1200_ADCDATA_SHIFT 5
207 1.1 uch #define UCB1200_ADCDATA_MASK 0x3ff
208 1.1 uch #define UCB1200_ADCDATA(cr) \
209 1.1 uch (((cr) >> UCB1200_ADCDATA_SHIFT) & \
210 1.1 uch UCB1200_ADCDATA_MASK)
211 1.1 uch
212 1.1 uch /*
213 1.1 uch * ID register
214 1.1 uch */
215 1.1 uch /* Version 4, Device 0, Supplier 1 */
216 1.1 uch #define UCB1200_ID 0x1004
217 1.2 uch /* TOSHIBA TC35413F */
218 1.2 uch #define TC35413F_ID 0x9712
219