sxreg.h revision 1.7 1 1.7 macallan /* $NetBSD: sxreg.h,v 1.7 2013/06/05 18:15:06 macallan Exp $ */
2 1.1 macallan
3 1.1 macallan /*-
4 1.1 macallan * Copyright (c) 2013 The NetBSD Foundation, Inc.
5 1.1 macallan * All rights reserved.
6 1.1 macallan *
7 1.1 macallan * This code is derived from software contributed to The NetBSD Foundation
8 1.1 macallan * by Michael Lorenz.
9 1.1 macallan *
10 1.1 macallan * Redistribution and use in source and binary forms, with or without
11 1.1 macallan * modification, are permitted provided that the following conditions
12 1.1 macallan * are met:
13 1.1 macallan * 1. Redistributions of source code must retain the above copyright
14 1.1 macallan * notice, this list of conditions and the following disclaimer.
15 1.1 macallan * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 macallan * notice, this list of conditions and the following disclaimer in the
17 1.1 macallan * documentation and/or other materials provided with the distribution.
18 1.1 macallan *
19 1.1 macallan * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 macallan * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 macallan * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 macallan * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 macallan * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 macallan * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 macallan * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 macallan * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 macallan * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 macallan * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 macallan * POSSIBILITY OF SUCH DAMAGE.
30 1.1 macallan */
31 1.1 macallan
32 1.1 macallan /* register definitions for Sun's SX / SPAM rendering engine */
33 1.1 macallan
34 1.1 macallan #ifndef SXREG_H
35 1.1 macallan #define SXREG_H
36 1.1 macallan
37 1.1 macallan /* SX control registers */
38 1.1 macallan #define SX_CONTROL_STATUS 0x00000000
39 1.1 macallan #define SX_ERROR 0x00000004
40 1.1 macallan #define SX_PAGE_BOUND_LOWER 0x00000008
41 1.1 macallan #define SX_PAGE_BOUND_UPPER 0x0000000c
42 1.1 macallan #define SX_PLANEMASK 0x00000010
43 1.1 macallan #define SX_ROP_CONTROL 0x00000014 /* 8 bit ROP */
44 1.1 macallan #define SX_IQ_OVERFLOW_COUNTER 0x00000018
45 1.1 macallan #define SX_DIAGNOSTICS 0x0000001c
46 1.1 macallan #define SX_INSTRUCTIONS 0x00000020
47 1.1 macallan #define SX_ID 0x00000028
48 1.1 macallan #define SX_R0_INIT 0x0000002c
49 1.1 macallan #define SX_SOFTRESET 0x00000030
50 1.1 macallan /* write registers directly, only when processor is stopped */
51 1.1 macallan #define SX_DIRECT_R0 0x00000100
52 1.1 macallan #define SX_DIRECT_R1 0x00000104 /* and so on until R127 */
53 1.1 macallan /* write registers via pseudo instructions */
54 1.1 macallan #define SX_QUEUED_R0 0x00000300
55 1.1 macallan #define SX_QUEUED_R1 0x00000304 /* and so on until R127 */
56 1.2 macallan #define SX_QUEUED(r) (0x300 + (r << 2))
57 1.2 macallan
58 1.2 macallan /* special purpose registers */
59 1.2 macallan #define R_ZERO 0
60 1.2 macallan #define R_SCAM 1
61 1.2 macallan #define R_MASK 2 /* bitmask for SX_STORE_SELECT */
62 1.1 macallan
63 1.1 macallan /*
64 1.1 macallan * registers are repeated at 0x1000 with certain parts read only
65 1.4 macallan * ( like the PAGE_BOUND registers ) which userland has no business writing to
66 1.1 macallan */
67 1.1 macallan
68 1.1 macallan /* SX_CONTROL_STATUS */
69 1.1 macallan #define SX_EE1 0x00000001 /* illegal instruction */
70 1.1 macallan #define SX_EE2 0x00000002 /* page bound error */
71 1.1 macallan #define SX_EE3 0x00000004 /* illegal memory access */
72 1.1 macallan #define SX_EE4 0x00000008 /* illegal register access */
73 1.1 macallan #define SX_EE5 0x00000010 /* alignment violation */
74 1.1 macallan #define SX_EE6 0x00000020 /* illegal instruction queue write */
75 1.1 macallan #define SX_EI 0x00000080 /* interrupt on error */
76 1.1 macallan #define SX_PB 0x00001000 /* enable page bound checking */
77 1.1 macallan #define SX_WO 0x00002000 /* write occured ( by SX ) */
78 1.1 macallan #define SX_GO 0x00004000 /* start/stop the processor */
79 1.1 macallan #define SX_MT 0x00008000 /* instruction queue is empty */
80 1.1 macallan
81 1.1 macallan /* SX_ERROR */
82 1.1 macallan #define SX_SE1 0x00000001 /* illegal instruction */
83 1.1 macallan #define SX_SE2 0x00000002 /* page bound error */
84 1.1 macallan #define SX_SE3 0x00000004 /* illegal memory access */
85 1.1 macallan #define SX_SE4 0x00000008 /* illegal register access */
86 1.1 macallan #define SX_SE5 0x00000010 /* alignment violation */
87 1.1 macallan #define SX_SE6 0x00000020 /* illegal instruction queue write */
88 1.1 macallan #define SX_SI 0x00000080 /* interrupt on error */
89 1.1 macallan
90 1.1 macallan /* SX_ID */
91 1.1 macallan #define SX_ARCHITECTURE_MASK 0x000000ff
92 1.1 macallan #define SX_CHIP_REVISION 0x0000ff00
93 1.1 macallan
94 1.1 macallan /* SX_DIAGNOSTICS */
95 1.1 macallan #define SX_IQ_FIFO_ACCESS 0x00000001 /* allow memory instructions
96 1.1 macallan * in SX_INSTRUCTIONS */
97 1.1 macallan
98 1.1 macallan /*
99 1.1 macallan * memory referencing instructions are written to 0x800000000 + PA
100 1.1 macallan * so we have to go through ASI 0x28 ( ASI_BYPASS + 8 )
101 1.1 macallan */
102 1.1 macallan #define ASI_SX 0x28
103 1.1 macallan
104 1.1 macallan /* load / store instructions */
105 1.1 macallan #define SX_STORE_COND (0x4 << 19) /* conditional write with mask */
106 1.1 macallan #define SX_STORE_CLAMP (0x2 << 19)
107 1.1 macallan #define SX_STORE_MASK (0x1 << 19) /* apply plane mask */
108 1.2 macallan #define SX_STORE_SELECT (0x8 << 19) /* expand with plane reg dest[0]/dest[1] */
109 1.1 macallan #define SX_LOAD (0xa << 19)
110 1.1 macallan #define SX_STORE (0x0 << 19)
111 1.1 macallan
112 1.1 macallan /* data type */
113 1.1 macallan #define SX_UBYTE_0 (0x00 << 14)
114 1.1 macallan #define SX_UBYTE_8 (0x01 << 14)
115 1.1 macallan #define SX_UBYTE_16 (0x02 << 14)
116 1.1 macallan #define SX_UBYTE_24 (0x03 << 14)
117 1.1 macallan #define SX_SBYTE_0 (0x04 << 14)
118 1.1 macallan #define SX_SBYTE_8 (0x05 << 14)
119 1.1 macallan #define SX_SBYTE_16 (0x06 << 14)
120 1.1 macallan #define SX_SBYTE_24 (0x07 << 14)
121 1.1 macallan #define SX_UQUAD_0 (0x08 << 14)
122 1.1 macallan #define SX_UQUAD_8 (0x09 << 14)
123 1.1 macallan #define SX_UQUAD_16 (0x0a << 14)
124 1.1 macallan #define SX_UQUAD_24 (0x0b << 14)
125 1.1 macallan #define SX_SQUAD_0 (0x0c << 14)
126 1.1 macallan #define SX_SQUAD_8 (0x0d << 14)
127 1.1 macallan #define SX_SQUAD_16 (0x0e << 14)
128 1.1 macallan #define SX_SQUAD_24 (0x0f << 14)
129 1.1 macallan #define SX_UCHAN_0 (0x10 << 14)
130 1.1 macallan #define SX_UCHAN_8 (0x11 << 14)
131 1.1 macallan #define SX_UCHAN_16 (0x12 << 14)
132 1.1 macallan #define SX_UCHAN_24 (0x13 << 14)
133 1.1 macallan #define SX_SCHAN_0 (0x14 << 14)
134 1.1 macallan #define SX_SCHAN_8 (0x15 << 14)
135 1.1 macallan #define SX_SCHAN_16 (0x16 << 14)
136 1.1 macallan #define SX_SCHAN_24 (0x17 << 14)
137 1.1 macallan #define SX_USHORT_0 (0x18 << 14)
138 1.1 macallan #define SX_USHORT_8 (0x19 << 14)
139 1.1 macallan #define SX_USHORT_16 (0x1a << 14)
140 1.1 macallan #define SX_SSHORT_0 (0x1c << 14)
141 1.1 macallan #define SX_SSHORT_8 (0x1d << 14)
142 1.1 macallan #define SX_SSHORT_16 (0x1e << 14)
143 1.1 macallan #define SX_LONG (0x1b << 14)
144 1.1 macallan #define SX_PACKED (0x1f << 14)
145 1.1 macallan
146 1.1 macallan
147 1.2 macallan #define SX_LD(dreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_LOAD | \
148 1.2 macallan SX_LONG | (dreg << 7) | (o))
149 1.2 macallan #define SX_LDB(dreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_LOAD | \
150 1.2 macallan SX_UBYTE_0 | (dreg << 7) | (o))
151 1.2 macallan #define SX_LDP(dreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_LOAD | \
152 1.2 macallan SX_PACKED | (dreg << 7) | (o))
153 1.7 macallan #define SX_LDUQ0(dreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_LOAD | \
154 1.7 macallan SX_UQUAD_0 | (dreg << 7) | (o))
155 1.7 macallan #define SX_LDUQ8(dreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_LOAD | \
156 1.7 macallan SX_UQUAD_8 | (dreg << 7) | (o))
157 1.7 macallan #define SX_LDUQ16(dreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_LOAD | \
158 1.7 macallan SX_UQUAD_16 | (dreg << 7) | (o))
159 1.7 macallan #define SX_LDUQ24(dreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_LOAD | \
160 1.7 macallan SX_UQUAD_24 | (dreg << 7) | (o))
161 1.2 macallan #define SX_ST(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE | \
162 1.2 macallan SX_LONG | (sreg << 7) | (o))
163 1.6 macallan #define SX_STM(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE_MASK | \
164 1.6 macallan SX_LONG | (sreg << 7) | (o))
165 1.2 macallan #define SX_STB(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE | \
166 1.2 macallan SX_UBYTE_0 | (sreg << 7) | (o))
167 1.2 macallan #define SX_STP(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE | \
168 1.2 macallan SX_PACKED | (sreg << 7) | (o))
169 1.2 macallan #define SX_STS(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE_SELECT \
170 1.2 macallan | SX_LONG | (sreg << 7) | (o))
171 1.2 macallan #define SX_STBS(reg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE_SELECT \
172 1.2 macallan | SX_UBYTE_0 | (reg << 7) | (o))
173 1.7 macallan #define SX_STUQ0(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE | \
174 1.7 macallan SX_UQUAD_0 | (sreg << 7) | (o))
175 1.7 macallan #define SX_STUQ8(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE | \
176 1.7 macallan SX_UQUAD_8 | (sreg << 7) | (o))
177 1.7 macallan #define SX_STUQ16(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE | \
178 1.7 macallan SX_UQUAD_16 | (sreg << 7) | (o))
179 1.7 macallan #define SX_STUQ24(sreg, cnt, o) (0x80000000 | ((cnt) << 23) | SX_STORE | \
180 1.7 macallan SX_UQUAD_24 | (sreg << 7) | (o))
181 1.1 macallan
182 1.7 macallan /* ROP and SELECT instructions */
183 1.3 macallan #define SX_ROPB (0x0 << 21) /* mask bits apply to bytes */
184 1.3 macallan #define SX_ROPM (0x1 << 21) /* mask bits apply to each bit */
185 1.3 macallan #define SX_ROPL (0x2 << 21) /* mask bits apply per register */
186 1.3 macallan #define SX_SELB (0x4 << 21) /* byte select scalar */
187 1.3 macallan #define SX_SELV (0x6 << 21) /* register select vector */
188 1.3 macallan #define SX_SELS (0x7 << 21) /* register select scalar */
189 1.3 macallan
190 1.3 macallan #define SX_ROP(sa, sb, d, cnt) (0x90000000 | ((cnt) << 24) | SX_ROPL | \
191 1.3 macallan ((sa) << 14) | (sb) | ((d) << 7))
192 1.5 macallan #define SX_SELECT_S(sa, sb, d, cnt) (0x90000000 | ((cnt) << 24) | SX_SELS | \
193 1.5 macallan ((sa) << 14) | (sb) | ((d) << 7))
194 1.7 macallan
195 1.7 macallan /* multiply group */
196 1.7 macallan #define SX_M16X16SR0 (0x0 << 28) /* 16bit multiply, no shift */
197 1.7 macallan #define SX_M16X16SR8 (0x1 << 28) /* 16bit multiply, shift right 8 */
198 1.7 macallan #define SX_M16X16SR16 (0x2 << 28) /* 16bit multiply, shift right 16 */
199 1.7 macallan #define SX_M32X16SR0 (0x4 << 28) /* 32x16bit multiply, no shift */
200 1.7 macallan #define SX_M32X16SR8 (0x5 << 28) /* 32x16bit multiply, shift right 8 */
201 1.7 macallan #define SX_M32X16SR16 (0x6 << 28) /* 32x16bit multiply, shift right 16 */
202 1.7 macallan
203 1.7 macallan #define SX_MULTIPLY (0x0 << 21) /* normal multiplication */
204 1.7 macallan #define SX_DOT (0x1 << 21) /* dot product of A and B */
205 1.7 macallan #define SX_SAXP (0x2 << 21) /* A * SCAM + B */
206 1.7 macallan
207 1.7 macallan #define SX_ROUND (0x1 << 23) /* round results */
208 1.7 macallan
209 1.7 macallan #define SX_MUL16X16(sa, sb, d, cnt) (SX_M16X16SR0 | ((cnt) << 24) | \
210 1.7 macallan SX_MULTIPLY | ((sa) << 14) | ((sb) << 7) | (d))
211 1.7 macallan #define SX_MUL16X16R(sa, sb, d, cnt) (SX_M16X16SR0 | ((cnt) << 24) | \
212 1.7 macallan SX_MULTIPLY | ((sa) << 14) | ((sb) << 7) | (d) | SX_ROUND)
213 1.7 macallan #define SX_MUL16X16SR8(sa, sb, d, cnt) (SX_M16X16SR8 | ((cnt) << 24) | \
214 1.7 macallan SX_MULTIPLY | ((sa) << 14) | ((sb) << 7) | (d))
215 1.7 macallan #define SX_MUL16X16SR8R(sa, sb, d, cnt) (SX_M16X16SR8 | ((cnt) << 24) | \
216 1.7 macallan SX_MULTIPLY | ((sa) << 14) | ((sb) << 7) | (d) | SX_ROUND)
217 1.7 macallan
218 1.7 macallan #define SX_SAXP16X16(sa, sb, d, cnt) (SX_M16X16SR0 | ((cnt) << 24) | \
219 1.7 macallan SX_SAXP | ((sa) << 14) | ((sb) << 7) | (d))
220 1.7 macallan #define SX_SAXP16X16R(sa, sb, d, cnt) (SX_M16X16SR0 | ((cnt) << 24) | \
221 1.7 macallan SX_SAXP | ((sa) << 14) | ((sb) << 7) | (d) | SX_ROUND)
222 1.7 macallan #define SX_SAXP16X16SR8(sa, sb, d, cnt) (SX_M16X16SR8 | ((cnt) << 24) | \
223 1.7 macallan SX_SAXP | ((sa) << 14) | ((sb) << 7) | (d))
224 1.7 macallan #define SX_SAXP16X16SR8R(sa, sb, d, cnt) (SX_M16X16SR8 | ((cnt) << 24) | \
225 1.7 macallan SX_SAXP | ((sa) << 14) | ((sb) << 7) | (d) | SX_ROUND)
226 1.7 macallan
227 1.7 macallan /* logic group */
228 1.7 macallan #define SX_AND_V (0x0 << 21) /* vector AND vector */
229 1.7 macallan #define SX_AND_S (0x1 << 21) /* vector AND scalar */
230 1.7 macallan #define SX_AND_I (0x2 << 21) /* vector AND immediate */
231 1.7 macallan #define SX_XOR_V (0x3 << 21) /* vector XOR vector */
232 1.7 macallan #define SX_XOR_S (0x4 << 21) /* vector XOR scalar */
233 1.7 macallan #define SX_XOR_I (0x5 << 21) /* vector XOR immediate */
234 1.7 macallan #define SX_OR_V (0x6 << 21) /* vector OR vector */
235 1.7 macallan #define SX_OR_S (0x7 << 21) /* vector OR scalar */
236 1.7 macallan /* immediates are 7bit sign extended to 32bit */
237 1.7 macallan
238 1.7 macallan #define SX_ANDV(sa, sb, d, cnt) (0xb0000000 | ((cnt) << 24) | SX_AND_V | \
239 1.7 macallan ((sa) << 14) | ((sb) << 7) | (d))
240 1.7 macallan #define SX_ANDS(sa, sb, d, cnt) (0xb0000000 | ((cnt) << 24) | SX_AND_S | \
241 1.7 macallan ((sa) << 14) | ((sb) << 7) | (d))
242 1.7 macallan #define SX_ANDI(sa, sb, d, cnt) (0xb0000000 | ((cnt) << 24) | SX_AND_I | \
243 1.7 macallan ((sa) << 14) | ((sb) << 7) | (d))
244 1.7 macallan #define SX_XORV(sa, sb, d, cnt) (0xb0000000 | ((cnt) << 24) | SX_XOR_V | \
245 1.7 macallan ((sa) << 14) | ((sb) << 7) | (d))
246 1.7 macallan #define SX_XORS(sa, sb, d, cnt) (0xb0000000 | ((cnt) << 24) | SX_XOR_S | \
247 1.7 macallan ((sa) << 14) | ((sb) << 7) | (d))
248 1.7 macallan #define SX_XORI(sa, sb, d, cnt) (0xb0000000 | ((cnt) << 24) | SX_XOR_I | \
249 1.7 macallan ((sa) << 14) | ((sb) << 7) | (d))
250 1.7 macallan #define SX_ORV(sa, sb, d, cnt) (0xb0000000 | ((cnt) << 24) | SX_OR_V | \
251 1.7 macallan ((sa) << 14) | ((sb) << 7) | (d))
252 1.7 macallan #define SX_ORS(sa, sb, d, cnt) (0xb0000000 | ((cnt) << 24) | SX_OR_S | \
253 1.7 macallan ((sa) << 14) | ((sb) << 7) | (d))
254 1.7 macallan
255 1.1 macallan #endif /* SXREG_H */
256