Encoding:

P32A

001000

rt

rs

1101000

100

111

111

6

5

5

7

3

3

3

Format:

PRECEU.PH.QBR rt, rs

DSP

Precision Expand two Unsigned Bytes to Unsigned Halfword Values

Purpose:

Precision Expand two Unsigned Bytes to Unsigned Halfword Values

Expand the precision of two unsigned integer byte values taken from the two right-most elements of a quad byte vector to create two unsigned halfword values.

Description:

rt = expand_prec8u16(rs15..8) || expand_prec8u16(rs7..0)

The two right-most unsigned integer byte values from the four byte elements in register rs are expanded to create two unsigned halfword values that are then written to destination register rt. The precision expansion is achieved by prepending eight most-significant zero bits to each original value to generate each 16 bit halfword value.

Restrictions:

No data-dependent exceptions are possible.

The operands must be values in the specified format. If they are not, the results are UNPREDICTABLE and the values of the operand vectors become UNPREDICTABLE.

Operation:

ValidateAccessToDSPResources()
tempB15..0 = 08 || GPR[rs]15..8
tempA15..0 = 08 || GPR[rs]7..0
GPR[rt]31..0 = tempB15..0 || tempA15..0

Exceptions:

Reserved Instruction, DSP Disabled