

# SH7000 Series

# Multi-Bit Shift of 32-Bit Data (Logical Right Shift)

Label: SHLRN

Functions Used: SHLR2 Instruction

SHLR8 Instruction SHLR16 Instruction

#### **Contents**

| 1. | Function                                   | 2 |
|----|--------------------------------------------|---|
| 2. | Arguments                                  | 2 |
| 3. | Internal Register Changes and Flag Changes | 2 |
| 4. | Programming Specifications                 | 3 |
| 5. | Notes                                      | 3 |
| 6. | Description                                | 4 |
| 7. | Flowchart                                  | 6 |
| 8. | Program Listing                            | 7 |



### 1. Function

Performs a multi-bit (0–31) logical right shift of 32-bit data.

## 2. Arguments

| Description |                             | Storage Location | Data Length (Bytes) |
|-------------|-----------------------------|------------------|---------------------|
| Input       | Number of shift bits (0–31) | R0               | 4                   |
|             | 32-bit data before shift    | R1               | 4                   |
| Output      | 32-bit data after shift     | R1               | 4                   |

## 3. Internal Register Changes and Flag Changes

|     | (Before Execution) → (After Execution)                         |  |  |  |  |  |  |
|-----|----------------------------------------------------------------|--|--|--|--|--|--|
| R0  | Number of shift bits $\rightarrow$ No change                   |  |  |  |  |  |  |
| R1  | 32-bit data before shift $\rightarrow$ 32-bit data after shift |  |  |  |  |  |  |
| R2  | Work                                                           |  |  |  |  |  |  |
| R3  | Work                                                           |  |  |  |  |  |  |
| R4  |                                                                |  |  |  |  |  |  |
| R5  |                                                                |  |  |  |  |  |  |
| R6  |                                                                |  |  |  |  |  |  |
| R7  |                                                                |  |  |  |  |  |  |
| R8  |                                                                |  |  |  |  |  |  |
| R9  |                                                                |  |  |  |  |  |  |
| R10 |                                                                |  |  |  |  |  |  |
| R11 |                                                                |  |  |  |  |  |  |
| R12 |                                                                |  |  |  |  |  |  |
| R13 |                                                                |  |  |  |  |  |  |
| R14 |                                                                |  |  |  |  |  |  |
| R15 | (SP)                                                           |  |  |  |  |  |  |

T bit \* — : No change \* : Change 0 : Fixed 0

1 : Fixed 1



## 4. Programming Specifications

| Program memory (bytes) |
|------------------------|
| 36                     |
| Data memory (bytes)    |
| 0                      |
| Stack (bytes)          |
| 0                      |
| Number of states       |
| 19                     |
| Reentrant              |
| Yes                    |
| Relocation             |
| Yes                    |
| Intermediate interrupt |
| Yes                    |

### 5. Notes

The number of states indicated in the programming specifications is the value when a 31-bit shift is performed.



### 6. Description

#### (1) Function

Details of the arguments are as follows.

R0: As the input argument, set the number of shift bits (0–31).

R1: Set the 32-bit data before the shift as the input argument.

Holds the 32-bit data after the shift as the output argument.

Figure 1 shows a software SHLRN execution example.



Figure 1 Software SHLRN Execution Example

#### (2) Usage Notes

The contents of R1, which holds the 32-bit data before the shift, are destroyed after the shift when the 32-bit data after the shift is stored there. If the value for the 32-bit data before the shift will be needed after the software SHLRN instruction is executed, it should be saved beforehand.

#### (3) RAM Used

No RAM is used by the software SHLRN instruction.



#### (4) Usage Example

After the number of shift bits and the 32-bit data before the shift have been set in the input arguments, the software SHLRN instruction is executed by a subroutine call.

```
MOV #H'05,R0 .... Sets number of shift bits in input argument (R0)

BSR SHARN .... Subroutine call to software SHLRN

MOV.L DATA,R1 .... Sets 32-bit data before shift in input argument (R1)

.... align 4

DATA .data.l H'80000000
```

