## Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding.

Renesas Electronics website: http://www.renesas.com

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (http://www.renesas.com)

Send any inquiries to http://www.renesas.com/inquiry.

## HITACHI MICROCOMPUTER TECHNICAL UPDATE

| DATE           | 25 January 2001                                         | No.               | TN-SH7-298A/E    |  |  |
|----------------|---------------------------------------------------------|-------------------|------------------|--|--|
| THEME          | NMI usage notice                                        |                   |                  |  |  |
| CLASSIFICATION | Spec change Supplement of Documents                     | Limitation on Use |                  |  |  |
| PRODUCTNAME    | SH7750,SH7750S,SH7751                                   | Lot No.etc.       |                  |  |  |
| REFERENCE      | SH7750 Series Hardware Manual<br>SH7751 Hardware Manual |                   | v. EffectiveDate |  |  |
| DOCUMENTS      |                                                         |                   | From             |  |  |

There is a case NMI does not work correctly. Please notice the following NMI usage.

## 1. Phenomenon

NMI detection logic may not work correctly in the following condition.

When the plural NMI are requested via the external pin within a certain time (it depend on the CPU and external-BUS state.), the CPU may not accept all kind of interrupt.

In following cases, NMI works correctly.

- The system guarantees enough interval time between two NMI requests (\*).

- The system uses interrupts other than NMI, such an IRL.

(\*) On condition CPU can be execute at least one instruction between two NMI requests under SR.BL=0.

## 2. Workaround

There are three workarounds available to avoid this phenomenon.

(1) Please provide enough interval time between two NMI requests as above (\*).

In addition, a hazard on NMI pin may violate this interval time requirement and cause this phenomenon described above. Thus, the external circuits must pay attention to avoid a hazard (\*\*).

(\*\*) Each HIGH/LOW voltage level width must be more than 5 CKIO, the transition must not include noise pulse.

(2) Please use IRL interrupt instead of NMI interrupt.

|                    | Notes:           |                                         |             |                                                |
|--------------------|------------------|-----------------------------------------|-------------|------------------------------------------------|
|                    | (***) W          | hen SR.BL bit is                        | changed in  | NMI exception handler routine,                 |
|                    |                  |                                         | -           | ce at the location before SR.BL changes.       |
|                    | (****)]          | R0 to R3 can be re                      | place with  | other registers.                               |
|                    | If the re        | gister store/restore                    | e are neces | sary, please add them to the beginning and the |
|                    | ending           | of this instruction                     | sequence.   |                                                |
|                    |                  | ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; |             |                                                |
| ;; R0 :<br>;; R2 : |                  | R1 : Origina<br>CR R3 : ICR A           |             |                                                |
|                    | -                | ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; |             |                                                |
|                    | R.IMASK          | = H'F                                   |             |                                                |
|                    | stc<br>mov       | SR, R1<br>R1,R0                         | ;           | SR store                                       |
|                    | or               | #H'F0,R0                                |             |                                                |
|                    | ldc              | R0, SR                                  |             |                                                |
| ; (2) Reve         | rse ICR.NI       |                                         |             |                                                |
|                    | mov.l #<br>mov.w | @R3, R2                                 | :           | ICR store                                      |
|                    | mov.w            | #H'0100, R0                             | ;           |                                                |
|                    | xor<br>mov.w     | R2, R0<br>R0, @R3                       | ;           | ICR.NMIE (Reverse and dummy write)             |
|                    | bra NMI          |                                         | ,           |                                                |
|                    | nop<br>.pool     |                                         |             |                                                |
|                    | .align           | 4                                       |             |                                                |
| NMIH2:<br>; (3)    |                  |                                         |             |                                                |
|                    | mov.w            | @R3, R0                                 | ;           | dummy read                                     |
|                    | mov.w<br>stc     | R2, @R3<br>SR, R0                       | ;           | ICR.NMIE (Write)                               |
|                    | ldc              | R0, SR                                  |             |                                                |
|                    | ldc<br>ldc       | R0, SR<br>R0, SR                        |             |                                                |
|                    | ldc              | R0, SR<br>R0, SR                        |             |                                                |
|                    | ldc              | R0, SR                                  |             |                                                |
|                    | ldc              | R0, SR                                  |             |                                                |
|                    | ldc<br>ldc       | R0, SR<br>R0, SR                        |             |                                                |
|                    | ldc              | R1, SR                                  | ;           | SR restore                                     |
|                    | bra NMI          | H3                                      |             |                                                |
| NMIH1:             | nop              |                                         |             |                                                |
|                    | bra NMI          | H2                                      |             |                                                |
| NMIH3:             | nop              |                                         |             |                                                |
| ;;;;;;;;;          | ;;;;;;;;;        | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ;;;;;       |                                                |