# Infineon TC275 Interrupt

Architecture and Compiler for Embedded System LAB.
School of Electronics Engineering, KNU, KOREA
2021-05-11



### **Hitex ShieldBuddy TC275**





- 1. External Request Input을 External Request Unit (ERU)이 처리함
  - ✓ 각 Input Channel에 있는 ERS에서 4개의 가능한 입력 중 하나의 입력 벡터를 선택함





Figure 7-40 External Request Unit Overview

- 1. External Request Input을 External Request Unit (ERU)이 처리함
  - ✓ 각 Input Channel에 있는 ETL이 지정된 엣지에서 입력을 트리거 이벤트로 전환함





Figure 7-40 External Request Unit Overview

- 1. External Request Input을 External Request Unit (ERU)이 처리함
  - ✓ Connecting Matrix는 입력 채널에서 생성된 이벤트를 출력 채널로 배포함





Figure 7-40 External Request Unit Overview

- 1. External Request Input을 External Request Unit (ERU)이 처리함
  - ✓ Output Gating Unit은 Input Channel로 부터의 트리거 이벤트와 상태 정보를 조합하여 출력을 내보냄
  - ✓ 하나의 이벤트가 여러 채널에 갈 수 있고 여러 이벤트가 하나의 채널에서 패턴을 만들 수 있음





Figure 7-40 External Request Unit Overview

- 2. ERU의 출력이 Interrupt Router (IR)의 입력이 됨
  - ✓ OGU에서 나온 출력이 연결된 Service Request Nodes (SRN)의 입력이 됨
  - ✓ SRN은 모든 Interrupt Control Units (ICU)에 연결되어 있고 Service Request Control Register (SRC) 설정을 통해 가능한 Service Provider (CPUO-2, DMA)에 매핑함
  - ✓ 각 ICU는 ICU에 매핑된 SRN의 Service Request 간의 인터럽트 중재를 처리함





Figure 16-1 Block Diagram of the TC27x Interrupt System

- External Interrupt를 사용하여 Switch를 눌렀을 때 LED Toggle
  - 1. 새로운 예제를 위한 프로젝트를 생성한다.
  - 2. 원하는 동작을 위해 레지스터와 메모리에 직접 접근해서 값을 써야한다.
  - 3. Switch 사용을 위해 Board Schematic과 Datasheet에서 Switch 연결 정보를 파악한다.
  - 4. External Interrupt를 사용하기 위해 Datasheet를 분석한다.
  - 5. 분석 결과를 활용해 임베디드 프로그래밍을 한다.

- 1. Switch 연결 정보 파악
  - ✓ Switch는 Easy Module Shield V1 확장 보드의 Pin D2/D3과 연결되어 있다.
  - ✓ Switch가 눌리면 연결된 Pin은 Low-level이 되고, Switch가 눌리지 않으면 연결된 Pin은 High-level이 된다.
  - ✓ 타겟 보드는 Easy Module Shield V1 확장 보드의 Pin D2/D3을 통해 Switch 입력을 받을 수 있다. (정상적인 Switch 동작을 위해 VCC 및 GND도 연결해야 한다.)





- 1. Switch 연결 정보 파악
  - ✓ TC275 보드의 Schematic과 Datasheet를 확인했을 때, Easy Module Shield V1 확장 보드의 **Pin D3**와 연결되는 IO는 **PORTO2의 Pin 1**다.





- 2. Data sheet 분석: IO 설정
  - ✓ Switch에 의한 External Interrupt를 사용하기 위해 연결된 Pin의 IO 설정이 필요하다.
  - ✓ Switch가 연결된 PORT02 Pin 1은 External Interrupt를 관리하는 SCU (System Control Unit) 내 ERU (External Request Unit)의 REQ14와 연결되어 있다.
  - ✓ 따라서, PORT02 Pin 1을 Input으로 설정하여 Switch 신호를 ERU의 입력으로 설정해야 한다.

| 2 | P02.1    | I  | LP/PU1 | General-purpose input  |
|---|----------|----|--------|------------------------|
|   | TIN1     |    | / VEXT | GTM input              |
|   | REQ14    |    |        | SCU input              |
|   | ARX2B    |    |        | ASCLIN2 input          |
|   | RXDCAN0A |    |        | CAN node 0 input       |
|   | RXDA2    |    |        | ERAY input             |
|   | CIFD1    |    |        | CIF input              |
|   | P02.1    | 00 |        | General-purpose output |
|   | TOUT1    | 01 |        | GTM output             |
|   | _        | 02 |        | Reserved               |
|   | SLSO32   | О3 |        | QSPI3 output           |
|   | DSCGPWMP | O4 |        | DSADC output           |
|   | _        | O5 | 1      | Reserved               |
|   | _        | O6 | 1      | Reserved               |
|   | COUT60   | 07 | 1      | CCU60 output           |

- 2. Data sheet 분석: PORT 설정 (1)
  - ✓ P02\_IOCR Register는 PORT02의 Input/Output을 설정한다.
  - ✓ Switch가 PORT02의 Pin 1에 연결되어 있기 때문에 PO2\_IOCRO Register의 PC1 bits를 설정한다.

Table 13-3 Registers Address Space

| Module | Base Address           | End Address            | Note    |  |
|--------|------------------------|------------------------|---------|--|
| P00    | F003 A000 <sub>H</sub> | F003 A0FF <sub>H</sub> | 13 pins |  |
| P01    | F003 A100 <sub>H</sub> | F003 A1FF <sub>H</sub> | 5 pins  |  |
| P02    | F003 A200 <sub>H</sub> | F003 A2FF <sub>H</sub> | 12 pins |  |
| P10    | F003 B000 <sub>H</sub> | F003 B0FF <sub>H</sub> | 9 pins  |  |
| P11    | F003 B100 <sub>H</sub> | F003 B1FF <sub>H</sub> | 16 pins |  |
| P12    | F003 B200 <sub>H</sub> | F003 B2FF <sub>H</sub> | 2 pins  |  |
| P13    | F003 B300 <sub>H</sub> | F003 B3FF <sub>H</sub> | 4 pins  |  |
| P14    | F003 B400 <sub>H</sub> | F003 B4FF <sub>H</sub> | 11 pins |  |
| P15    | F003 B500 <sub>H</sub> | F003 B5FF <sub>H</sub> | 9 pins  |  |

P02\_IOCR0 Register 주소: F003\_A210h (F003A200h + 10h)
P02\_IOCR0 Register 구조:

P02\_IOCR0
Port 02 Input/Output Control Register

| Port | 02 Iոլ | put/O | utput | Cont | rol R | egist              | er 0 |    |    |     |    |       |        |       |                   |
|------|--------|-------|-------|------|-------|--------------------|------|----|----|-----|----|-------|--------|-------|-------------------|
|      |        |       |       |      |       | (10 <sub>H</sub> ) |      |    |    |     |    | et Va | lue: 1 | 010 1 | 1010 <sub>H</sub> |
| 31   | 30     | 29    | 28    | 27   | 26    | 25                 | 24   | 23 | 22 | 21  | 20 | 19    | 18     | 17    | 16                |
|      |        | PC3   |       |      |       | 0                  |      |    |    | PC2 |    |       |        | 0     |                   |
|      | -      | rw    |       |      |       | r                  |      |    |    | rw  |    |       |        | r     |                   |
| 15   | 14     | 13    | 12    | 11   | 10    | 9                  | 8    | 7  | 6  | 5   | 4  | 3     | 2      | 1     | 0                 |
|      |        | PC1   |       |      |       | 0                  | 1    |    |    | PC0 |    |       |        | 0     | '                 |
|      |        | 5144  |       |      |       | -                  |      |    |    |     |    |       |        | -     | $\overline{}$     |

