Encoding:

SPECIAL3

011111

0

00000

rt

rd

PRECEQU.PH.QBR

00101

ABSQ_S.PH

010010

6

5

5

5

5

6

Format:

PRECEQU.PH.QBR rd, rt

MIPSDSP

Precision Expand two Unsigned Bytes to Fractional Halfword Values

Purpose:

Precision Expand two Unsigned Bytes to Fractional Halfword Values

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

Description:

rd = sign_extend(expand_prec(rt15..8) || expand_prec(rt7..0))

The two right-most unsigned integer byte values from the four right-most byte elements in register rt are expanded to create two Q15 fractional values that are then written to destination register rd. The precision expansion is achieved by pre-pending a single zero bit (for positive sign) to the original byte value and appending seven least-significant zeros to generate each 16-bit fractional value.

Bit 31 of the result is extended into the 32 most-significant bits of the destination register.

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:

tempB15..0 = 01 || GPR[rt]15..8 || 07 
tempA15..0 = 01 || GPR[rt]7..0 || 07 
GPR[rd]63..0 = (tempB15) || tempB15..0 || tempA15..0

Exceptions:

Reserved Instruction, DSP Disabled