Instructions
www.ti.com
F32TOI16R RaH, RbH
Convert 32-bit Floating-Point Value to 16-bit Integer and Round
Operands
RaH
floating-point destination register (R0H to R7H)
RbH
floating-point source register (R0H to R7H)
Opcode
LSW: 1110 0110
1000 1100
MSW: 1000 0000
00bb baaa
Description
Convert the 32-bit floating point value in RbH to a 16-bit integer and round to the nearest
even value. The result is stored in RaH.
RaH(15:0)
= F32ToI16round(RbH)
RaH(31:16) = sign extension of RaH(15)
Flags
This instruction does not affect any flags:
Flag
TF
ZI
NI
ZF
NF
LUF
LVF
Modified
No
No
No
No
No
No
No
Pipeline
This is a 2 pipeline cycle (2p) instruction. That is:
F32TOI16R
RaH, RbH
; 2 pipeline cycles (2p)
NOP
; 1 cycle delay or non-conflicting instruction
; <-- F32TOI16R completes, RaH updated
NOP
Any instruction in the delay slot must not use RaH as a destination register or use RaH
as a source operand.
Example
MOVIZ
R0H, #0x3FD9
; R0H [31:16] = 0x3FD9
MOVXI
R0H, #0x999A
; R0H [15:0]
= 0x999A
; R0H = 1.7 (0x3FD9999A)
F32TOI16R
R1H, R0H
; R1H(15:0)
= F32TOI16round (R0H)
; R1H(31:16) = Sign extension of R1H(15)
MOVF32
R2H, #-1.7
; R2H = -1.7 (0xBFD9999A)
; <-- F32TOI16R complete, R1H(15:0)
= 2 (0x0002)
;
R1H(31:16) = 0 (0x0000)
F32TOI16R
R3H, R2H
; R3H(15:0)
= F32TOI16round (R2H)
; R3H(31:16) = Sign extension of R2H(15)
NOP
; 1 Cycle delay for F32TOI16R to complete
; <-- F32TOI16R complete, R1H(15:0)
= -2 (0xFFFE)
;
R1H(31:16) = (0xFFFF)
See also
Instruction Set
52
SPRUEO2A – June 2007 – Revised August 2008
Содержание TMS320C28 series
Страница 2: ...2 SPRUEO2A June 2007 Revised August 2008 Submit Documentation Feedback ...
Страница 12: ...Introduction 12 SPRUEO2A June 2007 Revised August 2008 Submit Documentation Feedback ...
Страница 20: ...CPU Register Set 20 SPRUEO2A June 2007 Revised August 2008 Submit Documentation Feedback ...
Страница 136: ...Instruction Set 136 SPRUEO2A June 2007 Revised August 2008 Submit Documentation Feedback ...