| Field                       | Bits                                      | Туре | Description                                                                                                                                             |
|-----------------------------|-------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| PC0,<br>PC1,<br>PC2,<br>PC3 | [7:3],<br>[15:11],<br>[23:19],<br>[31:27] | rw   | Port Control for Port n Pin 0 to 3  This bit field determines the Port n line x functionality (x = 0-3) according to the coding table (see Table 13-5). |
| 0                           | [2:0],<br>[10:8],<br>[18:16],<br>[26:24]  | r    | Reserved Read as 0; should be written with 0.                                                                                                           |



- 2. Data sheet 분석: PORT 설정 (2)
  - ✓ Easy Module Shield V1의 Switch는 pull-up device이다.
  - ✓ 따라서, PORT02의 Pin 1을 Input으로 설정할 때 PC1 bits를 0XX10b로 설정한다.

Table 13-5 PCx Coding

| PCx[4:0]           | I/O   | Characteristics | Selected Pull-up / Pull-down /<br>Selected Output Function |
|--------------------|-------|-----------------|------------------------------------------------------------|
| 0XX00 <sub>B</sub> | Input | _               | No input pull device connected, tri-state mode             |
| 0XX01 <sub>B</sub> |       |                 | Input pull-down device connected                           |
| 0XX10 <sub>B</sub> |       |                 | Input pull-up device connected <sup>1)</sup>               |
| 0XX11 <sub>B</sub> |       |                 | No input pull device connected, tri-state mode             |



#### 7.4.1.2 ERU Input Pin Connections



Figure 7-41 External Request Unit Input Connections for TC27x



- 2. Data sheet 분석 : ERU External Input Channel 설정 (1)
  - ✓ SCU\_EICR Register는 ERU의 External input Channel 0-7에 대한 설정을 한다.
  - ✓ 하나의 SCU\_EICR Register는 2개의 Channel에 대한 설정을 한다.
    (SCU\_EICRO: Channel 0-1, SCU\_EICR1: Channel 2-3, SCU\_EICR2: Channel 4-5, ...)
  - ✓ PORTO2 Pin 1과 연결된 REQ14가 **ERU의 Channel 2 Input 1**과 연결되어 있기 때문에 **SCU\_EICR1** Register의 INPO bits / EIENO bit / FENO bit / EXISO bits를 설정한다.

SCU\_EICR1 Register 주소: F003\_6214h (F0036000h + 214h)

Table 7-27 Registers Address Spaces - SCII Kernel Registers

#### SCU\_EICR1 Register 구조:

| Table                                   | e /-2 | , ,  | regist       | egisters Address Spaces - SCO Kerner Registers |           |          |                  |             |                |       |       |        |      |                   |    |  |
|-----------------------------------------|-------|------|--------------|------------------------------------------------|-----------|----------|------------------|-------------|----------------|-------|-------|--------|------|-------------------|----|--|
| Mod                                     | ule   |      | Base         | Addr                                           | ess       |          | End              | End Address |                |       |       |        | Note |                   |    |  |
| SCU                                     |       |      | F003         | 6000 <sub>l</sub>                              | Н         |          | F00              | 3 63F       | F <sub>H</sub> |       |       | -      |      |                   |    |  |
| EICR1 External Input Channel Register 1 |       |      |              |                                                |           | (21      | 4 <sub>H</sub> ) |             |                | Res   | et Va | lue: ( | 0000 | 0000 <sub>H</sub> |    |  |
| 31                                      | 30    | 29   | 28           | 27                                             | 26        | 25       | 24               | 23          | 22             | 21    | 20    | 19     | 18   | 17                | 16 |  |
| 0                                       |       | INP1 | '<br> <br> - | EI<br>EN1                                      | LD<br>EN1 | R<br>EN1 | F<br>EN1         | 0           |                | EXIS1 |       |        |      | )<br>)            |    |  |
| r                                       |       | rw   | -            | rw                                             | rw        | rw       | rw               | r           |                | rw    |       |        |      | r                 |    |  |
| 15                                      | 14    | 13   | 12           | 11                                             | 10        | 9        | 8                | 7           | 6              | 5     | 4     | 3      | 2    | 1                 | 0  |  |
| 0                                       |       | INP  | )            | EI<br>EN0                                      | LD<br>EN0 | R<br>EN0 | F<br>EN0         | 0           |                | EXIS0 |       |        | (    | )<br>D            |    |  |
| r                                       |       | rw   |              | rw                                             | rw        | rw       | rw               | r           |                | rw    |       |        |      | r                 |    |  |







#### 7.4.1.8 External Request Unit Registers

The External Input Channel Registers EICRi (i=0 to 3) for the 4 external input channels contain bits to configure the external request selection ERS and the event trigger logic ETL.

