## 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.

# **RENESAS TECHNICAL UPDATE**

Nippon Bldg., 2-6-2, Ohte-machi, Chiyoda-ku, Tokyo 100-0004, Japan Renesas Technology Corp.

| Product<br>Category   | MPU&MCU                                                                                                                                                                                                                                                                                                                        |                                                                    | Document<br>No.                                                                                                                                                                                   | TN-H8*-A386A/E                                                                             | Rev.        | 1.00    |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-------------|---------|
| Title                 | Notes on Rewriting DTC Enable Registers (DTCER)                                                                                                                                                                                                                                                                                |                                                                    | Information<br>Category                                                                                                                                                                           | Technical Notification                                                                     |             |         |
| Applicable<br>Product | H8SX/1622 group, H8SX/1638 group                                                                                                                                                                                                                                                                                               | Lot No.                                                            |                                                                                                                                                                                                   |                                                                                            |             |         |
| Tioduct               | H8SX/1648 group, H8SX/1650 group<br>H8SX/1651 group, H8SX/1653 group<br>H8SX/1657 group, H8SX/1658R group<br>H8SX/1663 group, H8SX/1668R group                                                                                                                                                                                 | All lots                                                           | Reference<br>Document                                                                                                                                                                             | See below.                                                                                 |             |         |
| We would lik          | te to inform you of some notes on rewriting                                                                                                                                                                                                                                                                                    | the DTC enable                                                     | e registers (DTCI                                                                                                                                                                                 | ER) of the above listed [                                                                  | products.   |         |
| Specifically, i       | if rewriting the DTCER conflicts with generation                                                                                                                                                                                                                                                                               | ation of a DTC a                                                   | ctivation source                                                                                                                                                                                  | interrupt, both DTC act                                                                    | ivation an  | d CPU   |
| nterrupt exc          | eption handling may be executed; it has tu                                                                                                                                                                                                                                                                                     | rned out that a c                                                  | louble interrupt r                                                                                                                                                                                | may be caused in some                                                                      | cases. Th   | ne      |
| ollowing give         | es details of this problem, which can be pre                                                                                                                                                                                                                                                                                   | evented accordi                                                    | ng to the proced                                                                                                                                                                                  | ures in figure 1.                                                                          |             |         |
|                       |                                                                                                                                                                                                                                                                                                                                |                                                                    |                                                                                                                                                                                                   |                                                                                            |             |         |
| 1. Preventive         | e Measures (DTCER Rewriting Method)                                                                                                                                                                                                                                                                                            |                                                                    |                                                                                                                                                                                                   |                                                                                            |             |         |
| The following         | g DTCER rewriting procedures can preven                                                                                                                                                                                                                                                                                        | t a conflict betwe                                                 | een rewriting the                                                                                                                                                                                 | DTCER and a DTC act                                                                        | tivation so | ource   |
| nterrupt fron         | n causing execution of both DTC activation                                                                                                                                                                                                                                                                                     | and CPU interr                                                     | upt exception ha                                                                                                                                                                                  | andling. The DTCER rev                                                                     | vriting pro | cedure  |
| depends on            | the interrupt control mode: set the I bit in C                                                                                                                                                                                                                                                                                 | CR to "1" in inte                                                  | errupt control mo                                                                                                                                                                                 | de 0, and set the interru                                                                  | ipt mask l  | evel to |
| '7" (I2 to I0 b       | oits in EXR = B'111) in interrupt control mo                                                                                                                                                                                                                                                                                   | de 2. This mask                                                    | s an interrupt to                                                                                                                                                                                 | the CPU thus preventing                                                                    | a executio  | on of   |
|                       |                                                                                                                                                                                                                                                                                                                                |                                                                    | o un interrupt to                                                                                                                                                                                 | and of o ands preventing                                                                   | y executio  |         |
|                       | eption handling by the CPU.                                                                                                                                                                                                                                                                                                    |                                                                    |                                                                                                                                                                                                   |                                                                                            | g executio  |         |
|                       | eption handling by the CPU.                                                                                                                                                                                                                                                                                                    |                                                                    |                                                                                                                                                                                                   |                                                                                            | y execution |         |
|                       | eption handling by the CPU.<br>Interrupt Control Mode 0                                                                                                                                                                                                                                                                        |                                                                    | rupt Control Mc                                                                                                                                                                                   |                                                                                            | g executio  |         |
| interrupt exc         | Interrupt Control Mode 0                                                                                                                                                                                                                                                                                                       | Inter                                                              | rupt Control Mc                                                                                                                                                                                   | ode 2                                                                                      | g executio  |         |
| interrupt exc         |                                                                                                                                                                                                                                                                                                                                | Inter                                                              |                                                                                                                                                                                                   | ode 2                                                                                      | geneturi    |         |
| interrupt exc         | Interrupt Control Mode 0<br>Copy the CCR register value.                                                                                                                                                                                                                                                                       | Inter<br>Copy                                                      | rupt Control Mo<br>v EXR register v                                                                                                                                                               | ode 2<br>value.                                                                            | geneturi    |         |
| nterrupt exc          | Interrupt Control Mode 0 Copy the CCR register value.  tet the interrupt mask bit to " 1 ".                                                                                                                                                                                                                                    | Inter<br>Copy                                                      | rupt Control Mo<br>v EXR register v<br>↓<br>terrupt mask lev                                                                                                                                      | ode 2<br>/alue.<br>/el to " 7 "                                                            |             |         |
| nterrupt exc          | Interrupt Control Mode 0<br>Copy the CCR register value.                                                                                                                                                                                                                                                                       | Inter<br>Copy                                                      | rupt Control Mo<br>v EXR register v                                                                                                                                                               | ode 2<br>/alue.<br>/el to " 7 "                                                            |             |         |
| nterrupt exc          | Interrupt Control Mode 0 Copy the CCR register value.  tet the interrupt mask bit to " 1 ".                                                                                                                                                                                                                                    | Inter<br>Copy<br>Set the int<br>(I2 to I                           | rupt Control Mo<br>v EXR register v<br>↓<br>terrupt mask lev                                                                                                                                      | ode 2<br>value.<br>/el to " 7 ".<br>B'111)                                                 |             |         |
| nterrupt exc          | Interrupt Control Mode 0<br>Copy the CCR register value.<br>t the interrupt mask bit to "1 ".<br>(I bit in CCR = 1)                                                                                                                                                                                                            | Inter<br>Copy<br>Set the int<br>(I2 to I                           | rupt Control Mo<br>v EXR register v<br>v<br>terrupt mask lev<br>0 bits in EXR =                                                                                                                   | ode 2<br>/alue.<br>/el to " 7 ".<br>B'111)                                                 | <br>/lask   |         |
| nterrupt exc          | Interrupt Control Mode 0<br>Copy the CCR register value.<br>the interrupt mask bit to "1".<br>(I bit in CCR = 1)<br>Rewrite DTCER.                                                                                                                                                                                             | Inter<br>Copy<br>Set the inf<br>(I2 to I                           | rupt Control Mo<br>v EXR register v<br>v EXR register v<br>v errupt mask lev<br>0 bits in EXR =<br>v<br>Rewrite DTCER                                                                             | ode 2<br>/alue.<br>/el to " 7 ".<br>B'111)<br>2.                                           | _           |         |
| interrupt exc         | Interrupt Control Mode 0<br>Copy the CCR register value.<br>t the interrupt mask bit to "1 ".<br>(I bit in CCR = 1)                                                                                                                                                                                                            | Inter<br>Copy<br>Set the inf<br>(I2 to I                           | rupt Control Mo<br>v EXR register v<br>v<br>terrupt mask lev<br>0 bits in EXR =                                                                                                                   | ode 2<br>/alue.<br>/el to " 7 ".<br>B'111)<br>2.                                           | <br>/lask   |         |
|                       | Interrupt Control Mode 0<br>Copy the CCR register value.<br>t the interrupt mask bit to " 1 ".<br>(I bit in CCR = 1)<br>Rewrite DTCER.<br>Dummy-read DTCER.                                                                                                                                                                    | Inter<br>Copy<br>Set the int<br>(I2 to I<br>F<br>Du                | rupt Control Mo<br>v EXR register v<br>v errupt mask lev<br>0 bits in EXR =<br>v<br>Rewrite DTCER<br>v<br>mmy-read DTC                                                                            | ode 2<br>/alue.<br>/el to " 7 ".<br>B'111)<br>ER.<br>ER.                                   | <br>/lask   |         |
|                       | Interrupt Control Mode 0<br>Copy the CCR register value.<br>the interrupt mask bit to "1".<br>(I bit in CCR = 1)<br>Rewrite DTCER.                                                                                                                                                                                             | Inter<br>Copy<br>Set the int<br>(I2 to I<br>F<br>Du                | rupt Control Mo<br>v EXR register v<br>v EXR register v<br>v errupt mask lev<br>0 bits in EXR =<br>v<br>Rewrite DTCER                                                                             | <u>value.</u><br><u>vel to " 7 ".</u><br><u>B'111)</u><br><u>R.</u><br>ER.<br>level to the | <br>/lask   |         |
|                       | Interrupt Control Mode 0 Copy the CCR register value.  et the interrupt mask bit to " 1 ". (I bit in CCR = 1)  Rewrite DTCER.  Dummy-read DTCER.  turn the interrupt mask bit to the previous value.                                                                                                                           | Inter<br>Copy<br>Set the int<br>(I2 to I<br>F<br>Du                | rupt Control Mo<br>v EXR register v<br>v errupt mask lev<br>0 bits in EXR =<br>v<br>Rewrite DTCER<br>v<br>mmy-read DTC<br>v<br>interrupt mask<br>previous level.                                  | <u>value.</u><br><u>vel to " 7 ".</u><br><u>B'111)</u><br><u>R.</u><br>ER.<br>level to the | <br>/lask   |         |
|                       | Interrupt Control Mode 0<br>Copy the CCR register value.<br>to the interrupt mask bit to " 1 ".<br>(I bit in CCR = 1)<br>Rewrite DTCER.<br>Dummy-read DTCER.<br>turn the interrupt mask bit to the                                                                                                                             | Inter<br>Copy<br>Set the int<br>(I2 to I<br>F<br>Du                | rupt Control Mo<br>v EXR register v<br>v errupt mask lev<br>0 bits in EXR =<br>v<br>Rewrite DTCER<br>v<br>mmy-read DTC<br>v<br>interrupt mask                                                     | <u>value.</u><br><u>vel to " 7 ".</u><br><u>B'111)</u><br><u>R.</u><br>ER.<br>level to the | <br>/lask   |         |
|                       | Interrupt Control Mode 0 Copy the CCR register value.  Copy the interrupt mask bit to " 1 ". (I bit in CCR = 1)  Rewrite DTCER.  Dummy-read DTCER.  Lummy-read DTCER.  Lum the interrupt mask bit to the previous value.  Lum the interrupt mask bit to the previous value.  Lum the interrupt mask bit to the previous value. | Inter<br>Copy<br>Set the int<br>(12 to 1<br>I<br>Dur<br>Return the | rupt Control Mo<br>v EXR register v<br>v errupt mask lev<br>0 bits in EXR =<br>v<br>Rewrite DTCER<br>v<br>mmy-read DTC<br>v<br>mmy-read DTC<br>v<br>interrupt mask<br>previous level.<br>v<br>END | value.         /el to " 7 ".         B'111)         c.         BR.         level to the    | <br>/lask   |         |
|                       | Interrupt Control Mode 0 Copy the CCR register value.  Copy the interrupt mask bit to " 1 ". (I bit in CCR = 1)  Rewrite DTCER.  Dummy-read DTCER.  Lummy-read DTCER.  Lum the interrupt mask bit to the previous value.  Lum the interrupt mask bit to the previous value.  Lum the interrupt mask bit to the previous value. | Inter<br>Copy<br>Set the int<br>(12 to 1<br>I<br>Dur<br>Return the | rupt Control Mo<br>v EXR register v<br>v errupt mask lev<br>0 bits in EXR =<br>v<br>Rewrite DTCER<br>v<br>mmy-read DTC<br>v<br>interrupt mask<br>previous level.                                  | value.         /el to " 7 ".         B'111)         c.         BR.         level to the    | <br>/lask   |         |



2. Conditions on Which both DTC Activation and CPU Interrupt Exception Handling are Executed and Specific Executed

#### Operations

If the above preventive measure is not taken, both DTC activation and CPU interrupt exception handling may be executed when rewriting the DTC enable registers (DTCER) conflicts with generation of a DTC activation source interrupt.

If the above preventive measure is taken, CPU interrupt exception handling is not executed.



Figure 2 Execution of Both DTC Activation and CPU Interrupt Exception Handling

- 3. Conditions on Which a Double Interrupt is Caused and Executed Operations
- Conditions
- Interrupt control mode 2 is set (INTM1 bit in INTCR = 1).
- Interrupts A and B are enabled (interrupts A and B can be any interrupts).
- While interrupt A is processed, the DTC transfer enable register (DTCER) for interrupt B is rewritten.
- --- While interrupt A is processed, interrupt B is generated.

When all the above conditions are satisfied and rewriting the DTC enable register conflicts with generation of a DTC activation source interrupt B, double exception handling of interrupt A may be caused.

• Operations

As described above, when all the above listed conditions are satisfied and rewriting the DTCER for interrupt B conflicts with generation of interrupt B, double exception handling of interrupt A may be generated.

When such a conflict occurs, both a DTC transfer request and a CPU interrupt request may be generated. When both the requests are generated and the DTC transfer request priority is higher than the CPU interrupt request priority, the DTC transfer request is processed first, holding the CPU interrupt request pending.



After the DTC transfer is completed, the interrupt B source flag is cleared by the DTC. Due to this, exception handling of interrupt A, whose interrupt source flag has not been cleared, is erroneously executed again instead (double processing of interrupt A).

Figure 3 shows a double processing example of interrupt A and figure 4 shows an operation example when a preventive measure is taken.



Figure 3 Double Processing Example of Interrupt A



#### RENESAS TECHNICAL UPDATE TN-H8\*-A386A/E





### Reference Document

H8SX/1622 Group Hardware Manual (revision 1.00 REJ09B0414-0100) H8SX/1638 Group Hardware Manual (revision 1.00 REJ09B0364-0100) H8SX/1648 Group Hardware Manual (revision 1.00 REJ09B0365-0100) H8SX/1650 Group Hardware Manual (revision 2.00 REJ09B0311-0200) H8SX/1651 Group Hardware Manual (revision 2.00 REJ09B0248-0200) H8SX/1653 Group Hardware Manual (revision 1.00 REJ09B0219-0100) H8SX/1657 Group Hardware Manual (revision 2.00 REJ09B0341-0200) H8SX/1658R Group Hardware Manual (revision 1.00 REJ09B0341-0200) H8SX/1668R Group Hardware Manual (revision 1.00 REJ09B0413-0100) H8SX/1663 Group Hardware Manual (revision 1.00 REJ09B0413-0100)

