1 |
205 |
julius |
; IQ10-only CPU description. -*- Scheme -*-
|
2 |
|
|
;
|
3 |
|
|
; Copyright 2001, 2002, 2007, 2009 Free Software Foundation, Inc.
|
4 |
|
|
;
|
5 |
|
|
; Contributed by Red Hat Inc; developed under contract from Vitesse.
|
6 |
|
|
;
|
7 |
|
|
; This file is part of the GNU Binutils.
|
8 |
|
|
;
|
9 |
|
|
; This program is free software; you can redistribute it and/or modify
|
10 |
|
|
; it under the terms of the GNU General Public License as published by
|
11 |
|
|
; the Free Software Foundation; either version 3 of the License, or
|
12 |
|
|
; (at your option) any later version.
|
13 |
|
|
;
|
14 |
|
|
; This program is distributed in the hope that it will be useful,
|
15 |
|
|
; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
16 |
|
|
; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
17 |
|
|
; GNU General Public License for more details.
|
18 |
|
|
;
|
19 |
|
|
; You should have received a copy of the GNU General Public License
|
20 |
|
|
; along with this program; if not, write to the Free Software
|
21 |
|
|
; Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
|
22 |
|
|
; MA 02110-1301, USA.
|
23 |
|
|
|
24 |
|
|
|
25 |
|
|
; Instructions.
|
26 |
|
|
|
27 |
|
|
(dni andoui-q10 "iq10 and upper ones immediate" (MACH10 USES-RS USES-RT)
|
28 |
|
|
"andoui $rt,$rs,$hi16"
|
29 |
|
|
(+ OP10_ANDOUI rs rt hi16)
|
30 |
|
|
(set rt (and rs (or (sll hi16 16) #xFFFF)))
|
31 |
|
|
())
|
32 |
|
|
|
33 |
|
|
(dni andoui2-q10 "iq10 and upper ones immediate" (ALIAS NO-DIS MACH10 USES-RS USES-RT)
|
34 |
|
|
"andoui ${rt-rs},$hi16"
|
35 |
|
|
(+ OP10_ANDOUI rt-rs hi16)
|
36 |
|
|
(set rt-rs (and rt-rs (or (sll hi16 16) #xFFFF)))
|
37 |
|
|
())
|
38 |
|
|
|
39 |
|
|
(dni orui-q10 "or upper immediate" (MACH10 USES-RS USES-RT)
|
40 |
|
|
"orui $rt,$rs,$hi16"
|
41 |
|
|
(+ OP10_ORUI rs rt hi16)
|
42 |
|
|
(set rt (or rs (sll hi16 16)))
|
43 |
|
|
())
|
44 |
|
|
|
45 |
|
|
(dni orui2-q10 "or upper immediate" (ALIAS NO-DIS MACH10 USES-RS USES-RT)
|
46 |
|
|
"orui ${rt-rs},$hi16"
|
47 |
|
|
(+ OP10_ORUI rt-rs hi16)
|
48 |
|
|
(set rt-rs (or rt-rs (sll hi16 16)))
|
49 |
|
|
())
|
50 |
|
|
|
51 |
|
|
(dni mrgbq10 "merge bytes" (MACH10 USES-RD USES-RS USES-RT)
|
52 |
|
|
"mrgb $rd,$rs,$rt,$maskq10"
|
53 |
|
|
(+ OP_SPECIAL rs rt rd maskq10 FUNC_MRGB)
|
54 |
|
|
(sequence ((SI temp))
|
55 |
|
|
(if (bitclear? mask 0)
|
56 |
|
|
(set temp (and rs #xFF))
|
57 |
|
|
(set temp (and rt #xFF)))
|
58 |
|
|
(if (bitclear? mask 1)
|
59 |
|
|
(set temp (or temp (and rs #xFF00)))
|
60 |
|
|
(set temp (or temp (and rt #xFF00))))
|
61 |
|
|
(if (bitclear? mask 2)
|
62 |
|
|
(set temp (or temp (and rs #xFF0000)))
|
63 |
|
|
(set temp (or temp (and rt #xFF0000))))
|
64 |
|
|
(if (bitclear? mask 3)
|
65 |
|
|
(set temp (or temp (and rs #xFF000000)))
|
66 |
|
|
(set temp (or temp (and rt #xFF000000))))
|
67 |
|
|
(set rd temp))
|
68 |
|
|
())
|
69 |
|
|
|
70 |
|
|
(dni mrgbq102 "merge bytes" (ALIAS NO-DIS MACH10 USES-RD USES-RS USES-RT)
|
71 |
|
|
"mrgb ${rd-rs},$rt,$maskq10"
|
72 |
|
|
(+ OP_SPECIAL rt rd-rs maskq10 FUNC_MRGB)
|
73 |
|
|
(sequence ((SI temp))
|
74 |
|
|
(if (bitclear? mask 0)
|
75 |
|
|
(set temp (and rd-rs #xFF))
|
76 |
|
|
(set temp (and rt #xFF)))
|
77 |
|
|
(if (bitclear? mask 1)
|
78 |
|
|
(set temp (or temp (and rd-rs #xFF00)))
|
79 |
|
|
(set temp (or temp (and rt #xFF00))))
|
80 |
|
|
(if (bitclear? mask 2)
|
81 |
|
|
(set temp (or temp (and rd-rs #xFF0000)))
|
82 |
|
|
(set temp (or temp (and rt #xFF0000))))
|
83 |
|
|
(if (bitclear? mask 3)
|
84 |
|
|
(set temp (or temp (and rd-rs #xFF000000)))
|
85 |
|
|
(set temp (or temp (and rt #xFF000000))))
|
86 |
|
|
(set rd-rs temp))
|
87 |
|
|
())
|
88 |
|
|
|
89 |
|
|
; In the future, we'll want the j & jal to use the 21 bit target, with
|
90 |
|
|
; the upper five bits shifted up. For now, give 'em the 16 bit target.
|
91 |
|
|
|
92 |
|
|
(dni jq10 "jump" (MACH10)
|
93 |
|
|
"j $jmptarg"
|
94 |
|
|
(+ OP_J (f-rs 0) (f-rt 0) jmptarg)
|
95 |
|
|
; "j $jmptargq10"
|
96 |
|
|
; (+ OP_J upper-5-jmptargq10 (f-rt 0) lower-16-jmptargq10)
|
97 |
|
|
(delay 1 (set pc jmptarg))
|
98 |
|
|
())
|
99 |
|
|
|
100 |
|
|
(dni jalq10 "jump and link" (MACH10 USES-RT)
|
101 |
|
|
"jal $rt,$jmptarg"
|
102 |
|
|
(+ OP_JAL (f-rs 0) rt jmptarg)
|
103 |
|
|
; "jal $rt,$jmptargq10"
|
104 |
|
|
; (+ OP_JAL upper-5-jmptargq10 rt lower-16-jmptargq10)
|
105 |
|
|
(delay 1
|
106 |
|
|
(sequence ()
|
107 |
|
|
(set rt (add pc 8))
|
108 |
|
|
(set pc jmptarg)))
|
109 |
|
|
())
|
110 |
|
|
|
111 |
|
|
(dni jalq10-2 "jump and link, implied r31" (MACH10 USES-RT)
|
112 |
|
|
"jal $jmptarg"
|
113 |
|
|
(+ OP_JAL (f-rs 0) (f-rt 31) jmptarg)
|
114 |
|
|
(delay 1
|
115 |
|
|
(sequence ()
|
116 |
|
|
(set rt (add pc 8))
|
117 |
|
|
(set pc jmptarg)))
|
118 |
|
|
())
|
119 |
|
|
|
120 |
|
|
; Branch instructions.
|
121 |
|
|
|
122 |
|
|
(dni bbil "branch bit immediate likely" (MACH10 USES-RS)
|
123 |
|
|
"bbil $rs($bitnum),$offset"
|
124 |
|
|
(+ OP10_BBIL rs bitnum offset)
|
125 |
|
|
(if (bitset? rs bitnum)
|
126 |
|
|
(delay 1 (set pc offset))
|
127 |
|
|
(skip 1))
|
128 |
|
|
())
|
129 |
|
|
|
130 |
|
|
(dni bbinl "branch bit immediate negated likely" (MACH10 USES-RS)
|
131 |
|
|
"bbinl $rs($bitnum),$offset"
|
132 |
|
|
(+ OP10_BBINL rs bitnum offset)
|
133 |
|
|
(if (bitclear? rs bitnum)
|
134 |
|
|
(delay 1 (set pc offset))
|
135 |
|
|
(skip 1))
|
136 |
|
|
())
|
137 |
|
|
|
138 |
|
|
(dni bbvl "branch bit variable likely" (MACH10 USES-RS USES-RT)
|
139 |
|
|
"bbvl $rs,$rt,$offset"
|
140 |
|
|
(+ OP10_BBVL rs rt offset)
|
141 |
|
|
(if (bitset? rs (and rt #x1F))
|
142 |
|
|
(delay 1 (set pc offset))
|
143 |
|
|
(skip 1))
|
144 |
|
|
())
|
145 |
|
|
|
146 |
|
|
(dni bbvnl "branch bit variable negated likely" (MACH10 USES-RS USES-RT)
|
147 |
|
|
"bbvnl $rs,$rt,$offset"
|
148 |
|
|
(+ OP10_BBVNL rs rt offset)
|
149 |
|
|
(if (bitclear? rs (and rt #x1F))
|
150 |
|
|
(delay 1 (set pc offset))
|
151 |
|
|
(skip 1))
|
152 |
|
|
())
|
153 |
|
|
|
154 |
|
|
(dni bgtzal "branch if greater than zero and link" (MACH10 USES-RS USES-R31)
|
155 |
|
|
"bgtzal $rs,$offset"
|
156 |
|
|
(+ OP_REGIMM rs FUNC_BGTZAL offset)
|
157 |
|
|
(if (gt rs 0)
|
158 |
|
|
(sequence ()
|
159 |
|
|
(set (reg h-gr 31) (add pc 8))
|
160 |
|
|
(delay 1 (set pc offset))))
|
161 |
|
|
())
|
162 |
|
|
|
163 |
|
|
(dni bgtzall
|
164 |
|
|
"branch if greater than zero and link likely" (MACH10 USES-RS USES-R31)
|
165 |
|
|
"bgtzall $rs,$offset"
|
166 |
|
|
(+ OP_REGIMM rs FUNC_BGTZALL offset)
|
167 |
|
|
(if (gt rs 0)
|
168 |
|
|
(sequence ()
|
169 |
|
|
(set (reg h-gr 31) (add pc 8))
|
170 |
|
|
(delay 1 (set pc offset)))
|
171 |
|
|
(skip 1))
|
172 |
|
|
())
|
173 |
|
|
|
174 |
|
|
(dni blezal "branch if less than or equal to zero and link" (MACH10 USES-RS USES-R31)
|
175 |
|
|
"blezal $rs,$offset"
|
176 |
|
|
(+ OP_REGIMM rs FUNC_BLEZAL offset)
|
177 |
|
|
(if (le rs 0)
|
178 |
|
|
(sequence ()
|
179 |
|
|
(set (reg h-gr 31) (add pc 8))
|
180 |
|
|
(delay 1 (set pc offset))))
|
181 |
|
|
())
|
182 |
|
|
|
183 |
|
|
(dni blezall
|
184 |
|
|
"branch if less than or equal to zero and link likely" (MACH10 USES-RS USES-R31)
|
185 |
|
|
"blezall $rs,$offset"
|
186 |
|
|
(+ OP_REGIMM rs FUNC_BLEZALL offset)
|
187 |
|
|
(if (le rs 0)
|
188 |
|
|
(sequence ()
|
189 |
|
|
(set (reg h-gr 31) (add pc 8))
|
190 |
|
|
(delay 1 (set pc offset)))
|
191 |
|
|
(skip 1))
|
192 |
|
|
())
|
193 |
|
|
|
194 |
|
|
(dni bgtz-q10 "branch if greater than zero" (MACH10 USES-RS)
|
195 |
|
|
"bgtz $rs,$offset"
|
196 |
|
|
(+ OP_REGIMM rs FUNC_BGTZ offset)
|
197 |
|
|
(if (gt rs 0)
|
198 |
|
|
(delay 1 (set pc offset)))
|
199 |
|
|
())
|
200 |
|
|
|
201 |
|
|
(dni bgtzl-q10 "branch if greater than zero likely" (MACH10 USES-RS)
|
202 |
|
|
"bgtzl $rs,$offset"
|
203 |
|
|
(+ OP_REGIMM rs FUNC_BGTZL offset)
|
204 |
|
|
(if (gt rs 0)
|
205 |
|
|
(delay 1 (set pc offset))
|
206 |
|
|
(skip 1))
|
207 |
|
|
())
|
208 |
|
|
|
209 |
|
|
|
210 |
|
|
(dni blez-q10 "branch if less than or equal to zero" (MACH10 USES-RS)
|
211 |
|
|
"blez $rs,$offset"
|
212 |
|
|
(+ OP_REGIMM rs FUNC_BLEZ offset)
|
213 |
|
|
(if (le rs 0)
|
214 |
|
|
(delay 1 (set pc offset)))
|
215 |
|
|
())
|
216 |
|
|
|
217 |
|
|
(dni blezl-q10 "branch if less than or equal to zero likely" (MACH10 USES-RS)
|
218 |
|
|
"blezl $rs,$offset"
|
219 |
|
|
(+ OP_REGIMM rs FUNC_BLEZL offset)
|
220 |
|
|
(if (le rs 0)
|
221 |
|
|
(delay 1 (set pc offset))
|
222 |
|
|
(skip 1))
|
223 |
|
|
())
|
224 |
|
|
|
225 |
|
|
(dni bmb-q10 "branch if matching byte-lane" (MACH10 USES-RS USES-RT)
|
226 |
|
|
"bmb $rs,$rt,$offset"
|
227 |
|
|
(+ OP10_BMB rs rt offset)
|
228 |
|
|
(sequence ((BI branch?))
|
229 |
|
|
(set branch? 0)
|
230 |
|
|
(if (eq (and rs #xFF) (and rt #xFF))
|
231 |
|
|
(set branch? 1))
|
232 |
|
|
(if (eq (and rs #xFF00) (and rt #xFF00))
|
233 |
|
|
(set branch? 1))
|
234 |
|
|
(if (eq (and rs #xFF0000) (and rt #xFF0000))
|
235 |
|
|
(set branch? 1))
|
236 |
|
|
(if (eq (and rs #xFF000000) (and rt #xFF000000))
|
237 |
|
|
(set branch? 1))
|
238 |
|
|
(if branch?
|
239 |
|
|
(delay 1 (set pc offset))))
|
240 |
|
|
())
|
241 |
|
|
|
242 |
|
|
(dni bmbl "branch if matching byte-lane likely" (MACH10 USES-RS USES-RT)
|
243 |
|
|
"bmbl $rs,$rt,$offset"
|
244 |
|
|
(+ OP10_BMBL rs rt offset)
|
245 |
|
|
(sequence ((BI branch?))
|
246 |
|
|
(set branch? 0)
|
247 |
|
|
(if (eq (and rs #xFF) (and rt #xFF))
|
248 |
|
|
(set branch? 1))
|
249 |
|
|
(if (eq (and rs #xFF00) (and rt #xFF00))
|
250 |
|
|
(set branch? 1))
|
251 |
|
|
(if (eq (and rs #xFF0000) (and rt #xFF0000))
|
252 |
|
|
(set branch? 1))
|
253 |
|
|
(if (eq (and rs #xFF000000) (and rt #xFF000000))
|
254 |
|
|
(set branch? 1))
|
255 |
|
|
(if branch?
|
256 |
|
|
(delay 1 (set pc offset))
|
257 |
|
|
(skip 1)))
|
258 |
|
|
())
|
259 |
|
|
|
260 |
|
|
(dni bri "branch if register invalid" (MACH10 USES-RS)
|
261 |
|
|
"bri $rs,$offset"
|
262 |
|
|
(+ OP_REGIMM rs FUNC_BRI offset)
|
263 |
|
|
(if (gt rs 0)
|
264 |
|
|
(delay 1 (set pc offset))
|
265 |
|
|
(skip 1))
|
266 |
|
|
())
|
267 |
|
|
|
268 |
|
|
(dni brv "branch if register invalid" (MACH10 USES-RS)
|
269 |
|
|
"brv $rs,$offset"
|
270 |
|
|
(+ OP_REGIMM rs FUNC_BRV offset)
|
271 |
|
|
(if (gt rs 0)
|
272 |
|
|
(delay 1 (set pc offset))
|
273 |
|
|
(skip 1))
|
274 |
|
|
())
|
275 |
|
|
|
276 |
|
|
; debug instructions
|
277 |
|
|
|
278 |
|
|
(dni bctx "branch if the current context == instruction[21]" (MACH10 USES-RS)
|
279 |
|
|
"bctx $rs,$offset"
|
280 |
|
|
(+ OP_REGIMM rs FUNC_BCTX offset)
|
281 |
|
|
(delay 1 (set pc offset))
|
282 |
|
|
())
|
283 |
|
|
|
284 |
|
|
(dni yield "unconditional yield to the other context" (MACH10)
|
285 |
|
|
"yield"
|
286 |
|
|
(+ OP_SPECIAL (f-rs 0) (f-rt 0) (f-rd 0) (f-shamt 0) FUNC10_YIELD)
|
287 |
|
|
(unimp yield)
|
288 |
|
|
())
|
289 |
|
|
|
290 |
|
|
; Special instructions.
|
291 |
|
|
|
292 |
|
|
(dni crc32 "CRC, 32 bit input" (MACH10 USES-RD USES-RS USES-RT)
|
293 |
|
|
"crc32 $rd,$rs,$rt"
|
294 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_CRC32)
|
295 |
|
|
(unimp crc32)
|
296 |
|
|
())
|
297 |
|
|
|
298 |
|
|
(dni crc32b "CRC, 8 bit input" (MACH10 USES-RD USES-RS USES-RT)
|
299 |
|
|
"crc32b $rd,$rs,$rt"
|
300 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_CRC32B)
|
301 |
|
|
(unimp crc32b)
|
302 |
|
|
())
|
303 |
|
|
|
304 |
|
|
(dni cnt1s "Count ones" (MACH10 USES-RD USES-RS)
|
305 |
|
|
"cnt1s $rd,$rs"
|
306 |
|
|
(+ OP_SPECIAL rs rt rd (f-shamt 0) FUNC10_CNT1S)
|
307 |
|
|
(unimp crcp)
|
308 |
|
|
())
|
309 |
|
|
|
310 |
|
|
|
311 |
|
|
; Special Instructions
|
312 |
|
|
|
313 |
|
|
(dni avail "Mark Header Buffer Available" (MACH10 USES-RD)
|
314 |
|
|
"avail $rd"
|
315 |
|
|
(+ OP_COP3 (f-rs 0) (f-rt 0) rd (f-shamt 0) FUNC10_AVAIL)
|
316 |
|
|
(unimp avail)
|
317 |
|
|
())
|
318 |
|
|
|
319 |
|
|
(dni free "Mark Header Buffer Free" (MACH10 USES-RS USES-RD)
|
320 |
|
|
"free $rd,$rs"
|
321 |
|
|
(+ OP_COP3 rs (f-rt 0) rd (f-shamt 0) FUNC10_FREE)
|
322 |
|
|
(unimp free)
|
323 |
|
|
())
|
324 |
|
|
|
325 |
|
|
(dni tstod "Test Header Buffer Order Dependency" (MACH10 USES-RS USES-RD)
|
326 |
|
|
"tstod $rd,$rs"
|
327 |
|
|
(+ OP_COP3 rs (f-rt 0) rd (f-shamt 0) FUNC10_TSTOD)
|
328 |
|
|
(unimp tstod)
|
329 |
|
|
())
|
330 |
|
|
|
331 |
|
|
(dni cmphdr "Get a Complete Header" (MACH10 USES-RD)
|
332 |
|
|
"cmphdr $rd"
|
333 |
|
|
(+ OP_COP3 (f-rs 0) (f-rt 0) rd (f-shamt 0) FUNC10_CMPHDR)
|
334 |
|
|
(unimp cmphdr)
|
335 |
|
|
())
|
336 |
|
|
|
337 |
|
|
(dni mcid "Allocate a Multicast ID" (MACH10 USES-RD USES-RT)
|
338 |
|
|
"mcid $rd,$rt"
|
339 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-shamt 0) FUNC10_MCID)
|
340 |
|
|
(unimp mcid)
|
341 |
|
|
())
|
342 |
|
|
|
343 |
|
|
(dni dba "Allocate a Data Buffer Pointer" (MACH10 USES-RD)
|
344 |
|
|
"dba $rd"
|
345 |
|
|
(+ OP_COP3 (f-rs 0) (f-rt 0) rd (f-shamt 0) FUNC10_DBA)
|
346 |
|
|
(unimp dba)
|
347 |
|
|
())
|
348 |
|
|
|
349 |
|
|
(dni dbd "Deallocate a Data Buffer Pointer" (MACH10 USES-RS USES-RT USES-RD)
|
350 |
|
|
"dbd $rd,$rs,$rt"
|
351 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_DBD)
|
352 |
|
|
(unimp dbd)
|
353 |
|
|
())
|
354 |
|
|
|
355 |
|
|
(dni dpwt "DSTN_PORT Write" (MACH10 USES-RS USES-RD)
|
356 |
|
|
"dpwt $rd,$rs"
|
357 |
|
|
(+ OP_COP3 rs (f-rt 0) rd (f-shamt 0) FUNC10_DPWT)
|
358 |
|
|
(unimp dpwt)
|
359 |
|
|
())
|
360 |
|
|
|
361 |
|
|
; Architectural and coprocessor instructions.
|
362 |
|
|
|
363 |
|
|
(dni chkhdrq10 "" (MACH10 USES-RS USES-RD)
|
364 |
|
|
"chkhdr $rd,$rs"
|
365 |
|
|
(+ OP_COP3 rs (f-rt 0) rd (f-shamt 0) FUNC10_CHKHDR)
|
366 |
|
|
(unimp chkhdr)
|
367 |
|
|
())
|
368 |
|
|
|
369 |
|
|
; Coprocessor DMA Instructions (IQ10)
|
370 |
|
|
|
371 |
|
|
(dni rba "Read Bytes Absolute" (MACH10 USES-RS USES-RT USES-RD)
|
372 |
|
|
"rba $rd,$rs,$rt"
|
373 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_RBA)
|
374 |
|
|
(unimp rba)
|
375 |
|
|
())
|
376 |
|
|
|
377 |
|
|
(dni rbal "Read Bytes Absolute and Lock" (MACH10 USES-RS USES-RT USES-RD)
|
378 |
|
|
"rbal $rd,$rs,$rt"
|
379 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_RBAL)
|
380 |
|
|
(unimp rbal)
|
381 |
|
|
())
|
382 |
|
|
|
383 |
|
|
(dni rbar "Read Bytes Absolute and Release" (MACH10 USES-RS USES-RT USES-RD)
|
384 |
|
|
"rbar $rd,$rs,$rt"
|
385 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_RBAR)
|
386 |
|
|
(unimp rbar)
|
387 |
|
|
())
|
388 |
|
|
|
389 |
|
|
(dni wba "Write Bytes Absolute" (MACH10 USES-RS USES-RT USES-RD)
|
390 |
|
|
"wba $rd,$rs,$rt"
|
391 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_WBA)
|
392 |
|
|
(unimp wba)
|
393 |
|
|
())
|
394 |
|
|
|
395 |
|
|
(dni wbau "Write Bytes Absolute and Unlock" (MACH10 USES-RS USES-RT USES-RD)
|
396 |
|
|
"wbau $rd,$rs,$rt"
|
397 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_WBAU)
|
398 |
|
|
(unimp wbau)
|
399 |
|
|
())
|
400 |
|
|
|
401 |
|
|
(dni wbac "Write Bytes Absolute Cacheable" (MACH10 USES-RS USES-RT USES-RD)
|
402 |
|
|
"wbac $rd,$rs,$rt"
|
403 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_WBAC)
|
404 |
|
|
(unimp wbac)
|
405 |
|
|
())
|
406 |
|
|
|
407 |
|
|
(dni rbi "Read Bytes Immediate" (MACH10 USES-RD USES-RS USES-RT)
|
408 |
|
|
"rbi $rd,$rs,$rt,$bytecount"
|
409 |
|
|
(+ OP_COP3 rs rt rd FUNC10_RBI bytecount)
|
410 |
|
|
(unimp rbi)
|
411 |
|
|
())
|
412 |
|
|
|
413 |
|
|
(dni rbil "Read Bytes Immediate and Lock" (MACH10 USES-RD USES-RS USES-RT)
|
414 |
|
|
"rbil $rd,$rs,$rt,$bytecount"
|
415 |
|
|
(+ OP_COP3 rs rt rd FUNC10_RBIL bytecount)
|
416 |
|
|
(unimp rbil)
|
417 |
|
|
())
|
418 |
|
|
|
419 |
|
|
(dni rbir "Read Bytes Immediate and Release" (MACH10 USES-RD USES-RS USES-RT)
|
420 |
|
|
"rbir $rd,$rs,$rt,$bytecount"
|
421 |
|
|
(+ OP_COP3 rs rt rd FUNC10_RBIR bytecount)
|
422 |
|
|
(unimp rbir)
|
423 |
|
|
())
|
424 |
|
|
|
425 |
|
|
(dni wbi "Write Bytes Immediate" (MACH10 USES-RD USES-RS USES-RT)
|
426 |
|
|
"wbi $rd,$rs,$rt,$bytecount"
|
427 |
|
|
(+ OP_COP3 rs rt rd FUNC10_WBI bytecount)
|
428 |
|
|
(unimp wbi)
|
429 |
|
|
())
|
430 |
|
|
|
431 |
|
|
(dni wbic "Write Bytes Immediate Cacheable" (MACH10 USES-RD USES-RS USES-RT)
|
432 |
|
|
"wbic $rd,$rs,$rt,$bytecount"
|
433 |
|
|
(+ OP_COP3 rs rt rd FUNC10_WBIC bytecount)
|
434 |
|
|
(unimp wbic)
|
435 |
|
|
())
|
436 |
|
|
|
437 |
|
|
(dni wbiu "Write Bytes Immediate" (MACH10 USES-RD USES-RS USES-RT)
|
438 |
|
|
"wbiu $rd,$rs,$rt,$bytecount"
|
439 |
|
|
(+ OP_COP3 rs rt rd FUNC10_WBIU bytecount)
|
440 |
|
|
(unimp wbiu)
|
441 |
|
|
())
|
442 |
|
|
|
443 |
|
|
(dni pkrli "Packet Release Immediate" (MACH10 USES-RD USES-RS USES-RT)
|
444 |
|
|
"pkrli $rd,$rs,$rt,$bytecount"
|
445 |
|
|
(+ OP_COP2 rs rt rd FUNC10_PKRLI bytecount)
|
446 |
|
|
(unimp pkrli)
|
447 |
|
|
())
|
448 |
|
|
|
449 |
|
|
(dni pkrlih "Packet Release Immediate and Hold" (MACH10 USES-RD USES-RS USES-RT)
|
450 |
|
|
"pkrlih $rd,$rs,$rt,$bytecount"
|
451 |
|
|
(+ OP_COP2 rs rt rd FUNC10_PKRLIH bytecount)
|
452 |
|
|
(unimp pkrlih)
|
453 |
|
|
())
|
454 |
|
|
|
455 |
|
|
(dni pkrliu "Packet Release Immediate Unconditional" (MACH10 USES-RD USES-RS USES-RT)
|
456 |
|
|
"pkrliu $rd,$rs,$rt,$bytecount"
|
457 |
|
|
(+ OP_COP2 rs rt rd FUNC10_PKRLIU bytecount)
|
458 |
|
|
(unimp pkrliu)
|
459 |
|
|
())
|
460 |
|
|
|
461 |
|
|
(dni pkrlic "Packet Release Immediate Continue" (MACH10 USES-RD USES-RS USES-RT)
|
462 |
|
|
"pkrlic $rd,$rs,$rt,$bytecount"
|
463 |
|
|
(+ OP_COP2 rs rt rd FUNC10_PKRLIC bytecount)
|
464 |
|
|
(unimp pkrlic)
|
465 |
|
|
())
|
466 |
|
|
|
467 |
|
|
(dni pkrla "Packet Release Absolute" (MACH10 USES-RS USES-RT USES-RD)
|
468 |
|
|
"pkrla $rd,$rs,$rt"
|
469 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_PKRLA)
|
470 |
|
|
(unimp pkrla)
|
471 |
|
|
())
|
472 |
|
|
|
473 |
|
|
(dni pkrlau "Packet Release Absolute Unconditional" (MACH10 USES-RS USES-RT USES-RD)
|
474 |
|
|
"pkrlau $rd,$rs,$rt"
|
475 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_PKRLAU)
|
476 |
|
|
(unimp pkrlau)
|
477 |
|
|
())
|
478 |
|
|
|
479 |
|
|
(dni pkrlah "Packet Release Absolute and Hold" (MACH10 USES-RS USES-RT USES-RD)
|
480 |
|
|
"pkrlah $rd,$rs,$rt"
|
481 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_PKRLAH)
|
482 |
|
|
(unimp pkrlah)
|
483 |
|
|
())
|
484 |
|
|
|
485 |
|
|
(dni pkrlac "Packet Release Absolute Continue" (MACH10 USES-RS USES-RT USES-RD)
|
486 |
|
|
"pkrlac $rd,$rs,$rt"
|
487 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_PKRLAC)
|
488 |
|
|
(unimp pkrlac)
|
489 |
|
|
())
|
490 |
|
|
|
491 |
|
|
; Main Memory Access Instructions
|
492 |
|
|
|
493 |
|
|
(dni lock "lock memory" (MACH10 USES-RD USES-RT)
|
494 |
|
|
"lock $rd,$rt"
|
495 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-shamt 0) FUNC10_LOCK)
|
496 |
|
|
(unimp lock)
|
497 |
|
|
())
|
498 |
|
|
|
499 |
|
|
(dni unlk "unlock memory" (MACH10 USES-RT USES-RD)
|
500 |
|
|
"unlk $rd,$rt"
|
501 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-shamt 0) FUNC10_UNLK)
|
502 |
|
|
(unimp unlk)
|
503 |
|
|
())
|
504 |
|
|
|
505 |
|
|
(dni swrd "Single Word Read" (MACH10 USES-RT USES-RD)
|
506 |
|
|
"swrd $rd,$rt"
|
507 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-shamt 0) FUNC10_SWRD)
|
508 |
|
|
(unimp swrd)
|
509 |
|
|
())
|
510 |
|
|
|
511 |
|
|
(dni swrdl "Single Word Read and Lock" (MACH10 USES-RT USES-RD)
|
512 |
|
|
"swrdl $rd,$rt"
|
513 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-shamt 0) FUNC10_SWRDL)
|
514 |
|
|
(unimp swrdl)
|
515 |
|
|
())
|
516 |
|
|
|
517 |
|
|
(dni swwr "Single Word Write" (MACH10 USES-RS USES-RT USES-RD)
|
518 |
|
|
"swwr $rd,$rs,$rt"
|
519 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_SWWR)
|
520 |
|
|
(unimp swwr)
|
521 |
|
|
())
|
522 |
|
|
|
523 |
|
|
(dni swwru "Single Word Write and Unlock" (MACH10 USES-RS USES-RT USES-RD)
|
524 |
|
|
"swwru $rd,$rs,$rt"
|
525 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 0) FUNC10_SWWRU)
|
526 |
|
|
(unimp swwru)
|
527 |
|
|
())
|
528 |
|
|
|
529 |
|
|
(dni dwrd "Double Word Read" (MACH10 EVEN-REG-NUM USES-RT USES-RD)
|
530 |
|
|
"dwrd $rd,$rt"
|
531 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-shamt 0) FUNC10_DWRD)
|
532 |
|
|
(unimp dwrd)
|
533 |
|
|
())
|
534 |
|
|
|
535 |
|
|
(dni dwrdl "Double Word Read and Lock" (MACH10 EVEN-REG-NUM USES-RT USES-RD)
|
536 |
|
|
"dwrdl $rd,$rt"
|
537 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-shamt 0) FUNC10_DWRDL)
|
538 |
|
|
(unimp dwrdl)
|
539 |
|
|
())
|
540 |
|
|
|
541 |
|
|
; CAM access instructions (IQ10)
|
542 |
|
|
|
543 |
|
|
(dni cam36 "CAM Access in 36-bit Mode" (MACH10 USES-RT USES-RD)
|
544 |
|
|
"cam36 $rd,$rt,${cam-z},${cam-y}"
|
545 |
|
|
(+ OP_COP3 (f-rs 0) rt rd FUNC10_CAM36 cam-z cam-y)
|
546 |
|
|
(unimp cam36)
|
547 |
|
|
())
|
548 |
|
|
|
549 |
|
|
(dni cam72 "CAM Access in 72-bit Mode" (MACH10 USES-RT USES-RD)
|
550 |
|
|
"cam72 $rd,$rt,${cam-y},${cam-z}"
|
551 |
|
|
(+ OP_COP3 (f-rs 0) rt rd FUNC10_CAM72 cam-z cam-y)
|
552 |
|
|
(unimp cam72)
|
553 |
|
|
())
|
554 |
|
|
|
555 |
|
|
(dni cam144 "CAM Access in 144-bit Mode" (MACH10 USES-RT USES-RD)
|
556 |
|
|
"cam144 $rd,$rt,${cam-y},${cam-z}"
|
557 |
|
|
(+ OP_COP3 (f-rs 0) rt rd FUNC10_CAM144 cam-z cam-y)
|
558 |
|
|
(unimp cam144)
|
559 |
|
|
())
|
560 |
|
|
|
561 |
|
|
(dni cam288 "CAM Access in 288-bit Mode" (MACH10 USES-RT USES-RD)
|
562 |
|
|
"cam288 $rd,$rt,${cam-y},${cam-z}"
|
563 |
|
|
(+ OP_COP3 (f-rs 0) rt rd FUNC10_CAM288 cam-z cam-y)
|
564 |
|
|
(unimp cam288)
|
565 |
|
|
())
|
566 |
|
|
|
567 |
|
|
; Counter manager instructions (IQ10)
|
568 |
|
|
|
569 |
|
|
(dni cm32and "Counter Manager And" (MACH10 USES-RS USES-RT USES-RD)
|
570 |
|
|
"cm32and $rd,$rs,$rt"
|
571 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32AND)
|
572 |
|
|
(unimp cm32and)
|
573 |
|
|
())
|
574 |
|
|
|
575 |
|
|
(dni cm32andn "Counter Manager And With Inverse" (MACH10 USES-RS USES-RT USES-RD)
|
576 |
|
|
"cm32andn $rd,$rs,$rt"
|
577 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32ANDN)
|
578 |
|
|
(unimp cm32andn)
|
579 |
|
|
())
|
580 |
|
|
|
581 |
|
|
(dni cm32or "Counter Manager Or" (MACH10 USES-RS USES-RT USES-RD)
|
582 |
|
|
"cm32or $rd,$rs,$rt"
|
583 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32OR)
|
584 |
|
|
(unimp cm32or)
|
585 |
|
|
())
|
586 |
|
|
|
587 |
|
|
(dni cm32ra "Counter Manager 32-bit Rolling Add" (MACH10 USES-RS USES-RT USES-RD)
|
588 |
|
|
"cm32ra $rd,$rs,$rt"
|
589 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 2) FUNC10_CM32RA)
|
590 |
|
|
(unimp cm32ra)
|
591 |
|
|
())
|
592 |
|
|
|
593 |
|
|
(dni cm32rd "Counter Manager 32-bit Rolling Decrement" (MACH10 USES-RT USES-RD)
|
594 |
|
|
"cm32rd $rd,$rt"
|
595 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32RD)
|
596 |
|
|
(unimp cm32rd)
|
597 |
|
|
())
|
598 |
|
|
|
599 |
|
|
(dni cm32ri "Counter Manager 32-bit Rolling Increment" (MACH10 USES-RT USES-RD)
|
600 |
|
|
"cm32ri $rd,$rt"
|
601 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32RI)
|
602 |
|
|
(unimp cm32ri)
|
603 |
|
|
())
|
604 |
|
|
|
605 |
|
|
(dni cm32rs "Counter Manager 32-bit Rolling Subtract" (MACH10 USES-RS USES-RT USES-RD)
|
606 |
|
|
"cm32rs $rd,$rs,$rt"
|
607 |
|
|
(+ OP_COP3 rs rt rd (f-shamt 2) FUNC10_CM32RS)
|
608 |
|
|
(unimp cm32rs)
|
609 |
|
|
())
|
610 |
|
|
|
611 |
|
|
(dni cm32sa "Counter Manager 32-bit Saturating Add" (MACH10 USES-RS USES-RT USES-RD)
|
612 |
|
|
"cm32sa $rd,$rs,$rt"
|
613 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32SA)
|
614 |
|
|
(unimp cm32sa)
|
615 |
|
|
())
|
616 |
|
|
|
617 |
|
|
(dni cm32sd "Counter Manager 32-bit Saturating Decrement" (MACH10 USES-RT USES-RD)
|
618 |
|
|
"cm32sd $rd,$rt"
|
619 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32SD)
|
620 |
|
|
(unimp cm32sd)
|
621 |
|
|
())
|
622 |
|
|
|
623 |
|
|
(dni cm32si "Counter Manager 32-bit Saturating Increment" (MACH10 USES-RT USES-RD)
|
624 |
|
|
"cm32si $rd,$rt"
|
625 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32SI)
|
626 |
|
|
(unimp cm32si)
|
627 |
|
|
())
|
628 |
|
|
|
629 |
|
|
(dni cm32ss "Counter Manager 32-bit Saturating Subtract" (MACH10 USES-RS USES-RT USES-RD)
|
630 |
|
|
"cm32ss $rd,$rs,$rt"
|
631 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32SS)
|
632 |
|
|
(unimp cm32ss)
|
633 |
|
|
())
|
634 |
|
|
|
635 |
|
|
(dni cm32xor "Counter Manager Xor" (MACH10 USES-RS USES-RT USES-RD)
|
636 |
|
|
"cm32xor $rd,$rs,$rt"
|
637 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM32XOR)
|
638 |
|
|
(unimp cm32xor)
|
639 |
|
|
())
|
640 |
|
|
|
641 |
|
|
(dni cm64clr "Counter Manager Clear" (MACH10 EVEN-REG-NUM USES-RT USES-RD)
|
642 |
|
|
"cm64clr $rd,$rt"
|
643 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64CLR)
|
644 |
|
|
(unimp cm64clr)
|
645 |
|
|
())
|
646 |
|
|
|
647 |
|
|
(dni cm64ra "Counter Manager 64-bit Rolling Add" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
648 |
|
|
"cm64ra $rd,$rs,$rt"
|
649 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64RA)
|
650 |
|
|
(unimp cm64ra)
|
651 |
|
|
())
|
652 |
|
|
|
653 |
|
|
(dni cm64rd "Counter Manager 64-bit Rolling Decrement" (MACH10 EVEN-REG-NUM USES-RT USES-RD)
|
654 |
|
|
"cm64rd $rd,$rt"
|
655 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64RD)
|
656 |
|
|
(unimp cm64rd)
|
657 |
|
|
())
|
658 |
|
|
|
659 |
|
|
(dni cm64ri "Counter Manager 32-bit Rolling Increment" (MACH10 EVEN-REG-NUM USES-RT USES-RD)
|
660 |
|
|
"cm64ri $rd,$rt"
|
661 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64RI)
|
662 |
|
|
(unimp cm64ri)
|
663 |
|
|
())
|
664 |
|
|
|
665 |
|
|
(dni cm64ria2 "Counter Manager 32/32 Rolling Increment/Add" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
666 |
|
|
"cm64ria2 $rd,$rs,$rt"
|
667 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64RIA2)
|
668 |
|
|
(unimp cm64ria2)
|
669 |
|
|
())
|
670 |
|
|
|
671 |
|
|
(dni cm64rs "Counter Manager 64-bit Rolling Subtract" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
672 |
|
|
"cm64rs $rd,$rs,$rt"
|
673 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64RS)
|
674 |
|
|
(unimp cm64rs)
|
675 |
|
|
())
|
676 |
|
|
|
677 |
|
|
(dni cm64sa "Counter Manager 64-bit Saturating Add" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
678 |
|
|
"cm64sa $rd,$rs,$rt"
|
679 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64SA)
|
680 |
|
|
(unimp cm64sa)
|
681 |
|
|
())
|
682 |
|
|
|
683 |
|
|
(dni cm64sd "Counter Manager 64-bit Saturating Decrement" (MACH10 EVEN-REG-NUM USES-RT USES-RD)
|
684 |
|
|
"cm64sd $rd,$rt"
|
685 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64SD)
|
686 |
|
|
(unimp cm64sd)
|
687 |
|
|
())
|
688 |
|
|
|
689 |
|
|
(dni cm64si "Counter Manager 64-bit Saturating Increment" (MACH10 EVEN-REG-NUM USES-RT USES-RD)
|
690 |
|
|
"cm64si $rd,$rt"
|
691 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64SI)
|
692 |
|
|
(unimp cm64si)
|
693 |
|
|
())
|
694 |
|
|
|
695 |
|
|
(dni cm64sia2 "Counter Manager 32/32 Saturating Increment/Add" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
696 |
|
|
"cm64sia2 $rd,$rs,$rt"
|
697 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64SIA2)
|
698 |
|
|
(unimp cm64sia2)
|
699 |
|
|
())
|
700 |
|
|
|
701 |
|
|
(dni cm64ss "Counter Manager 64-bit Saturating Subtract" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
702 |
|
|
"cm64ss $rd,$rs,$rt"
|
703 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM64SS)
|
704 |
|
|
(unimp cm64ss)
|
705 |
|
|
())
|
706 |
|
|
|
707 |
|
|
(dni cm128ria2 "Counter Manager 128-bit 64/64 Rolling Increment/Add" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
708 |
|
|
"cm128ria2 $rd,$rs,$rt"
|
709 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM128RIA2)
|
710 |
|
|
(unimp cm128ria2)
|
711 |
|
|
())
|
712 |
|
|
|
713 |
|
|
(dni cm128ria3 "Counter Manager 128-bit 32/32/64 Rolling Increment/Add" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
714 |
|
|
"cm128ria3 $rd,$rs,$rt,${cm-3z}"
|
715 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM128RIA3 cm-3z)
|
716 |
|
|
(unimp cm128ria3)
|
717 |
|
|
())
|
718 |
|
|
|
719 |
|
|
(dni cm128ria4 "Counter Manager 128-bit 32/32/32/32 Rolling Inc/Add" (MACH10 USES-RS USES-RT USES-RD)
|
720 |
|
|
"cm128ria4 $rd,$rs,$rt,${cm-4z}"
|
721 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM128RIA4 cm-4z)
|
722 |
|
|
(unimp cm128ria4)
|
723 |
|
|
())
|
724 |
|
|
|
725 |
|
|
(dni cm128sia2 "Counter Manager 128-bit 64/64 Saturating Inc/Add" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
726 |
|
|
"cm128sia2 $rd,$rs,$rt"
|
727 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM128SIA2)
|
728 |
|
|
(unimp cm128sia2)
|
729 |
|
|
())
|
730 |
|
|
|
731 |
|
|
(dni cm128sia3 "Counter Manager 128-bit 32/32/64 Saturating Inc/Add" (MACH10 EVEN-REG-NUM USES-RS USES-RT USES-RD)
|
732 |
|
|
"cm128sia3 $rd,$rs,$rt,${cm-3z}"
|
733 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM128SIA3 cm-3z)
|
734 |
|
|
(unimp cm128sia3)
|
735 |
|
|
())
|
736 |
|
|
|
737 |
|
|
(dni cm128sia4 "Counter Manager 128-bit 32/32/32/32 Saturating Inc/Add" (MACH10 USES-RS USES-RT USES-RD)
|
738 |
|
|
"cm128sia4 $rd,$rs,$rt,${cm-4z}"
|
739 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM128SIA4 cm-4z)
|
740 |
|
|
(unimp cm128sia4)
|
741 |
|
|
())
|
742 |
|
|
|
743 |
|
|
(dni cm128vsa "Counter Manager Continuous State Dual Leaky Token Bucket Policing" (MACH10 USES-RS USES-RT USES-RD)
|
744 |
|
|
"cm128vsa $rd,$rs,$rt"
|
745 |
|
|
(+ OP_COP3 rs rt rd (f-cp-op 0) (f-cp-grp 2) FUNC10_CM128VSA)
|
746 |
|
|
(unimp cm128vsa)
|
747 |
|
|
())
|
748 |
|
|
|
749 |
|
|
; Coprocessor Data Movement Instructions
|
750 |
|
|
|
751 |
|
|
; Note that we don't set the USES-RD or USES-RT attributes for many of the following
|
752 |
|
|
; instructions, as it's the COP register that's being specified.
|
753 |
|
|
|
754 |
|
|
; ??? Is YIELD-INSN the right attribute for IQ10? The IQ2000 used the attribute to warn about
|
755 |
|
|
; yielding instructions in a delay slot, but that's not relevant in IQ10. What *is* relevant
|
756 |
|
|
; (and unique to IQ10) is instructions that yield if the destination register is accessed
|
757 |
|
|
; before the value is there, causing a yield.
|
758 |
|
|
|
759 |
|
|
(dni cfc "copy from coprocessor control register" (MACH10 LOAD-DELAY USES-RD YIELD-INSN)
|
760 |
|
|
"cfc $rd,$rt"
|
761 |
|
|
(+ OP_COP3 (f-rs 0) rt rd (f-shamt 0) FUNC10_CFC)
|
762 |
|
|
(unimp cfc)
|
763 |
|
|
())
|
764 |
|
|
|
765 |
|
|
(dni ctc "copy to coprocessor control register" (MACH10 USES-RS)
|
766 |
|
|
"ctc $rs,$rt"
|
767 |
|
|
(+ OP_COP3 rs rt (f-rd 0) (f-shamt 0) FUNC10_CTC)
|
768 |
|
|
(unimp ctc)
|
769 |
|
|
())
|
770 |
|
|
|
771 |
|
|
; Macros
|
772 |
|
|
|
773 |
|
|
(dnmi m-avail "Mark Header Buffer Available" (MACH10 NO-DIS)
|
774 |
|
|
"avail"
|
775 |
|
|
(emit avail (f-rd 0))
|
776 |
|
|
)
|
777 |
|
|
|
778 |
|
|
(dnmi m-cam36 "CAM Access in 36-bit Mode" (MACH10 USES-RT USES-RD NO-DIS)
|
779 |
|
|
"cam36 $rd,$rt,${cam-z}"
|
780 |
|
|
(emit cam36 rd rt cam-z (f-cam-y 0))
|
781 |
|
|
)
|
782 |
|
|
|
783 |
|
|
(dnmi m-cam72 "CAM Access in 72-bit Mode" (MACH10 USES-RT USES-RD NO-DIS)
|
784 |
|
|
"cam72 $rd,$rt,${cam-z}"
|
785 |
|
|
(emit cam72 rd rt cam-z (f-cam-y 0))
|
786 |
|
|
)
|
787 |
|
|
|
788 |
|
|
(dnmi m-cam144 "CAM Access in 144-bit Mode" (MACH10 USES-RT USES-RD NO-DIS)
|
789 |
|
|
"cam144 $rd,$rt,${cam-z}"
|
790 |
|
|
(emit cam144 rd rt cam-z (f-cam-y 0))
|
791 |
|
|
)
|
792 |
|
|
|
793 |
|
|
(dnmi m-cam288 "CAM Access in 288-bit Mode" (MACH10 USES-RT USES-RD NO-DIS)
|
794 |
|
|
"cam288 $rd,$rt,${cam-z}"
|
795 |
|
|
(emit cam288 rd rt cam-z (f-cam-y 0))
|
796 |
|
|
)
|
797 |
|
|
|
798 |
|
|
(dnmi m-cm32read "Counter Manager 32-bit Rolling Add R0" (MACH10 USES-RT USES-RD NO-DIS)
|
799 |
|
|
"cm32read $rd,$rt"
|
800 |
|
|
(emit cm32ra rd (f-rs 0) rt)
|
801 |
|
|
)
|
802 |
|
|
|
803 |
|
|
(dnmi m-cm64read "Counter Manager 64-bit Rolling Add R0" (MACH10 USES-RT USES-RD NO-DIS)
|
804 |
|
|
"cm64read $rd,$rt"
|
805 |
|
|
(emit cm64ra rd (f-rs 0) rt)
|
806 |
|
|
)
|
807 |
|
|
|
808 |
|
|
(dnmi m-cm32mlog "Counter Manager 32-bit or R0" (MACH10 USES-RS USES-RT NO-DIS)
|
809 |
|
|
"cm32mlog $rs,$rt"
|
810 |
|
|
(emit cm32or (f-rd 0) rs rt)
|
811 |
|
|
)
|
812 |
|
|
|
813 |
|
|
(dnmi m-cm32and "Counter Manager And" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
814 |
|
|
"cm32and $rs,$rt"
|
815 |
|
|
(emit cm32and (f-rd 0) rs rt)
|
816 |
|
|
)
|
817 |
|
|
|
818 |
|
|
(dnmi m-cm32andn "Counter Manager And With Inverse" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
819 |
|
|
"cm32andn $rs,$rt"
|
820 |
|
|
(emit cm32andn (f-rd 0) rs rt)
|
821 |
|
|
)
|
822 |
|
|
|
823 |
|
|
(dnmi m-cm32or "Counter Manager Or" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
824 |
|
|
"cm32or $rs,$rt"
|
825 |
|
|
(emit cm32or (f-rd 0) rs rt)
|
826 |
|
|
)
|
827 |
|
|
|
828 |
|
|
(dnmi m-cm32ra "Counter Manager 32-bit Rolling Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
829 |
|
|
"cm32ra $rs,$rt"
|
830 |
|
|
(emit cm32ra (f-rd 0) rs rt)
|
831 |
|
|
)
|
832 |
|
|
|
833 |
|
|
(dnmi m-cm32rd "Counter Manager 32-bit Rolling Decrement" (MACH10 USES-RT USES-RD NO-DIS)
|
834 |
|
|
"cm32rd $rt"
|
835 |
|
|
(emit cm32rd (f-rd 0) rt)
|
836 |
|
|
)
|
837 |
|
|
|
838 |
|
|
(dnmi m-cm32ri "Counter Manager 32-bit Rolling Increment" (MACH10 USES-RT USES-RD NO-DIS)
|
839 |
|
|
"cm32ri $rt"
|
840 |
|
|
(emit cm32ri (f-rd 0) rt)
|
841 |
|
|
)
|
842 |
|
|
|
843 |
|
|
(dnmi m-cm32rs "Counter Manager 32-bit Rolling Subtract" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
844 |
|
|
"cm32rs $rs,$rt"
|
845 |
|
|
(emit cm32rs (f-rd 0) rs rt)
|
846 |
|
|
)
|
847 |
|
|
|
848 |
|
|
(dnmi m-cm32sa "Counter Manager 32-bit Saturating Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
849 |
|
|
"cm32sa $rs,$rt"
|
850 |
|
|
(emit cm32sa (f-rd 0) rs rt)
|
851 |
|
|
)
|
852 |
|
|
|
853 |
|
|
(dnmi m-cm32sd "Counter Manager 32-bit Saturating Decrement" (MACH10 USES-RT USES-RD NO-DIS)
|
854 |
|
|
"cm32sd $rt"
|
855 |
|
|
(emit cm32sd (f-rd 0) rt)
|
856 |
|
|
)
|
857 |
|
|
|
858 |
|
|
(dnmi m-cm32si "Counter Manager 32-bit Saturating Increment" (MACH10 USES-RT USES-RD NO-DIS)
|
859 |
|
|
"cm32si $rt"
|
860 |
|
|
(emit cm32si (f-rd 0) rt)
|
861 |
|
|
)
|
862 |
|
|
|
863 |
|
|
(dnmi m-cm32ss "Counter Manager 32-bit Saturating Subtract" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
864 |
|
|
"cm32ss $rs,$rt"
|
865 |
|
|
(emit cm32ss (f-rd 0) rs rt)
|
866 |
|
|
)
|
867 |
|
|
|
868 |
|
|
(dnmi m-cm32xor "Counter Manager Xor" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
869 |
|
|
"cm32xor $rs,$rt"
|
870 |
|
|
(emit cm32xor (f-rd 0) rs rt)
|
871 |
|
|
)
|
872 |
|
|
|
873 |
|
|
(dnmi m-cm64clr "Counter Manager Clear" (MACH10 USES-RT USES-RD NO-DIS)
|
874 |
|
|
"cm64clr $rt"
|
875 |
|
|
(emit cm64clr (f-rd 0) rt)
|
876 |
|
|
)
|
877 |
|
|
|
878 |
|
|
(dnmi m-cm64ra "Counter Manager 64-bit Rolling Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
879 |
|
|
"cm64ra $rs,$rt"
|
880 |
|
|
(emit cm64ra (f-rd 0) rs rt)
|
881 |
|
|
)
|
882 |
|
|
|
883 |
|
|
(dnmi m-cm64rd "Counter Manager 64-bit Rolling Decrement" (MACH10 USES-RT USES-RD NO-DIS)
|
884 |
|
|
"cm64rd $rt"
|
885 |
|
|
(emit cm64rd (f-rd 0) rt)
|
886 |
|
|
)
|
887 |
|
|
|
888 |
|
|
(dnmi m-cm64ri "Counter Manager 32-bit Rolling Increment" (MACH10 USES-RT USES-RD NO-DIS)
|
889 |
|
|
"cm64ri $rt"
|
890 |
|
|
(emit cm64ri (f-rd 0) rt)
|
891 |
|
|
)
|
892 |
|
|
|
893 |
|
|
(dnmi m-cm64ria2 "Counter Manager 32/32 Rolling Increment/Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
894 |
|
|
"cm64ria2 $rs,$rt"
|
895 |
|
|
(emit cm64ria2 (f-rd 0) rs rt)
|
896 |
|
|
)
|
897 |
|
|
|
898 |
|
|
(dnmi m-cm64rs "Counter Manager 64-bit Rolling Subtract" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
899 |
|
|
"cm64rs $rs,$rt"
|
900 |
|
|
(emit cm64rs (f-rd 0) rs rt)
|
901 |
|
|
)
|
902 |
|
|
|
903 |
|
|
(dnmi m-cm64sa "Counter Manager 64-bit Saturating Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
904 |
|
|
"cm64sa $rs,$rt"
|
905 |
|
|
(emit cm64sa (f-rd 0) rs rt)
|
906 |
|
|
)
|
907 |
|
|
|
908 |
|
|
(dnmi m-cm64sd "Counter Manager 64-bit Saturating Decrement" (MACH10 USES-RT USES-RD NO-DIS)
|
909 |
|
|
"cm64sd $rt"
|
910 |
|
|
(emit cm64sd (f-rd 0) rt)
|
911 |
|
|
)
|
912 |
|
|
|
913 |
|
|
(dnmi m-cm64si "Counter Manager 64-bit Saturating Increment" (MACH10 USES-RT USES-RD NO-DIS)
|
914 |
|
|
"cm64si $rt"
|
915 |
|
|
(emit cm64si (f-rd 0) rt)
|
916 |
|
|
)
|
917 |
|
|
|
918 |
|
|
(dnmi m-cm64sia2 "Counter Manager 32/32 Saturating Increment/Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
919 |
|
|
"cm64sia2 $rs,$rt"
|
920 |
|
|
(emit cm64sia2 (f-rd 0) rs rt)
|
921 |
|
|
)
|
922 |
|
|
|
923 |
|
|
(dnmi m-cm64ss "Counter Manager 64-bit Saturating Subtract" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
924 |
|
|
"cm64ss $rs,$rt"
|
925 |
|
|
(emit cm64ss (f-rd 0) rs rt)
|
926 |
|
|
)
|
927 |
|
|
|
928 |
|
|
(dnmi m-cm128ria2 "Counter Manager 128-bit 64/64 Rolling Increment/Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
929 |
|
|
"cm128ria2 $rs,$rt"
|
930 |
|
|
(emit cm128ria2 (f-rd 0) rs rt)
|
931 |
|
|
)
|
932 |
|
|
|
933 |
|
|
(dnmi m-cm128ria3 "Counter Manager 128-bit 32/32/64 Rolling Increment/Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
934 |
|
|
"cm128ria3 $rs,$rt,${cm-3z}"
|
935 |
|
|
(emit cm128ria3 (f-rd 0) rs rt cm-3z)
|
936 |
|
|
)
|
937 |
|
|
|
938 |
|
|
(dnmi m-cm128ria4 "Counter Manager 128-bit 32/32/32/32 Rolling Inc/Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
939 |
|
|
"cm128ria4 $rs,$rt,${cm-4z}"
|
940 |
|
|
(emit cm128ria4 (f-rd 0) rs rt cm-4z)
|
941 |
|
|
)
|
942 |
|
|
|
943 |
|
|
(dnmi m-cm128sia2 "Counter Manager 128-bit 64/64 Saturating Inc/Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
944 |
|
|
"cm128sia2 $rs,$rt"
|
945 |
|
|
(emit cm128sia2 (f-rd 0) rs rt)
|
946 |
|
|
)
|
947 |
|
|
|
948 |
|
|
(dnmi m-cm128sia3 "Counter Manager 128-bit 32/32/64 Saturating Inc/Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
949 |
|
|
"cm128sia3 $rs,$rt,${cm-3z}"
|
950 |
|
|
(emit cm128sia3 (f-rd 0) rs rt cm-3z)
|
951 |
|
|
)
|
952 |
|
|
|
953 |
|
|
(dnmi m-cm128sia4 "Counter Manager 128-bit 32/32/32/32 Saturating Inc/Add" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
954 |
|
|
"cm128sia4 $rs,$rt,${cm-4z}"
|
955 |
|
|
(emit cm128sia4 (f-rd 0) rs rt cm-4z)
|
956 |
|
|
)
|
957 |
|
|
|
958 |
|
|
(dnmi m-cmphdr "Get a Complete Header" (MACH10 NO-DIS)
|
959 |
|
|
"cmphdr"
|
960 |
|
|
(emit cmphdr (f-rd 0))
|
961 |
|
|
)
|
962 |
|
|
|
963 |
|
|
(dnmi m-dbd "Deallocate a Data Buffer Pointer" (MACH10 USES-RD USES-RT NO-DIS)
|
964 |
|
|
"dbd $rd,$rt"
|
965 |
|
|
(emit dbd rd (f-rs 0) rt)
|
966 |
|
|
)
|
967 |
|
|
|
968 |
|
|
(dnmi m2-dbd "Deallocate a Data Buffer Pointer" (MACH10 USES-RT NO-DIS)
|
969 |
|
|
"dbd $rt"
|
970 |
|
|
(emit dbd (f-rd 0) (f-rs 0) rt)
|
971 |
|
|
)
|
972 |
|
|
|
973 |
|
|
(dnmi m-dpwt "DSTN_PORT Write" (MACH10 USES-RS NO-DIS)
|
974 |
|
|
"dpwt $rs"
|
975 |
|
|
(emit dpwt (f-rd 0) rs)
|
976 |
|
|
)
|
977 |
|
|
|
978 |
|
|
(dnmi m-free "" (MACH10 USES-RS USES-RD NO-DIS)
|
979 |
|
|
"free $rs"
|
980 |
|
|
(emit free (f-rd 0) rs)
|
981 |
|
|
)
|
982 |
|
|
|
983 |
|
|
;(dnmi m-jal "jump and link, implied r31" (MACH10 USES-RT NO-DIS)
|
984 |
|
|
; "jal $jmptarg"
|
985 |
|
|
; (emit jal (f-rt 31) jmptarg)
|
986 |
|
|
;)
|
987 |
|
|
|
988 |
|
|
(dnmi m-lock "lock memory" (MACH10 USES-RT NO-DIS)
|
989 |
|
|
"lock $rt"
|
990 |
|
|
(emit lock (f-rd 0) rt)
|
991 |
|
|
)
|
992 |
|
|
|
993 |
|
|
(dnmi m-pkrla "Packet Release Absolute" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
994 |
|
|
"pkrla $rs,$rt"
|
995 |
|
|
(emit pkrla (f-rd 0) rs rt)
|
996 |
|
|
)
|
997 |
|
|
|
998 |
|
|
(dnmi m-pkrlac "Packet Release Absolute Continue" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
999 |
|
|
"pkrlac $rs,$rt"
|
1000 |
|
|
(emit pkrlac (f-rd 0) rs rt)
|
1001 |
|
|
)
|
1002 |
|
|
|
1003 |
|
|
(dnmi m-pkrlah "Packet Release Absolute and Hold" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1004 |
|
|
"pkrlah $rs,$rt"
|
1005 |
|
|
(emit pkrlah (f-rd 0) rs rt)
|
1006 |
|
|
)
|
1007 |
|
|
|
1008 |
|
|
(dnmi m-pkrlau "Packet Release Absolute Unconditional" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1009 |
|
|
"pkrlau $rs,$rt"
|
1010 |
|
|
(emit pkrlau (f-rd 0) rs rt)
|
1011 |
|
|
)
|
1012 |
|
|
|
1013 |
|
|
(dnmi m-pkrli "Packet Release Immediate" (MACH10 USES-RD USES-RS USES-RT NO-DIS)
|
1014 |
|
|
"pkrli $rs,$rt,$bytecount"
|
1015 |
|
|
(emit pkrli (f-rd 0) rs rt bytecount)
|
1016 |
|
|
)
|
1017 |
|
|
|
1018 |
|
|
(dnmi m-pkrlic "Packet Release Immediate Continue" (MACH10 USES-RS USES-RT NO-DIS)
|
1019 |
|
|
"pkrlic $rs,$rt,$bytecount"
|
1020 |
|
|
(emit pkrlic (f-rd 0) rs rt bytecount)
|
1021 |
|
|
)
|
1022 |
|
|
|
1023 |
|
|
(dnmi m-pkrlih "Packet Release Immediate and Hold" (MACH10 USES-RD USES-RS USES-RT NO-DIS)
|
1024 |
|
|
"pkrlih $rs,$rt,$bytecount"
|
1025 |
|
|
(emit pkrlih (f-rd 0) rs rt bytecount)
|
1026 |
|
|
)
|
1027 |
|
|
|
1028 |
|
|
(dnmi m-pkrliu "Packet Release Immediate Unconditional" (MACH10 USES-RD USES-RS USES-RT NO-DIS)
|
1029 |
|
|
"pkrliu $rs,$rt,$bytecount"
|
1030 |
|
|
(emit pkrliu (f-rd 0) rs rt bytecount)
|
1031 |
|
|
)
|
1032 |
|
|
|
1033 |
|
|
(dnmi m-rba "Read Bytes Absolute" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1034 |
|
|
"rba $rs,$rt"
|
1035 |
|
|
(emit rba (f-rd 0) rs rt)
|
1036 |
|
|
)
|
1037 |
|
|
|
1038 |
|
|
(dnmi m-rbal "Read Bytes Absolute and Lock" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1039 |
|
|
"rbal $rs,$rt"
|
1040 |
|
|
(emit rbal (f-rd 0) rs rt)
|
1041 |
|
|
)
|
1042 |
|
|
|
1043 |
|
|
(dnmi m-rbar "Read Bytes Absolute and Release" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1044 |
|
|
"rbar $rs,$rt"
|
1045 |
|
|
(emit rbar (f-rd 0) rs rt)
|
1046 |
|
|
)
|
1047 |
|
|
|
1048 |
|
|
(dnmi m-rbi "Read Bytes Immediate" (MACH10 USES-RS USES-RT NO-DIS)
|
1049 |
|
|
"rbi $rs,$rt,$bytecount"
|
1050 |
|
|
(emit rbi (f-rd 0) rs rt bytecount)
|
1051 |
|
|
)
|
1052 |
|
|
|
1053 |
|
|
(dnmi m-rbil "Read Bytes Immediate and Lock" (MACH10 USES-RS USES-RT NO-DIS)
|
1054 |
|
|
"rbil $rs,$rt,$bytecount"
|
1055 |
|
|
(emit rbil (f-rd 0) rs rt bytecount)
|
1056 |
|
|
)
|
1057 |
|
|
|
1058 |
|
|
(dnmi m-rbir "Read Bytes Immediate and Release" (MACH10 USES-RS USES-RT NO-DIS)
|
1059 |
|
|
"rbir $rs,$rt,$bytecount"
|
1060 |
|
|
(emit rbir (f-rd 0) rs rt bytecount)
|
1061 |
|
|
)
|
1062 |
|
|
|
1063 |
|
|
(dnmi m-swwr "Single Word Write" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1064 |
|
|
"swwr $rs,$rt"
|
1065 |
|
|
(emit swwr (f-rd 0) rs rt)
|
1066 |
|
|
)
|
1067 |
|
|
|
1068 |
|
|
(dnmi m-swwru "Single Word Write and Unlock" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1069 |
|
|
"swwru $rs,$rt"
|
1070 |
|
|
(emit swwru (f-rd 0) rs rt)
|
1071 |
|
|
)
|
1072 |
|
|
|
1073 |
|
|
(dnmi m-tstod "Test Header Buffer Order Dependency" (MACH10 USES-RS USES-RD NO-DIS)
|
1074 |
|
|
"tstod $rs"
|
1075 |
|
|
(emit tstod (f-rd 0) rs)
|
1076 |
|
|
)
|
1077 |
|
|
|
1078 |
|
|
(dnmi m-unlk "" (MACH10 USES-RT USES-RD NO-DIS)
|
1079 |
|
|
"unlk $rt"
|
1080 |
|
|
(emit unlk (f-rd 0) rt)
|
1081 |
|
|
)
|
1082 |
|
|
|
1083 |
|
|
(dnmi m-wba "Write Bytes Absolute" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1084 |
|
|
"wba $rs,$rt"
|
1085 |
|
|
(emit wba (f-rd 0) rs rt)
|
1086 |
|
|
)
|
1087 |
|
|
|
1088 |
|
|
(dnmi m-wbac "Write Bytes Absolute Cacheable" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1089 |
|
|
"wbac $rs,$rt"
|
1090 |
|
|
(emit wbac (f-rd 0) rs rt)
|
1091 |
|
|
)
|
1092 |
|
|
|
1093 |
|
|
(dnmi m-wbau "Write Bytes Absolute and Unlock" (MACH10 USES-RS USES-RT USES-RD NO-DIS)
|
1094 |
|
|
"wbau $rs,$rt"
|
1095 |
|
|
(emit wbau (f-rd 0) rs rt)
|
1096 |
|
|
)
|
1097 |
|
|
|
1098 |
|
|
(dnmi m-wbi "Write Bytes Immediate" (MACH10 USES-RD USES-RS USES-RT NO-DIS)
|
1099 |
|
|
"wbi $rs,$rt,$bytecount"
|
1100 |
|
|
(emit wbi (f-rd 0) rs rt bytecount)
|
1101 |
|
|
)
|
1102 |
|
|
|
1103 |
|
|
(dnmi m-wbic "Write Bytes Immediate Cacheable" (MACH10 USES-RD USES-RS USES-RT NO-DIS)
|
1104 |
|
|
"wbic $rs,$rt,$bytecount"
|
1105 |
|
|
(emit wbic (f-rd 0) rs rt bytecount)
|
1106 |
|
|
)
|
1107 |
|
|
|
1108 |
|
|
(dnmi m-wbiu "Write Bytes Immediate" (MACH10 USES-RD USES-RS USES-RT NO-DIS)
|
1109 |
|
|
"wbiu $rs,$rt,$bytecount"
|
1110 |
|
|
(emit wbiu (f-rd 0) rs rt bytecount)
|
1111 |
|
|
)
|
1112 |
|
|
|