| EICR<br>Exter<br>EICR<br>Exter<br>EICR | rnal II<br>1<br>rnal II<br>2<br>rnal II | nput ( nput ( nput ( | Chan<br>Chan | nel R<br>nel R | egist<br>egist | er 1<br>er 2 | (21<br>(21 | 0 <sub>H</sub> ) 4 <sub>H</sub> ) 8 <sub>H</sub> ) C <sub>H</sub> ) |    |       | Res<br>Res | et Va<br>et Va | lue:<br>lue: | 0000<br>0000 | 0000 <sub>H</sub> |
|----------------------------------------|-----------------------------------------|----------------------|--------------|----------------|----------------|--------------|------------|---------------------------------------------------------------------|----|-------|------------|----------------|--------------|--------------|-------------------|
| 31                                     | 30                                      | 29                   | 28           | 27             | 26             | 25           | 24         | 23                                                                  | 22 | 21    | 20         | 19             | 18           | 17           | 16                |
| 0                                      |                                         | INP1                 |              | EI<br>EN1      | LD<br>EN1      | R<br>EN1     | F<br>EN1   | 0                                                                   |    | EXIS1 |            |                |              | 0            |                   |
| r                                      | -                                       | rw                   |              | rw             | rw             | rw           | rw         | r                                                                   |    | rw    |            |                |              | r            |                   |
| 15                                     | 14                                      | 13                   | 12           | 11             | 10             | 9            | 8          | 7                                                                   | 6  | 5     | 4          | 3              | 2            | 1            | 0                 |
| 0                                      |                                         | INP0                 |              | EI<br>EN0      | LD<br>EN0      | R<br>EN0     | F<br>EN0   | 0                                                                   |    | EXIS0 |            |                |              | 0            |                   |
| r                                      |                                         | rw                   |              | rw             | rw             | rw           | rw         | r                                                                   |    | rw    |            |                |              | r            |                   |

| Field | Bits  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EXIS0 | [6:4] | rw   | External Input Selection 0 This bit field determines which input line is selected for Input Channel (2i).  000 <sub>B</sub> Input (2i) 0 is selected  001 <sub>B</sub> Input (2i) 1 is selected  010 <sub>B</sub> Input (2i) 2 is selected  011 <sub>B</sub> Input (2i) 3 is selected  100 <sub>B</sub> Reserved  101 <sub>B</sub> Reserved  111 <sub>B</sub> Reserved  111 <sub>B</sub> Reserved |

User's Manual 7-239 V2.2, 2014-12 SCU, V3.8.9

| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEN0  | 8       | rw   | Falling Edge Enable 0 This bit determines if the falling edge of Input Channel (2i) is used to set bit INTF(2i).  0 <sub>B</sub> The falling edge is not used 1 <sub>B</sub> The detection of a falling edge of Input Channel 0 generates a trigger event. INTF(2i) becomes set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| REN0  | 9       | rw   | Rising Edge Enable 0 This bit determines if the rising edge of Input Channel (2*i) is used to set bit INTF(2i).  0 <sub>B</sub> The rising edge is not used 1 <sub>B</sub> The detection of a rising edge of Input Channel (2*i) generates a trigger event. INTF(2*i) becomes set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LDEN0 | 10      | rw   | Level Detection Enable 0 This bit determines if bit INTF(2i) is cleared automatically if an edge of the input Input Channel (2i) is detected, which has not been selected (rising edge with REN0 = 0 or falling edge with FEN0 = 0).  0 <sub>B</sub> Bit INTF(2i) will not be cleared 1 <sub>B</sub> Bit INTF(2i) will be cleared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| EIEN0 | 11      | rw   | External Input Enable 0 This bit enables the generation of a trigger event for request channel (2i) (e.g. for interrupt generation) when a selected edge is detected.  0 <sub>B</sub> The trigger event is disabled 1 <sub>B</sub> The trigger event is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| INP0  | [14:12] | rw   | Input Node Pointer  This bit field determines the destination (output channel) for trigger event (2i) (if enabled by EIEN(2i)).  000 <sub>B</sub> An event from input ETL 2i triggers output OGU0 (signal TR(2i) 0)  011 <sub>B</sub> An event from input ETL 2i triggers output OGU1 (signal TR(2i) 1)  010 <sub>B</sub> An event from input ETL 2i triggers output OGU2 (signal TR(2i) 2)  011 <sub>B</sub> An event from input ETL 2i triggers output OGU3 (signal TR(2i) 3)  100 <sub>B</sub> An event from input ETL 2i triggers output OGU4 (signal TR(2i) 0)  101 <sub>B</sub> An event from input ETL 2i triggers output OGU5 (signal TR(2i) 0)  110 <sub>B</sub> An event from input ETL 2i triggers output OGU5 (signal TR(2i) 0)  111 <sub>B</sub> An event from input ETL 2i triggers output OGU6 (signal TR(2i) 0)  111 <sub>B</sub> An event from input ETL 2i triggers output OGU6 (signal TR(2i) 0) |

- 2. Data sheet 분석 : ERU External Input Channel 설정 (2)
  - ✓ ERU의 각 External Input Channel은 여러 개의 External Request Input을 입력 받기 때문에 이들 중하나의 입력을 결정해야 한다.
  - ✔ PORT02 Pin 1이 ERU의 Channel 2 Input 1과 연결되어 있기 때문에 EXISO bits를 001b로



EICR1





- 2. Data sheet 분석 : ERU External Input Channel 설정 (3)
  - ✓ Switch가 pull-up device이기 때문에 Switch가 눌렸을 때, 신호는 High-level에서 Low-level로 바뀌며 Falling edge가 발생한다.
  - ✓ 따라서, Falling edge가 검출되었을 때 트리거 신호 (for External Interrupt)를 생성하기 위해 **FENO** bit를 1로 설정한다.
  - ✓ 생성된 트리거 신호를 Enable 하기 위해 EIENO bit를 1로 설정한다.

|   | EICR<br>Exter |    | nput ( | Chan | nel R     | egist     | er 1     | (21      | 4 <sub>H</sub> ) |    |       | Res | et Va | lue: 0 | 0000   | 0000 <sub>H</sub> |
|---|---------------|----|--------|------|-----------|-----------|----------|----------|------------------|----|-------|-----|-------|--------|--------|-------------------|
|   | 31            | 30 | 29     | 28   | 27        | 26        | 25       | 24       | 23               | 22 | 21    | 20  | 19    | 18     | 17     | 16                |
|   | 0             |    | INP1   |      | EI<br>EN1 | LD<br>EN1 | R<br>EN1 | F<br>EN1 | 0                |    | EXIS1 |     |       | '<br>' | ,<br>) |                   |
| ı | r             |    | rw     |      | rw        | rw        | rw       | rw       | r                | ı  | rw    |     |       |        | r      |                   |
|   | 15            | 14 | 13     | 12   | 11        | 10        | 9        | 8        | 7                | 6  | 5     | 4   | 3     | 2      | 1      | 0                 |
|   | 0             |    | INP0   |      | EI<br>EN0 | LD<br>EN0 | R<br>EN0 | F<br>EN0 | 0                |    | EXIS0 |     |       | (      | )<br>) |                   |
| ٠ | r             |    | rw     |      | rw        | rw        | rw       | rw       | r                | •  | rw    |     | •     |        | r      |                   |

| Field | Bits | Туре | Description                                                                                                                                                                                                                                                                                                                       |
|-------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FEN0  | 8    | rw   | Falling Edge Enable 0 This bit determines if the falling edge of Input Channel (2i) is used to set bit INTF(2i).  0 <sub>B</sub> The falling edge is not used 1 <sub>B</sub> The detection of a falling edge of Input Channel 0 generates a trigger event. INTF(2i) becomes set.                                                  |
| REN0  | 9    | rw   | Rising Edge Enable 0 This bit determines if the rising edge of Input Channel (2*i) is used to set bit INTF(2i).  0 <sub>B</sub> The rising edge is not used 1 <sub>B</sub> The detection of a rising edge of Input Channel (2*i) generates a trigger event. INTF(2*i) becomes set                                                 |
| LDEN0 | 10   | rw   | Level Detection Enable 0 This bit determines if bit INTF(2i) is cleared automatically if an edge of the input Input Channel (2i) is detected, which has not been selected (rising edge with REN0 = 0 or falling edge with FEN0 = 0).  0 <sub>B</sub> Bit INTF(2i) will not be cleared 1 <sub>B</sub> Bit INTF(2i) will be cleared |
| EIEN0 | 11   | rw   | External Input Enable 0 This bit enables the generation of a trigger event for request channel (2i) (e.g. for interrupt generation) when a selected edge is detected.  0 <sub>B</sub> The trigger event is disabled 1 <sub>B</sub> The trigger event is enabled                                                                   |

- 2. Data sheet 분석 : ERU External Input Channel 설정 (4)
  - ✓ ERU의 각 External Input Channel에서 생성된 트리거 신호는 Connecting Matrix를 통해 Output Channel에 전달된다.
  - ✓ Output Channel은 입력 받은 트리거 신호를 Interrupt 신호로 전달할 수 있다.
  - ✓ 생성된 트리거 신호를 Output Channel 0에 전달하기 위해 INPO bits를 000b로 설정한다.





Figure 7-40 External Request Unit Overview

- 2. Data sheet 분석 : ERU Flag Gating 설정 (1)
  - ✓ SCU\_IGCR Register는 ERU의 Output Channel 0-7에 대한 설정을 한다.
  - ✓ 하나의 SCU\_IGCR Register는 2개의 Channel에 대한 설정을 한다.(SCU\_IGCR0: Channel 0-1, SCU\_IGCR1: Channel 2-3, SCU\_IGCR2: Channel 4-5, ...)
  - ✓ External Input Channel 2에서 생성된 트리거 신호가 Output Channel 0에 전달되기 때문에 SCU\_IGCRO Register의 IGPO bits를 설정한다.

SCU\_IGCR0 Register 주소: F003\_622Ch (F0036000h + 22Ch)

SCU\_IGCR0 Register 구조:

| <b>Table 7-27</b> | Registers Address Spaces - SCU Kernel Registers |
|-------------------|-------------------------------------------------|
|-------------------|-------------------------------------------------|