#### (5) Operating Principle

Bits 4 to 0 in R0, which is set to the number of shift bits, are tested. If any of them have a value of 1, a shift corresponding to the weighting of the bits in question is performed using the 16-bit logical right shift command (SHLR16), the 8-bit logical right shift command (SHLR8), the 2-bit logical right shift command (SHLR2), and the 1-bit logical right shift command (SHLR).

Table 1 Number of Shift Bits and Instructions Used for Each Bit

| Bit Number | Weighting          | Instruction   |   |
|------------|--------------------|---------------|---|
| Bit 4      | $2^4 = 16$         | SHLR16        |   |
| Bit 3      | 2 <sup>3</sup> = 8 | SHLR8         |   |
| Bit 2      | $2^2 = 4$          | SHLR2 (twice) |   |
| Bit 1      | $2^1 = 2$          | SHLR2         |   |
| Bit 0      | $2^0 = 1$          | SHLR          | _ |



#### 7. Flowchart





## 8. Program Listing

| 1   |           |          | 1  | .*****                                       | ******   | *****  | ******    | * *                | ******                     | * * |
|-----|-----------|----------|----|----------------------------------------------|----------|--------|-----------|--------------------|----------------------------|-----|
| 2   |           |          | 2  | ; *                                          |          |        |           |                    |                            | *   |
| 3   |           |          | 3  | ;* NAME; n BITS SHIFT LOGICAL RIGHT (SHLRN)  |          |        |           | ICAI DICHE /CHIDN\ | *                          |     |
| 4   |           |          | 4  | , NAME , N BITS SHIFT LOGICAL RIGHT (SHLRN)  |          |        |           | *                  |                            |     |
| 5   |           |          | 5  | , ^<br>;************************************ |          |        |           |                    | **                         |     |
| 6   |           |          | 6  | ;*                                           |          |        |           |                    | *                          |     |
| 7   |           |          | 7  | ; *                                          | ENTRY :  | · p0   | /NUMBER O | F .                | BIT SHIFTED)               | *   |
| 8   |           |          | 8  | ,<br>;*                                      | ENTICE . |        | (32 BIT D |                    |                            | *   |
| 9   |           |          | 9  |                                              | ETTIENS: |        |           |                    | ·                          | *   |
| 10  |           |          | 10 | ;* RETURNS : R1 (SHIFT RESULT) ;*            |          |        |           |                    | *                          |     |
| 11  |           |          | 11 | •                                            | *****    | *****  | *****     | * *                | ******                     | **  |
|     | 00001000  |          | 12 | ,                                            |          |        | E,LOCATE= |                    |                            |     |
| 13  | 00001000  | 00001000 | 13 | SHLRN                                        |          | \$     | , Locilla |                    | Entry point                |     |
|     | 00001000  | 00001000 | 14 | SHLRN1                                       | .100     | Y      |           | ;                  | mer, perme                 |     |
|     | 00001000  | C810     | 15 | DIILIUVI                                     | TST      | #B'000 | 10000 R0  |                    | Bit 4 = 1?                 |     |
|     | 00001002  |          | 16 |                                              | BT       | SHLRN2 |           |                    | No.                        |     |
|     | 00001004  |          | 17 |                                              | SHLR16   |        |           |                    | 16 bit shift logical right |     |
|     | 00001006  |          | 18 | SHLRN2                                       |          |        |           | ;                  |                            |     |
| 19  | 00001000  | C808     | 19 |                                              | TST      | #B'000 | 01000,R0  | ;                  | Bit 3 = 1?                 |     |
| 20  | 00001008  | 8900     | 20 |                                              | BT       | SHLRN3 |           | ;                  | No                         |     |
| 21  | 0000100A  | 4119     | 21 |                                              | SHLR8    | R1     |           | ;                  | 8 bit shift logical right  |     |
| 22  | 0000100C  |          | 22 | SHLRN3                                       |          |        |           | ;                  |                            |     |
| 23  | 0000100C  | C804     | 23 |                                              | TST      | #B'000 | 00100,R0  | ;                  | Bit 2 = 1?                 |     |
| 24  | 0000100E  | 8901     | 24 |                                              | BT       | SHLRN4 |           | ;                  | No                         |     |
| 25  | 00001010  | 4109     | 25 |                                              | SHLR2    | R1     |           | ;                  | 4 bit shift logical right  |     |
| 26  | 00001012  | 4109     | 26 |                                              | SHLR2    | R1     |           | ;                  |                            |     |
| 27  | 00001014  |          | 27 | SHLRN4                                       |          |        |           | ;                  |                            |     |
| 28  | 00001014  | C802     | 28 |                                              | TST      | #B'000 | 00010,R0  | ;                  | Bit 1 = 1?                 |     |
| 29  | 00001016  | 8900     | 29 |                                              | BT       | SHLRN5 |           | ;                  | No                         |     |
| 30  | 00001018  | 4109     | 30 |                                              | SHLR2    | R1     |           | ;                  | 2 bit shift logical right  |     |
| 31  | 0000101A  |          | 31 | SHLRN5                                       |          |        |           | ;                  |                            |     |
| 32  | 0000101A  | C801     | 32 |                                              | TST      | #B'000 | 00001,R0  | ;                  | Bit 0 = 1?                 |     |
| 33  | 0000101C  | 8900     | 33 |                                              | BT       | SHLRN_ | END       | ;                  | No                         |     |
| 34  | 0000101E  | 4101     | 34 |                                              | SHLR     | R1     |           | ;                  | 1 bit shift logical right  |     |
| 35  | 00001020  |          | 35 | SHLRN_E                                      | ND       |        |           | ;                  |                            |     |
| 36  | 00001020  | 000B     | 36 |                                              | RTS      |        |           | ;                  |                            |     |
| 37  | 00001022  | 0009     | 37 |                                              | NOP      |        |           | ;                  |                            |     |
| 38  |           |          | 38 |                                              | .END     |        |           | ;                  |                            |     |
| *** | **TOTAL E | RRORS 0  |    |                                              |          |        |           |                    |                            |     |



## SH7000 Series Multi-Bit Shift of 32-Bit Data (Logical Right Shift)

#### Keep safety first in your circuit designs!

1. Renesas Technology Corp. puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of nonflammable material or (iii) prevention against any malfunction or mishap.

#### Notes regarding these materials

- These materials are intended as a reference to assist our customers in the selection of the Renesas Technology Corp. product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Renesas Technology Corp. or a third party.
- 2. Renesas Technology Corp. assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts, programs, algorithms, or circuit application examples contained in these materials.
- 3. All information contained in these materials, including product data, diagrams, charts, programs and algorithms represents information on products at the time of publication of these materials, and are subject to change by Renesas Technology Corp. without notice due to product improvements or other reasons. It is therefore recommended that customers contact Renesas Technology Corp. or an authorized Renesas Technology Corp. product distributor for the latest product information before purchasing a product listed herein.
  - The information described here may contain technical inaccuracies or typographical errors. Renesas Technology Corp. assumes no responsibility for any damage, liability, or other loss rising from these inaccuracies or errors.
  - Please also pay attention to information published by Renesas Technology Corp. by various means, including the Renesas Technology Corp. Semiconductor home page (http://www.renesas.com).
- 4. When using any or all of the information contained in these materials, including product data, diagrams, charts, programs, and algorithms, please be sure to evaluate all information as a total system before making a final decision on the applicability of the information and products. Renesas Technology Corp. assumes no responsibility for any damage, liability or other loss resulting from the information contained herein.
- 5. Renesas Technology Corp. semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Renesas Technology Corp. or an authorized Renesas Technology Corp. product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use.
- 6. The prior written approval of Renesas Technology Corp. is necessary to reprint or reproduce in whole or in part these materials.
- 7. If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination.
  - Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the country of destination is prohibited.
- 8. Please contact Renesas Technology Corp. for further details on these materials or the products contained therein.