tx39ioreg.h revision 1.1 1 /* $NetBSD: tx39ioreg.h,v 1.1 1999/11/20 19:56:36 uch Exp $ */
2
3 /*
4 * Copyright (c) 1999, by UCHIYAMA Yasushi
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. The name of the developer may NOT be used to endorse or promote products
13 * derived from this software without specific prior written permission.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25 * SUCH DAMAGE.
26 *
27 */
28 /*
29 * TOSHIBA TX3912/TX3922 IO module
30 */
31
32 #define TX39_IOCTRL_REG 0x180
33 #define TX39_IOMFIODATAOUT_REG 0x184
34 #define TX39_IOMFIODATADIR_REG 0x188
35 #define TX39_IOMFIODATAIN_REG 0x18c
36 #define TX39_IOMFIODATASEL_REG 0x190
37 #define TX39_IOIOPOWERDWN_REG 0x194
38 #define TX39_IOMFIOPOWERDWN_REG 0x198
39 #ifdef TX392X
40 #define TX39_IODATAINOUT_REG 0x19c
41 #endif /* TX392X */
42
43 #define TX39_IO_MFIO_MAX 32
44 #ifdef TX391X
45 #define TX39_IO_IO_MAX 7
46 #endif /* TX391X */
47 #ifdef TX392X
48 #define TX39_IO_IO_MAX 16
49 #endif /* TX392X */
50
51 /*
52 * IO Control Register
53 */
54 #ifdef TX391X
55 #define TX39_IOCTRL_IODEBSEL_SHIFT 24
56 #define TX39_IOCTRL_IODEBSEL_MASK 0x7f
57 #define TX39_IOCTRL_IODEBSEL(cr) \
58 (((cr) >> TX39_IOCTRL_IODEBSEL_SHIFT) & \
59 TX39_IOCTRL_IODEBSEL_MASK)
60 #define TX39_IOCTRL_IODEBSEL_SET(cr, val) \
61 ((cr) | (((val) << TX39_IOCTRL_IODEBSEL_SHIFT) & \
62 (TX39_IOCTRL_IODEBSEL_MASK << TX39_IOCTRL_IODEBSEL_SHIFT)))
63
64 #define TX39_IOCTRL_IODIREC_SHIFT 16
65 #define TX39_IOCTRL_IODIREC_MASK 0x7f
66 #define TX39_IOCTRL_IODIREC(cr) \
67 (((cr) >> TX39_IOCTRL_IODIREC_SHIFT) & \
68 TX39_IOCTRL_IODIREC_MASK)
69 #define TX39_IOCTRL_IODIREC_SET(cr, val) \
70 ((cr) | (((val) << TX39_IOCTRL_IODIREC_SHIFT) & \
71 (TX39_IOCTRL_IODIREC_MASK << TX39_IOCTRL_IODIREC_SHIFT)))
72
73 #define TX39_IOCTRL_IODOUT_SHIFT 8
74 #define TX39_IOCTRL_IODOUT_MASK 0x7f
75 #define TX39_IOCTRL_IODOUT(cr) \
76 (((cr) >> TX39_IOCTRL_IODOUT_SHIFT) & \
77 TX39_IOCTRL_IODOUT_MASK)
78 #define TX39_IOCTRL_IODOUT_SET(cr, val) \
79 ((cr) | (((val) << TX39_IOCTRL_IODOUT_SHIFT) & \
80 (TX39_IOCTRL_IODOUT_MASK << TX39_IOCTRL_IODOUT_SHIFT)))
81
82 #define TX39_IOCTRL_IODIN_SHIFT 0
83 #define TX39_IOCTRL_IODIN_MASK 0x7f
84 #define TX39_IOCTRL_IODIN(cr) \
85 (((cr) >> TX39_IOCTRL_IODIN_SHIFT) & \
86 TX39_IOCTRL_IODIN_MASK)
87 #define TX39_IOCTRL_IODIN_SET(cr, val) \
88 ((cr) | (((val) << TX39_IOCTRL_IODIN_SHIFT) & \
89 (TX39_IOCTRL_IODIN_MASK << TX39_IOCTRL_IODIN_SHIFT)))
90 #endif /* TX391X */
91
92 #ifdef TX392X
93 #define TX39_IOCTRL_IODEBSEL_SHIFT 16
94 #define TX39_IOCTRL_IODEBSEL_MASK 0xffff
95 #define TX39_IOCTRL_IODEBSEL(cr) \
96 (((cr) >> TX39_IOCTRL_IODEBSEL_SHIFT) & \
97 TX39_IOCTRL_IODEBSEL_MASK)
98 #define TX39_IOCTRL_IODEBSEL_SET(cr, val) \
99 ((cr) | (((val) << TX39_IOCTRL_IODEBSEL_SHIFT) & \
100 (TX39_IOCTRL_IODEBSEL_MASK << TX39_IOCTRL_IODEBSEL_SHIFT)))
101
102 #define TX39_IOCTRL_IODIREC_SHIFT 0
103 #define TX39_IOCTRL_IODIREC_MASK 0xffff
104 #define TX39_IOCTRL_IODIREC(cr) \
105 (((cr) >> TX39_IOCTRL_IODIREC_SHIFT) & \
106 TX39_IOCTRL_IODIREC_MASK)
107 #define TX39_IOCTRL_IODIREC_SET(cr, val) \
108 ((cr) | (((val) << TX39_IOCTRL_IODIREC_SHIFT) & \
109 (TX39_IOCTRL_IODIREC_MASK << TX39_IOCTRL_IODIREC_SHIFT)))
110
111 #define TX39_IODATAINOUT_DOUT_SHIFT 16
112 #define TX39_IODATAINOUT_DOUT_MASK 0xffff
113 #define TX39_IODATAINOUT_DOUT(cr) \
114 (((cr) >> TX39_IODATAINOUT_DOUT_SHIFT) & \
115 TX39_IODATAINOUT_DOUT_MASK)
116 #define TX39_IODATAINOUT_DOUT_SET(cr, val) \
117 ((cr) | (((val) << TX39_IODATAINOUT_DOUT_SHIFT) & \
118 (TX39_IODATAINOUT_DOUT_MASK << TX39_IODATAINOUT_DOUT_SHIFT)))
119
120 #define TX39_IODATAINOUT_DIN_SHIFT 0
121 #define TX39_IODATAINOUT_DIN_MASK 0xffff
122 #define TX39_IODATAINOUT_DIN(cr) \
123 (((cr) >> TX39_IODATAINOUT_DIN_SHIFT) & \
124 TX39_IODATAINOUT_DIN_MASK)
125 #define TX39_IODATAINOUT_DIN_SET(cr, val) \
126 ((cr) | (((val) << TX39_IODATAINOUT_DIN_SHIFT) & \
127 (TX39_IODATAINOUT_DIN_MASK << TX39_IODATAINOUT_DIN_SHIFT)))
128 #endif /* TX392X */
129 /*
130 * MFIO Data Output Register
131 */
132 #define TX39_IOMFIODATAOUT_MFIODOUT 0
133
134 /*
135 * MFIO Data Direction Register
136 */
137 #define TX39_IOMFIODATADIR_MFIODIREC 0
138
139 /*
140 * MFIO Data Input Register
141 */
142 #define TX39_IOMFIODATAIN_MFIODIN 0
143
144 /*
145 * MFIO Data Select Register
146 */
147 #define TX39_IOMFIODATASEL_MFIOSEL 0
148 #define TX39_IOMFIODATASEL_MFIOSEL_RESET 0xf20f0fff
149
150 /*
151 * IO Power Down Register
152 */
153 #define TX39_IOIOPOWERDWN_IOPD_SHIFT 0
154 #ifdef TX391X
155 #define TX39_IOIOPOWERDWN_IOPD_MASK 0x7f
156 #define TX39_IOIOPOWERDWN_IOPD_RESET 0x7f
157 #endif /* TX391X */
158 #ifdef TX392X
159 #define TX39_IOIOPOWERDWN_IOPD_MASK 0xffff
160 #define TX39_IOIOPOWERDWN_IOPD_RESET 0x0fff
161 #endif /* TX392X */
162 #define TX39_IOIOPOWERDWN_IOPD(cr) \
163 (((cr) >> TX39_IOIOPOWERDWN_IOPD_SHIFT) & \
164 TX39_IOIOPOWERDWN_IOPD_MASK)
165 #define TX39_IOIOPOWERDWN_IOPD_SET(cr, val) \
166 ((cr) | (((val) << TX39_IOIOPOWERDWN_IOPD_SHIFT) & \
167 (TX39_IOIOPOWERDWN_IOPD_MASK << TX39_IOIOPOWERDOWN_IOPD_SHIFT)))
168
169
170 /*
171 * MFIO Power Down Register
172 */
173 #define TX39_IOMFIOPOWERDWN_MFIOPD 0
174 #define TX39_IOMFIOPOWERDWN_MFIOPD_RESET 0xfaf03ffc
175
176