| Modu | ıle        |           | Base  | Addı | ress |    | End | End Address Note        |            |            |            |            |            |            |                   |
|------|------------|-----------|-------|------|------|----|-----|-------------------------|------------|------------|------------|------------|------------|------------|-------------------|
| SCU  |            |           | F003  | 6000 | Н    |    | FOC | 003 63FF <sub>H</sub> - |            |            |            |            |            |            |                   |
| IGCR | 20         |           |       |      |      |    |     |                         |            |            |            |            |            |            |                   |
| Flag | Gatir      | ıg Re     | giste | r 0  |      |    | (22 | 2C <sub>H</sub> )       |            |            | Res        | et Va      | lue: (     | 0000       | 0000 <sub>H</sub> |
| 31   | 30         | 29        | 28    | 27   | 26   | 25 | 24  | 23                      | 22         | 21         | 20         | 19         | 18         | 17         | 16                |
| IG   | P1         | GE<br>EN1 |       |      | 0    |    |     | IPEN<br>17              | IPEN<br>16 | IPEN<br>15 | IPEN<br>14 | IPEN<br>13 | IPEN<br>12 | IPEN<br>11 | IPEN<br>10        |
| r    | W          | rw        |       |      | r    |    |     | rw                      | rw         | rw         | rw         | rw         | rw         | rw         | rw                |
| 15   | 14         | 13        | 12    | 11   | 10   | 9  | 8   | . 7                     | 6          | 5          | 4          | 3          | 2          | 1          | 0                 |
| IG   | <b>P</b> 0 | GE        |       | 1    | 0    | 1  | 1   | IPEN<br>07              | IPEN<br>06 | IPEN<br>05 | IPEN<br>04 | IPEN       | IPEN       | IPEN<br>01 | IPEN              |



- 2. Data sheet 분석 : ERU Flag Gating 설정 (2)
  - ✓ 트리거 신호를 IOUT (for External Interrupt)으로 출력하기 위해 IGPO bits를 01b로 설정한다.

| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IGP0  | [15:14] | rw   | Interrupt Gating Pattern 0 In each register IGCRj, bit field IGP0 determines how the pattern detection influences the output lines GOUT(2j) and IOUT(2j).  00 <sub>B</sub> IOUT(2j) is inactive. The pattern is not considered.  01 <sub>B</sub> IOUT(2j) is activated in response to a trigger event. The pattern is not considered.  10 <sub>B</sub> The detected pattern is considered. IOUT(2j) is activated if a trigger event occurs while the pattern is present.  11 <sub>B</sub> The detected pattern is considered. IOUT(2j) is activated if a trigger event occurs while the pattern is not present. |

| EICR0 | External Input<br>Channel Register 0 | 210 <sub>H</sub> | U, SV | U, SV, P | Application<br>Reset | Page<br>7-239 |
|-------|--------------------------------------|------------------|-------|----------|----------------------|---------------|
| EICR1 | External Input<br>Channel Register 1 | 214 <sub>H</sub> | U, SV | U, SV, P | Application<br>Reset | Page<br>7-239 |
| EICR2 | External Input<br>Channel Register 3 | 218 <sub>H</sub> | U, SV | U, SV, P | Application<br>Reset | Page<br>7-239 |
| EICR3 | External Input<br>Channel Register 4 | 21C <sub>H</sub> | U, SV | U, SV, P | Application<br>Reset | Page<br>7-239 |
| EIFR  | External Input Flag<br>Register      | 220 <sub>H</sub> | U, SV | BE       | Application<br>Reset | Page<br>7-243 |
| FMR   | Flag Modification<br>Register        | 224 <sub>H</sub> | U, SV | U, SV, P | Application<br>Reset | Page<br>7-244 |
| PDRR  | Pattern Detection<br>Result Register | 228 <sub>H</sub> | U, SV | BE       | Application<br>Reset | Page 7-245    |

User's Manual SCU, V3.8.9

7-313

V2.2, 2014-12



TC27x D-Step

Table 7-28 Register Overview of SCU (Offset from Main Register Base)

| Short Name | Long Name                      | Offset           | Access | s Mode   | Reset                | Descr<br>iption<br>See |  |
|------------|--------------------------------|------------------|--------|----------|----------------------|------------------------|--|
|            |                                | Addr.            | Read   | Write    |                      |                        |  |
| IGCR0      | Interrupt Gating<br>Register 0 | 22C <sub>H</sub> | U, SV  | U, SV, P | Application<br>Reset | Page<br>7-246          |  |
| IGCR1      | Interrupt Gating<br>Register 1 | 230 <sub>H</sub> | U, SV  | U, SV, P | Application<br>Reset | Page<br>7-246          |  |
| IGCR2      | Interrupt Gating<br>Register 2 | 234 <sub>H</sub> | U, SV  | U, SV, P | Application<br>Reset | Page<br>7-246          |  |
| IGCR3      | Interrupt Gating<br>Register 3 | 238 <sub>H</sub> | U, SV  | U, SV, P | Application<br>Reset | Page<br>7-246          |  |

| Table 2        | Access Terms                                                                                                                                                                          |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol         | Description                                                                                                                                                                           |
| U              | Access Mode: Access permitted in User Mode 0 or 1.                                                                                                                                    |
|                | Reset Value: Value or bit is not changed by a reset operation.                                                                                                                        |
| SV             | Access permitted only in Supervisor Mode.                                                                                                                                             |
| R              | Read-only register.                                                                                                                                                                   |
| 32             | Only 32-bit word accesses are permitted to this register/address range.                                                                                                               |
| 32/16          | Only 32-bit or 16-bit acesses are permitted to this register/address range.                                                                                                           |
| CEx            | CPUx Endinit protected register/address.                                                                                                                                              |
| SE             | Safety Endinit protected register/address.                                                                                                                                            |
| E              | Any CPU Endinit-protected register/address.                                                                                                                                           |
| P (or P0 / P1) | Access Enable Register protected register/address. (ACCEN0/1)                                                                                                                         |
| PW             | Password-protected register/address.                                                                                                                                                  |
| NC             | No change, indicated register is not changed.                                                                                                                                         |
| BE             | Indicates that an access to this address range generates a Bus Error.                                                                                                                 |
| nBE            | Indicates that no Bus Error is generated when accessing this address range, even though it is either an access to an undefined address or the access does not follow the given rules. |

Indicates that no Error is generated when accessing this address or address range, even though the access is to an undefined address or

address range. True for CPU accesses (MTCR/MFCR) to undefined

#### 1.1.5 Abbreviations and Acronyms

nΕ

The following acronyms and terms are used in this document:

addresses in the CSFR range.

| ADC    | Analog-to-Digital Converter                         |
|--------|-----------------------------------------------------|
| ALU    | Arithmetic and Logic Unit                           |
| ASCLIN | Asynchronous/Synchronous Serial Controller with LIN |
| BCU    | Bus Control Unit                                    |
| BROM   | Boot ROM & Test ROM                                 |
| CAN    | Controller Area Network                             |
| CAPCOM | Capture Compare Unit                                |
|        |                                                     |

User's Manual 1-4 V2.2, 2014-7



TC27x D-Step

#### Password Access to WDTxCON0

A correct password must be written to register WDTxCON0 (x=S CPU0,CPU1 or CPU2) in order to unlock it for modifications. Software must either know the correct password in advance or compute it at runtime. The passwords for each of the Watchdogs (x=S,CPU0,CPU1 or CPU2) can be different in order to provide independent watchdog functionality program flows to have independent watchdog functions.

The Safety Watchdog password register WDTSCON0 is protected by the generic SCU protection scheme which allows only configured master(s) to have write access (See ACCEN0).

CPU-specific Watchdog password registers WDTCPUyCON0 are individually protected such that they may only be written by the corresponding CPUy

A watchdog may be used within a safety application to provide a recovery time period during which software might attempt to recover from a safety alarm warning. To ensure that a CPU fault could not allow a fault to be ignored an option is provided to prevent watchdog unlocking if the Safety Management Unit (SMU) is not in the RUN state. This option may be enabled by bit WDTxCON0.UR.

If the password is valid and the SMU state meets the requirements of the WDTxCON0.US bit then WDTxCON0 will be unlocked as soon as the Password Access is completed. The unlocked condition will be indicated by WDTxCON0.LCK = 0. To ensure the correct servicing sequence, a password access is only permitted when the WDTxCON0.LCK bit was set prior to the access.

If an improper password value is written to WDTxCON0 during the Password Access, a Watchdog Access Error condition exists. Bit WDTxSR.AE is set and an alarm request is sent to the Safety Management Unit (SMU).

The 14-bit user-definable password, WDTxCON0.PW, provides additional options for adjusting the password requirements to the application's needs. It can be used, for instance, to detect unexpected software loops, or to monitor the execution sequence of routines.

Table 7-24 summarizes the requirements for the password. Various options exist, which are described in more detail below



TC27x D-Step

#### 7.4.8.3 SCU Access Restriction Registers

The Access Enable Register 0 restricts write access to all SCU registers so that they may only be written by specified bus masters (eg CPUs). See the Bus chapter for the mapping of TAG ID to specific system masters and CPUs).

