| SAR                                                                                                                                                                                              | ( shift arithmetically right)  | SHR Value,#B     | its 4 clks      |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------|-----------------|--|
| Result: Value is shifted arithmetically right by Bits<br>•Value (d-field) is the register to SAR<br>•Bits (s-field) is a register or a 5bit lateral whose value<br>is the number of bits to SAR. |                                |                  |                 |  |
| Assume we have a value to start in a register called adc1<br>adc1=%01000000_0000000_0000000_000000000                                                                                            |                                |                  |                 |  |
| SAR adc1,#10 (note the MSB is 0)<br>Result > adc1=%00000000_00010000_00000000_00000000<br>C flag=0 and the Z flag=0                                                                              |                                |                  |                 |  |
| Now we try the next one.(note the MSB is now 1)<br>adc1=%10000001_00000000_0000000_000000000                                                                                                     |                                |                  |                 |  |
| SAR adc1,#8<br>Result > adc1=%11111111_10000001_00000000_00000000<br>C flag=0 and the Z flag=0                                                                                                   |                                |                  |                 |  |
| One more to see the C flag being set.                                                                                                                                                            |                                |                  |                 |  |
| adc1=%10000001_00000000_00000000_00000001                                                                                                                                                        |                                |                  |                 |  |
| SAR adc1,#3<br>Result > adc1=%11110000_00100000_00000000_00000000<br>C flag=1 and the Z flag=0                                                                                                   |                                |                  |                 |  |
|                                                                                                                                                                                                  | Z flag set when resulting va   | lue =0           | IF WZ specified |  |
|                                                                                                                                                                                                  | C flag set to original value o | f bit0           | IF WC specified |  |
|                                                                                                                                                                                                  | The result is not written to V | /alue if NR is s | pecified.       |  |
| The MSB is extended along the way.<br>(preserves the sign in a signed value)                                                                                                                     |                                |                  |                 |  |

Result: Value is rotated left by Bits

- •Value (d-field) is the register to ROL
- •Bits (s-field) is a register or a 5bit lateral whose value is the number of bits to ROL

Assume we have a value to start in a register called adc1 adc1=%1111111\_00000000\_0000000\_00000000

We execute the following instruction

ROL adc1,#8 Result > adc1=%0000000\_0000000\_0000000\_11111111 C flag=1 and the Z flag=0

Now we try the next one. adc1=%00000000\_0000000\_10100000\_00001010

ROL adc1,#8 Result > adc1=%0000000\_1010000\_00001010\_0000000 C flag=0 and the Z flag=0

Z flag set when resulting value =0IF WZ specifiedC flag set to original value of bit31IF WC specifiedThe result is not written to Value if NR is specified.

(ROL and ROR are also referred to as Barrel Shifter instructions)

4 clks

| Result: Value is rotated right by Bits<br>•Value (d-field) is the register to ROR<br>•Bits (s-field) is a register or a 5bit lateral while<br>is the number of bits to ROR | nose value       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| Assume we have a value to start in a register cal adc1=%11111111_00000000_0000000_00000                                                                                    | lled adc1<br>000 |
| We execute the following instruction                                                                                                                                       |                  |
| ROR adc1,#8<br>Result > adc1=%00000000_11111111_0000000<br>C flag=0 and the Z flag=0                                                                                       | 0_0000000        |
| Now we try the next one.<br>adc1=%00000000_0000000_0000000_00001                                                                                                           | 010              |
| ROR adc1,#8<br>Result > adc1=%00001010_00000000_0000000<br>C flag=0 and the Z flag=0                                                                                       | 0_0000000        |
| One more<br>adc1=%00000000_0000000_0000000_00001<br>ROR adc1,#4<br>Result > adc1=%10010000_00000000_0000000<br>C flag=1 and the Z flag=0                                   | 001<br>0         |
| Z flag set when resulting value =0                                                                                                                                         | IF WZ specified  |

C flag set to original value of bit0 IF WC specified The result is not written to Value if NR is specified.

(ROL and ROR are also referred to as Barrel Shifter instructions)