288
Operation:
Exceptions:
None
T:
for i in 0...7
if (e
3...0
= 0000) then /* vector operand */
j
i
elseif ((e
3...0
& 1110) = 0010) then /* scalar quarter of vector */
j
(e
3...0
& 0001) + (i & 1110)
elseif ((e
3...0
& 1100) = 0100) then /* scalar half of vector */
j
(e
3...0
& 0011) + (i & 1100)
elseif ((e
3...0
& 1000) = 1000) then /* scalar whole of vector */
j
(e
3...0
& 0111)
endif
product
31...0
VR[vs][i*2]
15...0
* VR[vt][j*2]
15...0
ACC
47...16
product
30...0
|| 0
ACC
47...0
ACC
47...0
+ (1 || 0
15
)
VR[vd][i*2]
15...0
Clamp_Unsigned(ACC
31...16
)
endfor
Summary of Contents for Ultra64
Page 2: ...2 ...
Page 10: ...10 ...
Page 12: ...12 Figure 6 2 buildtask Operation 137 ...
Page 14: ...14 ...
Page 80: ...80 Vector Unit Instructions vmadm dres_int dres_int vconst 3 vmadn dres_frac vconst vconst 0 ...
Page 104: ...104 RSP Coprocessor 0 ...
Page 150: ...150 Advanced Information ...
Page 155: ...Revision 1 0 155 ...
Page 248: ...248 Exceptions None ...
Page 251: ...Revision 1 0 251 Exceptions None ...
Page 254: ...254 Exceptions None ...
Page 257: ...Revision 1 0 257 Exceptions None ...
Page 293: ...Revision 1 0 293 Exceptions None ...
Page 316: ...316 Exceptions None ...