#### ACCEN0

| Acce     |          | nable    | Regi     | ster 0   | )        |          | (3F      | C <sub>H</sub> ) |          |          | Rese     | t Val    | ue: Fl   | FFF F    | FFF <sub>H</sub> |
|----------|----------|----------|----------|----------|----------|----------|----------|------------------|----------|----------|----------|----------|----------|----------|------------------|
| 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       | 23               | 22       | 21       | 20       | 19       | 18       | 17       | 16               |
| EN<br>31 | EN<br>30 | EN<br>29 | EN<br>28 | EN<br>27 | EN<br>26 | EN<br>25 | EN<br>24 | EN<br>23         | EN<br>22 | EN<br>21 | EN<br>20 | EN<br>19 | EN<br>18 | EN<br>17 | EN<br>16         |
| rw               | rw       | rw       | rw       | rw       | rw       | rw       | rw               |
| 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        | 7                | 6        | 5        | 4        | 3        | 2        | 1        | 0                |
| EN<br>15 | EN<br>14 | EN<br>13 | EN<br>12 | EN<br>11 | EN<br>10 | EN9      | EN8      | EN7              | EN6      | EN5      | EN4      | EN3      | EN2      | EN1      | EN0              |
| rw               | rw       | rw       | rw       | rw       | rw       | rw       | rw               |

| Field      | Bits | Туре | Description                                                                                                                                                                                       |
|------------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ENn        | n    | rw   | Access Enable for Master TAG ID n                                                                                                                                                                 |
| (n = 0-31) |      |      | This bit enables write access to the SCU kernel addresses for transactions with the Master TAG ID n 0 <sub>B</sub> Write access will not be executed 1 <sub>B</sub> Write access will be executed |

#### ACCEN1

| Acce |    | nable | Regi | ster 1 |    |    | (3F    | 8 <sub>H</sub> ) |    |    | Res | et Va | lue: ( | 0000 | 0000 <sub>H</sub> |
|------|----|-------|------|--------|----|----|--------|------------------|----|----|-----|-------|--------|------|-------------------|
| 31   | 30 | 29    | 28   | 27     | 26 | 25 | 24     | 23               | 22 | 21 | 20  | 19    | 18     | 17   | 16                |
|      |    | ı     | 1    | ı      | ı  |    | '      | 0                | 1  | 1  | ı   |       |        | ı    | '                 |
|      |    |       |      |        |    |    |        | r                | -  | -  |     |       |        |      |                   |
| 15   | 14 | 13    | 12   | 11     | 10 | 9  | 8      | 7                | 6  | 5  | 4   | 3     | 2      | 1    | 0                 |
|      | ı  | 1     |      | 1      | 1  |    | '<br>' | 0                |    |    | 1   |       |        | 1    | <u> </u>          |
|      |    |       |      |        |    |    |        | r                |    |    |     |       |        |      |                   |

 User's Manual
 7-266
 V2.2, 2014-12
 User's Manual
 7-309
 V2.2, 2014-12

 SCU. V3.8.9
 SCU. V3.8.9
 SCU. V3.8.9

- 2. Data sheet 분석 : Safety Critical Register 설정 (1)
  - ✓ 설정해야 하는 SCU\_EICR1 / SCU\_IGCR0 Register는 Safety Critical Register이기 때문에 Write Protected (Safety ENDINIT, End-of-Initialization) 되어 있다.
  - ✓ 해당 Register를 수정하기 위해서는 Safety ENDINIT을 해제해야 한다.
  - ✓ SCU\_WDTSCONO Register는 Safety Critical Register에 대한 Safety ENDINIT을 설정/해제한다.

SCU\_WDTSCON0 Register 주소: F003\_60F0h (F0036000h + 0F0h)

#### SCU\_WDTSCON0 Register 구조:

| Table 7-27    | Registers Address S     | paces - SCU Kerne      | el Registers                        |
|---------------|-------------------------|------------------------|-------------------------------------|
| Module<br>SCU | Base Address            | End Address            | Note                                |
| SCU           | F003 6000 <sub>H</sub>  | F003 63FF <sub>H</sub> | -                                   |
| WDTSCON       | )<br>Control Register 0 | (0F0 <sub>H</sub> )    | Reset Value: FFFC 000E <sub>⊾</sub> |

