S3C84E5/C84E9/P84E9

INSTRUCTION SET

 

 

SRA — Shift Right Arithmetic

SRAdst

Operation: dst (7) dst (7)

C dst (0)

dst (n) dst (n + 1), n = 0–6

An arithmetic shift-right of one bit position is performed on the destination operand. Bit zero (the LSB) replaces the carry flag. The value of bit 7 (the sign bit) is unchanged and is shifted into the bit position 6.

7

6

0

C

 

 

Flags:

C: Set if the bit shifted from the LSB position (bit zero) was "1".

Z:Set if the result is "0"; cleared otherwise.

S:Set if the result is negative; cleared otherwise.

V:Always cleared to "0".

D:Unaffected.

H:Unaffected.

Format:

Bytes Cycles Opcode

Addr Mode

(Hex)

dst

opc

dst

2

4

D0

R

 

4

D1

IR

Examples:

Given:

Register 00H

= 9AH, register 02H = 03H, register 03H

= 0BCH, and C =

"1":

 

SRA

00H

Register 00H

=

0CD, C =

"0"

 

 

SRA

@02H

Register 02H

=

03H, register 03H = 0DEH, C

= "0"

In the first example, if the general register 00H contains the value 9AH (10011010B), the statement "SRA 00H" shifts the bit values in the register 00H right one bit position. Bit zero ("0") clears the C flag and bit 7 ("1") is then shifted into the bit 6 position (bit 7 remains unchanged). This leaves the value 0CDH (11001101B) in the destination register 00H.

6-79

Page 206
Image 206
Samsung S3C84E5 user manual SRA Shift Right Arithmetic, SRAdst, 00H Register 00H 0CD, C =