| S | afet | y WE | T Co | ntrol | Regi | ster 0 | )  | (OF | 0 <sub>H</sub> ) |    |    | Rese | t Val | ue: Fl | FFC ( | 000E <sub>H</sub> |
|---|------|------|------|-------|------|--------|----|-----|------------------|----|----|------|-------|--------|-------|-------------------|
| ; | 31   | 30   | 29   | 28    | 27   | 26     | 25 | 24  | 23               | 22 | 21 | 20   | 19    | 18     | 17    | 16                |
|   |      | I    | I    | I     | I    | I      | ı  | R   | EL               | ı  | I  | I    | ı     | I      | I     | '                 |
|   |      | l    |      |       |      | 1      |    | r   | W                | l  | l  |      |       | l      |       |                   |





- 2. Data sheet 분석 : Safety Critical Register 설정 (2)
  - ✓ ENDINIT bit는 Safety ENDINIT의 설정 상태를 나타내며 Modify Access를 통해서만 수정이 가능하다.
  - ✓ **LCK bit**는 SCU\_WDTSCONO Register의 Lock 상태를 나타내며 해당 Register의 Lock 상태는 Password Access를 통해 Unlock 되고, Modify Access를 통해 Lock 된다.
  - ✓ **PW bits**는 SCU\_WDTSCON0 Register에 접근하기 위한 Password를 저장하며 해당 값을 읽으면 bits[7:2]가 반전되어 읽힌다.

| Field   | Dita | Turns | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field   | Bits | Туре  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ENDINIT | 0    | rwh   | End-of-Initialization Control Bit  0 <sub>B</sub> Access to Endinit-protected registers is permitted.  1 <sub>B</sub> Access to Endinit-protected registers is not permitted.  This bit must be written with a '1' during a Password Access or Check Access (although this write is only used for the password-protection mechanism and is not stored). This bit must be written with the required ENDINIT update value during a Modify Access.                                                                                                                                                                                                                                                                                                                |
| LCK     | 1    | rwh   | Lock Bit to Control Access to WDTxCON0  0 <sub>B</sub> Register WDTxCON0 is unlocked  1 <sub>B</sub> Register WDTxCON0 is locked   (default after ApplicationReset)  The current value of LCK is controlled by hardware. It is cleared after a valid Password Access to WDTxCON0 when WDTxSR.US is 0 (or when WDTxSR.US is 1 and the SMU is in RUN mode), and it is automatically set again after a valid Modify Access to WDTxCON0. During a write to WDTxCON0, the value written to this bit is only used for the password-protection mechanism and is not stored.  This bit must be cleared during a Password Access to WDTxCON0, and set during a Modify Access to WDTxCON0, and set during a Modify Access to WDTxCON0, and set during a Modify Access to |

| WDTxCON0 This bit field is written with an initial password value during a Modify Access. A read from this bitfield returns this initial password, but bits [7:2] are inverted (toggled) to ensure that a simple read/write is not sufficient to service the WDT.                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| If corresponding WDTxSR.PAS = 0 then this bit field must be written with its current contents during a Password Access or Check Access.  If corresponding WDTxSR.PAS = 1 then this bit field must be written with the next password in the LFSR sequence during a Password Access or Check Access |
| The default password after Application Reset is 00000000111100 <sub>B</sub>                                                                                                                                                                                                                       |
| A-step silicon: Bits [7:2] must be written with 111100 <sub>B</sub> during Password Access and Modify Access. Read returns 000011 <sub>B</sub> for these bits.                                                                                                                                    |

User-Definable Password Field for Access to

- 2. Data sheet 분석 : Safety Critical Register 설정 (3)
  - ✓ SCU\_WDTSCONO Register에 적절한 값을 Write하여 Password Access를 수행한다.
  - ✓ Password Access는 SCU\_WDTSCONO Register의 Lock 상태를 해제하며 과정은 다음과 같다.
    - 1. SCU\_WDTSCONO Register의 값을 읽어 REL bits, PW bits를 파악한다.
    - 2. Bits[7:2] (PW bits의 일부)가 반전되어 읽히기 때문에 이를 반전시켜 정확한 PW bits를 얻는다.
    - 3. Write 할 값의 bits[31:16]은 읽혀진 REL bits 값으로 설정하고 bit[15:2]는 앞서 구한 정확한 PW bits 값으로 설정한다.
    - 4. Write 할 값의 bit[1]은 unlock(write 0) 후, bit[0]은 0으로 설정한다. (Safety ENDINIT 설정: bit[0] = 1, Safety ENDINIT 해제 : bit[0] = 0)
    - 5. 설정된 값을 SCU\_WDTSCONO Register에 한번에 쓴다.
    - 6. SCU\_WDTSCONO Register의 LCK bit를 확인하여 Lock 상태가 해제되었는지 파악한다.
      (Password Access가 정상적으로 수행되면 Lock 상태가 해제되며 LCK bit가 0으로 설정된다.)
  - ✔ Password Access를 통해 SCU\_WDTSCONO Register의 Lock 상태가 해제되면 Modify Access를

- 2. Data sheet 분석 : Safety Critical Register 설정 (4)
  - ✓ SCU\_WDTSCONO Register에 적절한 값을 Write하여 Modify Access를 수행한다.
  - ✓ Modify Access는 Safety ENDINIT을 설정/해제하며 과정은 다음과 같다.
    - 1. SCU\_WDTSCONO Register의 값을 읽어 REL bits, PW bits를 파악한다.
    - 2. Bits[7:2] (PW bits의 일부)가 반전되어 읽히기 때문에 이를 반전시켜 정확한 PW bits를 얻는다.
    - 3. Write 할 값의 bits[31:16]은 읽혀진 REL bits 값으로 설정하고 bit[15:2]는 앞서 구한 정확한 PW bits 값으로 설정한다.
    - 4. Write 할 값의 bit[1]은 unlock(write 0) 후, bit[0]은 1로 설정한다. (Safety ENDINIT 설정: bit[0] = 1, Safety ENDINIT 해제 : bit[0] = 0)
    - 5. 설정된 값을 SCU\_WDTSCONO Register에 한번에 쓴다.
    - 6. SCU\_WDTSCONO Register의 LCK bit를 확인하여 Lock 상태가 다시 설정되었는지 파악한다. (Modify Access가 정상적으로 수행되면 Lock 상태가 설정되며 LCK bit가 1로 설정된다.)
  - ✓ Modify Access를 통해 Safety ENDINIT을 해제하면 Safety Critical Register를 수정할 수 있으며

- 2. Data sheet 분석 : Safety Critical Register 설정 (2)
  - ✓ ENDINIT bit는 Safety ENDINIT의 설정 상태를 나타내며 Modify Access를 통해서만 수정이 가능하다.
  - ✓ **LCK bit**는 SCU\_WDTSCONO Register의 Lock 상태를 나타내며 해당 Register의 Lock 상태는 Password Access를 통해 Unlock 되고, Modify Access를 통해 Lock 된다.
  - ✓ PW bits는 SCU\_WDTSCONO Register에 접근하기 위한 Password를 저장하며 해당 값을 읽으면

| Field   | Bits | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ENDINIT | 0    | rwh  | End-of-Initialization Control Bit  0 <sub>B</sub> Access to Endinit-protected registers is permitted.  1 <sub>B</sub> Access to Endinit-protected registers is not permitted.  This bit must be written with a '1' during a Password Access or Check Access (although this write is only used for the password-protection mechanism and is not stored). This bit must be written with the required ENDINIT update value during a Modify Access.                                                                                                                                                                                                                                    |
| LCK     | 1    | rwh  | Lock Bit to Control Access to WDTxCON0  0 <sub>B</sub> Register WDTxCON0 is unlocked  1 <sub>B</sub> Register WDTxCON0 is locked     (default after ApplicationReset)  The current value of LCK is controlled by hardware. It is cleared after a valid Password Access to WDTxCON0 when WDTxSR.US is 0 (or when WDTxSR.US is 1 and the SMU is in RUN mode), and it is automatically set again after a valid Modify Access to WDTxCON0. During a write to WDTxCON0, the value written to this bit is only used for the password-protection mechanism and is not stored.  This bit must be cleared during a Password Access to WDTxCON0, and set during a Modify Access to WDTxCON0. |

| PW | [15:2] | rwh | User-Definable Password Field for Access to WDTxCON0  This bit field is written with an initial password value.                                                                                                                                                                                   |
|----|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |        |     | This bit field is written with an initial password value during a Modify Access.  A read from this bitfield returns this initial password, but bits [7:2] are inverted (toggled) to ensure that a simple read/write is not sufficient to service the WDT.                                         |
|    |        |     | If corresponding WDTxSR.PAS = 0 then this bit field must be written with its current contents during a Password Access or Check Access.  If corresponding WDTxSR.PAS = 1 then this bit field must be written with the next password in the LFSR sequence during a Password Access or Check Access |
|    |        |     | The default password after Application Reset is 00000000111100 <sub>B</sub>                                                                                                                                                                                                                       |
|    |        |     | A-step silicon: Bits [7:2] must be written with 111100 <sub>B</sub> during Password Access and Modify Access. Read returns 000011 <sub>B</sub> for these bits.                                                                                                                                    |

- 2. Data sheet 분석 : Interrupt Router 설정 (1)
  - ✔ Interrupt Router는 Interrupt Trigger를 Service Providers (CPU 0-2, DMA)에 연결한다.
  - ✓ Switch 신호에 따라 ERU에서 생성된 트리거 신호는 Output Channel 0의 IOUT으로 출력된다.
  - ✓ 해당 출력은 Interrupt Router의 SCUERUO SRN (Service Request Node)와 연결된다.
  - ✓ 해당 노드에 대한 설정을 하기 위해 SRC\_SCUERUO Register를 설정해야 한다.





Figure 16-1 Block Diagram of the TC27x Interrupt System

- 2. Data sheet 분석 : Interrupt Router 설정 (2)
  - ✓ SRC\_SCUERUO Register는 SCUERUO SRN에 대한 Interrupt 설정을 한다.
  - ✓ 해당 Interrupt의 우선순위를 설정하기 위해 SRPN bits를 Ah (임의의 값)로 설정한다. (우선순위는 해당 Interrupt가 할당된 Service Provider에서 Interrupt Vector Table의 Index가 된다.)
  - ✓ 해당 Interrupt가 CPU0에서 처리되도록 하기 위해 TOS bits를 0h로 설정한다.
  - ✓ 해당 Interrupt를 Enable 하기 위해 SRE bit를 1로 설정한다.

Note

SRC\_SCUERU0 Register 주소: F003\_8CD4h (F0038000h + CD4h)

#### SRC\_SCUERU0 Register 구조:

Race Address

Modula

Table 16-3 Registers Address Space - Service Request Control Registers (SRC)

End Address

| WOO                                                              | uie        |        |            | Das | e Au                   | aress            |        | Ena Address |                        |        |      | Note              |    |    |    |
|------------------------------------------------------------------|------------|--------|------------|-----|------------------------|------------------|--------|-------------|------------------------|--------|------|-------------------|----|----|----|
| SRC                                                              |            |        |            | F00 | F003 8000 <sub>H</sub> |                  |        |             | F003 9FFF <sub>H</sub> |        |      |                   |    |    |    |
| SRC_SCUERUm (m=0-3) SCU ERU Service Request m (0CD4 <sub>H</sub> |            |        |            |     | +m*4                   | l <sub>н</sub> ) |        | Res         | et Va                  | lue: ( | 0000 | 0000 <sub>H</sub> |    |    |    |
| 31                                                               | 30         | 29     | 28         | 27  | 26                     | 25               | 24     | 23          | 22                     | 21     | 20   | 19                | 18 | 17 | 16 |
| Rese<br>rved                                                     | SWS<br>CLR | SVVS   | IOVC<br>LR | IOV | SET<br>R               | CLR<br>R         | SRR    |             | )<br>)                 |        | 1    | E                 | cc | 1  |    |
| rh                                                               | W          | rh     | W          | rh  | W                      | W                | rh     |             | r                      | •      |      | rv                | vh |    |    |
| 15                                                               | 14         | 13     | 12         | 11  | 10                     | 9                | 8      | 7           | 6                      | 5      | 4    | 3                 | 2  | 1  | 0  |
|                                                                  | 0          | '<br>' | TC         | os  | SRE                    | (                | )<br>) |             | 1                      |        | SR   | PN                | 1  |    |    |
|                                                                  | r          |        | r          | N   | rw r                   |                  | r      |             |                        |        | r    | W                 |    |    |    |

| Field | Bits    | Туре | Description                                                                                                                                                                                                                                                                                                             |
|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRPN  | [7:0]   | rw   | Service Request Priority Number  00 <sub>H</sub> Service request is on lowest priority  01 <sub>H</sub> Service request is one before lowest priority   FF <sub>H</sub> Service request is on highest priority  Note: For a CPU 01H is the lowest priority as 00H is never serviced. For the DMA 00H triggers channel 0 |
| SRE   | 10      | rw   | Service Request Enable  0 <sub>B</sub> Service request is disabled  1 <sub>B</sub> Service request is enabled                                                                                                                                                                                                           |
| тоѕ   | [12:11] | rw   | Type of Service Control  0 <sub>H</sub> CPU0 service is initiated  1 <sub>H</sub> CPU1 service is initiated  2 <sub>H</sub> CPU2 service is initiated  3 <sub>H</sub> DMA service is initiated                                                                                                                          |

### 3. 프로그래밍

- 1) Switch 및 LED가 연결된 PORT에 대한 설정을 수행하는 함수를 구현한다.
  - ✓ 자세한 내용은 이전 강의자료 (GPIO)를 참고한다.

```
#define PORT10 BASE
                            (0xF003B000)
32 #define PORT10 IOCR0
                           (*(volatile unsigned int*)(PORT10_BASE + 0x10))
   #define PORT10 OMR
                           (*(volatile unsigned int*)(PORT10 BASE + 0x04))
34
   #define PC1
                           11
   #define PC2
                           19
38 #define PCL1
                           17
39 #define PCL2
                           18
40 #define PS1
                           1
41 #define PS2
```

PORT13 IO (LED RED) 설정관련 레지스터 주소 및 비트 필드 정의

PORT13 IO (LED RED) 설정 초기화 코드



### 3. 프로그래밍

- 1) Switch 및 LED가 연결된 PORT에 대한 설정을 수행하는 함수를 구현한다.
  - ✓ 자세한 내용은 이전 강의자료 (GPIO)를 참고한다.

```
/* Define PORT02 Registers for Switch2 */
41 #define PORT02_BASE (0xF003A200)
42 #define PORT02_IOCR0 (*(volatile unsigned int*)(PORT02_BASE + 0x10))
43 #define PORT02_IN (*(volatile unsigned int*)(PORT02_BASE + 0x24))
44 
45 #define PC1 11
46 #define P1 1
```

PORT02 IO (Switch2) 설정관련 레지스터 주소 및 비트 필드 정의

PORT02 IO (Switch2) 설정 코드

### 3. 프로그래밍

- 2) ERU를 설정하기 위한 함수를 구현한다.
  - ① SCU\_WDTSCONO Register를 통해 Password/Modify Access를 수행하여 Safety ENDINIT을 해제한다.
  - ② SCU\_EICR1 Register를 통해 ERU의 Channel 2의 입력으로 Input 1을 설정한다.
  - ③ SCU\_EICR1 Register를 통해 Falling edge가 트리거 신호를 생성하도록 설정하고 이를 Enable 한다.
  - ④ SCU\_EICR1 Register를 통해 생성된 트리거 신호가 Output Channel 0에 전달되도록 한다.
  - ⑤ SCU\_IGCRO Register를 통해 전달된 트리거 신호가 IOUT으로 출력되도록 설정한다.
  - ⑥ SCU\_WDTSCONO Register를 통해 Password/Modify Access를 수행하여 Safety ENDINIT을 설정한다.
  - ⑦ SRC\_SCUERU0 Register를 통해 SCUERU0 SRN의 우선순위를 설정한다.
  - ⑧ SRC\_SCUERUO Register를 통해 SCUERUO SRN의 처리가 CPUO에서 수행되도록 설정한다.
  - ⑨ SRC\_SCUERUO Register를 통해 SCUERUO SRN의 Interrupt를 Enable 한다.

### 3. 프로그래밍

2) ERU를 설정하기 위한 함수를 구현한다.

```
// SCU Registers
#define SCU_BASE (0xF0036000)

#define SCU_WDTSCON0 (*(volatile unsigned int*)(SCU_BASE + 0x0F0))

#define SCU_EICR1 (*(volatile unsigned int*)(SCU_BASE + 0x214))

#define SCU_IGCR0 (*(volatile unsigned int*)(SCU_BASE + 0x22C))
#define LCK
#define ENDINIT
#define INPO
#define EIEN0
#define FEN0
#define EXISO
#define IGP0
// SRC Registers
#define SRC_BASE (0xF0038000)
#define SRC_SCUERU0 (*(volatile unsigned int*)(SRC_BASE + 0xCD4))
#define TOS
#define SRE
                                       10
#define SRPN
```

ERU 설정관련 레지스터 주소 및 비트 필드 정의



- 3. 프로그래밍
  - 2) ERU를 설정하기 위한 함수를 구현한다.

```
93 /* Initialize External Request Unit (ERU) */
 94⊖ void init ERU(void)
        /* ERU Input Channel 2 Setting */
        /* Password Access to unlock WDTSCON0 */
        SCU_WDTSCON0 = ((SCU_WDTSCON0 ^ 0xFC) & \sim (1 << LCK)) | (1 << ENDINIT);
        while((SCU WDTSCON0 & (1 << LCK)) != 0);
101
        // Modify Access to clear ENDINIT bit
        SCU WDTSCONØ = ((SCU WDTSCONØ ^ ØxFC) | (1 << LCK)) & ~ (1 << ENDINIT);
103
        while((SCU WDTSCON0 & (1 << LCK)) == 0);
105 (2)
        SCU EICR1 &= ~((0x7) << EXISO);
                                                  // External input 1 is selected
106
        SCU EICR1 |= ((0x1) << EXISO);
107
        SCU EICR1 |= (1 << FEN0);
108
                                                  // Falling edge enable
110
        SCU EICR1 |= ((0x1) << EIEN0);
                                                  // The trigger event is enabled
111
112
        SCU EICR1 &= ~((0x7) << INP0);
                                                  // An event from input ETL 2 triggers output OGU 0
113
114
        SCU IGCR0 &= ~((0x3) << IGP0);
                                                  // IOUT(0) is activated in response to a trigger event
115
        SCU IGCR0 |= ((0x1) << IGP0);
                                                   // The pattern is not considered
116
        /* Password Access to unlock WDTSCON0 */
while((SCU WDTSCON0 & (1 << LCK)) != 0);</pre>
120
121
        /* Modify Access to set ENDINIT bit */
122
        SCU WDTSCON0 = ((SCU WDTSCON0 ^ 0xFC) | (1 << LCK)) | (1 << ENDINIT);
123
        while((SCU WDTSCON0 & (1 << LCK)) == 0);
124
        /* SRC Interrupt Setting For ECU */
126
        SRC_SCUERU0 &= ~((0xFF) << SRPN);</pre>
                                                   // Set Priority : 0x0A
127
        SRC SCUERU0 = ((0x0A) << SRPN);
        SRC SCUERUØ &= \sim((0x3) << TOS);
                                                  // CPU0 services
131 (9)
        SRC SCUERU0 |= (1 << SRE);
                                                   // Service Request is enabled
132
```



35/34

### 3. 프로그래밍

- 3) ERU를 통한 External Interrupt에 대한 ISR를 구현한다.
  - ✓ 해당 함수가 ISR 임을 나타내기 위해 컴파일러 지시자를 앞에 붙인다.
    - \_\_interrupt( PRIORITY ) : 괄호 안에는 ISR에 대응되는 Interrupt의 우선순위를 입력한다.
    - \_\_vector\_table( CPU\_NUM ) : 괄호 안에는 해당 ISR을 수행하는 CPU 번호를 입력한다.
  - ✓ ISR이 수행된 후, 해당 Interrupt Flag가 자동으로 Clear 되기 때문에 이를 위한 코드가 필요하지 않다.

**ERUO Interrupt Service Routine** 

### 3. 프로그래밍

4) 동작에 따라 'main' 함수를 구현한다.

```
32 /* Define PORT10 Registers for LED */
33 #define PORT10 BASE
                            (0xF003B000)
34 #define PORT10 IOCR0
                           (*(volatile unsigned int*)(PORT10 BASE + 0x10))
35 #define PORT10 OMR
                            (*(volatile unsigned int*)(PORT10 BASE + 0x04))
36
37 #define PC1
                           11
   #define PCL1
                           17
39 #define PS1
40
41 /* Define PORT02 Registers for Switch2 */
42 #define PORT02 BASE
                            (0xF003A200)
43 #define PORT02 IOCR0
                           (*(volatile unsigned int*)(PORT02_BASE + 0x10))
44 #define PORT02 IN
                            (*(volatile unsigned int*)(PORT02 BASE + 0x24))
45
46 #define PC1
                           11
47 #define P1
                           1
48
   /* Define SCU Registers for Interrupt */
50 #define SCU BASE
                            (0xF0036000)
51 #define SCU WDTSCON0
                         (*(volatile unsigned int*)(SCU BASE + 0x0F0))
52 #define SCU EICR1
                           (*(volatile unsigned int*)(SCU BASE + 0x214))
53 #define SCU IGCR0
                           (*(volatile unsigned int*)(SCU BASE + 0x22C))
54
55 #define LCK
56 #define ENDINIT
57 #define INP0
                           12
58 #define EIEN0
                           11
59 #define FEN0
                           8
60 #define EXISO
61 #define IGP0
62
63 /* Define SRC Registers for Interrupt */
64 #define SRC BASE
                            (0xF0038000)
65 //#define SRC SCUERU0
                             (*(volatile unsigned int*)(SRC BASE + 0xCD4))
66
67 #define TOS
                           11
68 #define SRE
                           10
69 #define SRPN
70
71 IfxCpu syncEvent g cpuSyncEvent = 0;
```

```
134⊖ int core0 main(void)
135 {
136
        IfxCpu enableInterrupts();
137
138⊖
        /* !!WATCHDOGO AND SAFETY WATCHDOG ARE DISABLED HERE!!
139
         * Enable the watchdogs and service them periodically if it is required
140
141
        IfxScuWdt disableCpuWatchdog(IfxScuWdt getCpuWatchdogPassword());
142
        IfxScuWdt disableSafetyWatchdog(IfxScuWdt getSafetyWatchdogPassword());
143
144
        /* Wait for CPU sync event */
145
        IfxCpu_emitEvent(&g_cpuSyncEvent);
146
        IfxCpu waitEvent(&g cpuSyncEvent, 1);
147
148
        init ERU();
                                                    // Initialize ERU
149
        init LED();
                                                    // Initialize LED
150
        init Switch();
                                                    // Initialize Switch
151
152
        while(1)
153
154
155
        return (1);
156 }
157
    interrupt(0x0A) vector table(0)
159@ void ERUØ ISR(void)
160 {
161
        PORT10 OMR |= ((1<<PCL1) | (1<<PS1));
                                                         // Toggle LED RED
162 }
163
```

- ✓ '\_enable()'을 통해 CPU의 Global Interrupt
  Enable을 수행한다.
- ✓ 앞서 구현한 함수들을 호출한다.

### 4. 동작 확인

✔ Build 및 Debug 후 ('Resume' 버튼 클릭), Switch를 누를 때마다 LED가 Toggle 되는 것을 확인한다.







# **SW1 & SW2 External Interrupt**



# Q&A

# Thank you for your attention

Compiler
for Embedded Systems Lab.

School of Electronics Engineering, KNU

ACE Lab (hn02301@gmail.com)

