

# **Infineon TC277 PWM (Pulse Width Modulation)**

Junho Kwak

Architecture and Compiler for Embedded System LAB.  
School of Electronics Engineering, KNU, KOREA

2021-05-11



# PWM Example

- PWM Duty Ratio에 따른 LED 밝기 변화
  1. 새로운 예제를 위한 프로젝트를 생성한다.
  2. 원하는 동작을 위해 레지스터와 메모리에 직접 접근해서 값을 써야한다.
  3. Board Schematic과 Datasheet를 통해 PWM 신호 출력에 대한 정보를 파악한다.
  4. PWM 신호 생성을 위해 사용할 GTM 모듈의 동작 원리를 파악하고 메모리 맵을 분석한다.
  5. 분석 결과를 활용해 임베디드 프로그래밍을 한다.



# PWM Example

## 1. LED 연결 정보 파악

- ✓ 여러 LED를 사용하기 위해 Target Board가 아닌 **Easy Module Shield V1 확장 보드**의 LED를 사용한다.



# PWM Example

## 1. LED 연결 정보 파악

- ✓ LED는 Easy Module Shield V1 확장 보드의 **Pin D12(RED)/D13(BLUE)**과 연결되어 있다.
- ✓ 타겟 보드는 Easy Module Shield V1 확장 보드의 Pin D12/D13을 통해 LED 출력을 보낼 수 있다.  
(정상적인 Switch 동작을 위해 VCC 및 GND도 연결해야 한다.)



# PWM Example

## 1. LED 연결 정보 파악

- ✓ TC275 보드의 Schematic과 Datasheet를 확인했을 때, Easy Module Shield V1 확장 보드의 Pin **D12/D13**과 연결되는 IO는 PORT10의 Pin 1-2다.
- ✓ 해당 Pin의 출력이 High-level 일 때 LED는 켜지고, Low-level 일 때 LED는 꺼진다.



# PWM Example

## 1. PWM 신호 출력 정보 파악

- ✓ LED가 연결된 PORT10 Pin 1는 GTM 모듈의 TOUT103과 연결되어 있다.
- ✓ GTM 모듈의 TOUT103은 PWM 신호를 출력하면 PORT10 Pin 1을 통해 LED에 인가될 수 있다.
- ✓ PWM 신호를 통해 LED 밝기를 제어하기 위해 해당 Pin을 **GTM 모듈의 TOUT103 (01)**으로 설정해야 한다.

| Pin | Symbol     | Ctrl | Type             | Function               |
|-----|------------|------|------------------|------------------------|
| 169 | P10.1      | I    | MP+ / PU1 / VEXT | General-purpose input  |
|     | TIN103     |      |                  | GTM input              |
|     | MRST1A     |      |                  | QSPI1 input            |
|     | T5EUDB     |      |                  | GPT120 input           |
|     | P10.1      |      |                  | General-purpose output |
|     | TOUT103    |      |                  | GTM output             |
|     | MTSR1      |      |                  | QSPI1 output           |
|     | MRST1      |      |                  | QSPI1 output           |
|     | EN01       |      |                  | MSC0 output            |
|     | VADCG6BFL1 |      |                  | VADC output            |
|     | END03      |      |                  | MSC0 output            |
|     | -          |      |                  | Reserved               |



# PWM Example

## 2. Data sheet 분석 : PORT 설정 (1)

- ✓ P10\_IOCR Register는 PORT10의 Input/Output을 설정한다.
- ✓ LED가 PORT10의 Pin 1에 연결되어 있기 때문에 **P10\_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       |
| <b>P10</b> | <b>F003 B000<sub>H</sub></b> | <b>F003 B0FF<sub>H</sub></b> | <b>9 pins</b> |
| 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        |

P10\_IOCRO Register 주소: F003\_B010h (F003B000h + 10h)

P10\_IOCRO Register 구조:



| Field                       | Bits                                      | Type | 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<br>This bit field determines the Port n line x functionality<br>(x = 0-3) according to the coding table (see<br><a href="#">Table 13-5</a> ). |
| 0                           | [2:0],<br>[10:8],<br>[18:16],<br>[26:24]  | r    | Reserved<br>Read as 0; should be written with 0.                                                                                                                                 |



# PWM Example

## 2. Data sheet 분석 : PORT 설정 (2)

- ✓ PORT10의 Pin 1을 GTM 모듈의 TOUT103 (01)으로 설정하기 위해 **PC1 bits**를 **10001b**로 설정한다.

Table 13-5 PCx Coding

| PCx[4:0]           | I/O        | Characteristics | Selected Pull-up / Pull-down / Selected Output Function |
|--------------------|------------|-----------------|---------------------------------------------------------|
| 10000 <sub>B</sub> | Output     | Push-pull       | General-purpose output                                  |
| 10001 <sub>B</sub> |            |                 | Alternate output function 1                             |
| 10010 <sub>B</sub> |            |                 | Alternate output function 2                             |
| 10011 <sub>B</sub> |            |                 | Alternate output function 3                             |
| 10100 <sub>B</sub> |            |                 | Alternate output function 4                             |
| 10101 <sub>B</sub> |            |                 | Alternate output function 5                             |
| 10110 <sub>B</sub> |            |                 | Alternate output function 6                             |
| 10111 <sub>B</sub> |            |                 | Alternate output function 7                             |
| 11000 <sub>B</sub> | Open-drain |                 | General-purpose output                                  |
| 11001 <sub>B</sub> |            |                 | Alternate output function 1                             |
| 11010 <sub>B</sub> |            |                 | Alternate output function 2                             |
| 11011 <sub>B</sub> |            |                 | Alternate output function 3                             |
| 11100 <sub>B</sub> |            |                 | Alternate output function 4                             |
| 11101 <sub>B</sub> |            |                 | Alternate output function 5                             |
| 11110 <sub>B</sub> |            |                 | Alternate output function 6                             |
| 11111 <sub>B</sub> |            |                 | Alternate output function 7                             |



# PWM Example

## 2. Data sheet 분석 : GTM Enable 설정

- ✓ GTM\_CLC Register는 GTM 모듈의 Enable 설정을 한다.
  - ✓ GTM 모듈을 Enable 하기 위해 **DISR bit**를 **0**으로 설정한다.
  - ✓ GTM 모듈이 Enable 되어 있는지 확인하기 위해 **DISS bit**가 **0**인지 확인한다.

GTM\_CLC Register 주소: F019\_FD00h (F0100000h + 9FD00h)

## GTM\_CLC Register 구조:

**Table 25-63 Registers Address Space**

| Module                                                                                                           | Base Address           | End Address            | Note                   |
|------------------------------------------------------------------------------------------------------------------|------------------------|------------------------|------------------------|
| GTM                                                                                                              | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |                        |
| <b>CLC</b><br><b>Clock Control Register</b> <b>(9FD00<sub>H</sub>)</b> <b>Reset Value: 0000 0003<sub>H</sub></b> |                        |                        |                        |
| 31                                                                                                               | 30                     | 29                     | 28                     |
| 27                                                                                                               | 26                     | 25                     | 24                     |
| 23                                                                                                               | 22                     | 21                     | 20                     |
| 19                                                                                                               | 18                     | 17                     | 16                     |
|                                                                                                                  |                        | 0                      |                        |
|                                                                                                                  |                        | r                      |                        |
| 15                                                                                                               | 14                     | 13                     | 12                     |
| 11                                                                                                               | 10                     | 9                      | 8                      |
| 7                                                                                                                | 6                      | 5                      | 4                      |
| 3                                                                                                                | 2                      | 1                      | 0                      |
|                                                                                                                  |                        | EDIS                   | DIS<br>S      DIS<br>R |
|                                                                                                                  |                        | r                      | r                      |
|                                                                                                                  |                        | RW                     | RW                     |

| Field       | Bits         | Type | Description                                                                                                                                            |
|-------------|--------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DISR</b> | 0            | rw   | <b>Module Disable Request Bit</b><br>Used for enable/disable control of the GTM module.<br>$0_B$ No disable requested<br>$1_B$ Disable requested       |
| <b>DISS</b> | 1            | r    | <b>Module Disable Status Bit</b><br>Bit indicates the current status of the GTM module.<br>$0_B$ GTM module is enabled<br>$1_B$ GTM module is disabled |
| <b>EDIS</b> | 3            | rw   | <b>Sleep Mode Enable Control</b><br>Used for module sleep mode control.                                                                                |
| <b>0</b>    | 2,<br>[31:4] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                |

# PWM Example

## 2. Data sheet 분석 : System Critical Register 설정 (1)

- ✓ 설정해야 하는 GTM\_CLC Register는 System Critical Register이기 때문에 Write Protected (System ENDINIT, End-of-Initialization) 되어 있다.
  - ✓ 해당 Register를 수정하기 위해서는 System ENDINIT을 해제해야 한다.
  - ✓ SCU\_WDTCPU0CON0 Register는 **System Critical Register**의 **System ENDINIT**을 설정/해제한다.

SCU\_WDTCPU0CON0 Register 주소: F003\_6100h  
(F0036000h + 100h)

## SCU\_WDTCPU0CON0 Register 구조:

**Table 7-27 Registers Address Spaces - SCU Kernel Registers**

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| SCU    | F003 6000 <sub>H</sub> | F003 63FF <sub>H</sub> | -    |

## WDTCPU0CON0

## CPU0 WPT Control Register 0

(100<sub>H</sub>)

Reset Value: FFFC 000E



# PWM Example

## 2. Data sheet 분석 : System Critical Register 설정 (2)

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

| Field   | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Field | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ENDINIT | 0    | rwh  | <b>End-of-Initialization Control Bit</b><br>0 <sub>B</sub> Access to Endinit-protected registers is permitted.<br>1 <sub>B</sub> Access to Endinit-protected registers is not permitted.<br>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.                                                                                                                                                                                                                                                                        | PW    | [15:2] | rwh  | <b>User-Definable Password Field for Access to WDTxCON0</b><br>This bit field is written with an initial password value during a Modify Access.<br>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.<br><br>If corresponding WDTxSR.PAS = 0 then this bit field must be written with its current contents during a Password Access or Check Access.<br>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<br><br>The default password after Application Reset is 00000000111100 <sub>B</sub><br><br>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. |
| LCK     | 1    | rwh  | <b>Lock Bit to Control Access to WDTxCON0</b><br>0 <sub>B</sub> Register WDTxCON0 is unlocked<br>1 <sub>B</sub> Register WDTxCON0 is locked (default after ApplicationReset)<br>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.<br>This bit must be cleared during a Password Access to WDTxCON0, and set during a Modify Access to WDTxCON0.<br>A Check Access does not clear LCK. |       |        |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



A

# PWM Example

## 2. Data sheet 분석 : System Critical Register 설정 (3)

- ✓ SCU\_WDTCPUOCONO Register에 적절한 값을 Write하여 **Password Access**를 수행한다.
- ✓ **Password Access**는 **SCU\_WDTCPUOCONO Register**의 **Lock** 상태를 해제하며 과정은 다음과 같다.
  1. SCU\_WDTCPUOCONO 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]은 0으로 설정하고, bit[0]은 1로 설정한다.
  5. 설정된 값을 SCU\_WDTCPUOCONO Register에 한번에 쓴다.
  6. SCU\_WDTCPUOCONO Register의 LCK bit를 확인하여 Lock 상태가 해제되었는지 파악한다.  
(Password Access가 정상적으로 수행되면 Lock 상태가 해제되며 LCK bit가 0으로 설정된다.)
- ✓ Password Access를 통해 SCU\_WDTCPUOCONO Register의 Lock 상태가 해제되면 Modify Access를 통해 System ENDINIT을 설정/해제할 수 있다.

# PWM Example

## 2. Data sheet 분석 : System Critical Register 설정 (4)

- ✓ SCU\_WDTCPUOCON0 Register에 적절한 값을 Write하여 **Modify Access**를 수행한다.
- ✓ **Modify Access**는 **System ENDINIT**을 설정/해제하며 과정은 다음과 같다.
  1. SCU\_WDTCPUOCON0 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]은 1로 설정하고, bit[0]은 적절한 값으로 설정한다.  
(System ENDINIT 설정: bit[0] = 1, System ENDINIT 해제 : bit[0] = 0)
  5. 설정된 값을 SCU\_WDTCPUOCON0 Register에 한번에 쓴다.
  6. SCU\_WDTCPUOCON0 Register의 LCK bit를 확인하여 Lock 상태가 다시 설정되었는지 파악한다.  
(Modify Access가 정상적으로 수행되면 Lock 상태가 설정되며 LCK bit가 1로 설정된다.)
- ✓ Modify Access를 통해 System ENDINIT을 해제하면 System Critical Register를 수정할 수 있으며 수정을 완료하면 System ENDINIT을 꼭 다시 설정해야 한다.



# PWM Example

## 2. Data sheet 분석 : GTM 내부 Clock 설정 (1)

- ✓ GTM 모듈은 내부에 CMU (Clock Management Unit)을 포함하고 있다.
- ✓ CMU는 GTM 입력 클럭을 분주하여 다양한 내부 클럭을 생성하고, GTM 내부의 하위 모듈에 공급한다.
- ✓ 본 실습에서 PWM 신호 생성을 위해 사용할 하위 모듈인 **TOM (Timer Output Module)**은 **CMU\_FXCLK**에 따라 동작한다.
- ✓ 따라서, CMU의 **FXU**에 대한 설정을 해야 한다.



# PWM Example

## 2. Data sheet 분석 : GTM 내부 Clock 설정 (2)

- ✓ GTM\_CMU\_FXCLK\_CTRL Register는 CMU\_FXCLK의 소스 클럭을 설정한다.
  - ✓ CMU\_FXCLK의 소스 클럭으로 GTM 모듈의 입력 클럭인 CMU\_GCLK\_EN 또는 GTM 모듈 내부에서 생성된 CMU\_CLKx가 사용될 수 있다.
  - ✓ 소스 클럭을 CMU\_GCLK\_EN으로 설정하기 위해 **FXCLK\_SEL bits**를 **0000b**로 설정한다.

## GTM\_CMU\_FXCLK\_CTRL Register 주소: F010\_0344h (F0100000h + 344h)

## GTM\_CMU\_FXCLK\_CTRL Register 구조:

Table 25-63 Registers Address Space

| Module                     | Base Address           | End Address            | Note                  |
|----------------------------|------------------------|------------------------|-----------------------|
| GTM                        | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |                       |
| <b>GTM_CMU_FXCLK_CTRL</b>  |                        |                        |                       |
| CMU FXCLK Control Register |                        | (00344 <sub>H</sub> )  | Reset Value: 00000000 |
|                            |                        |                        |                       |
| 31                         | 30                     | 29                     | 28                    |
| 27                         | 26                     | 25                     | 24                    |
| 23                         | 22                     | 21                     | 20                    |
| 19                         | 18                     | 17                     | 16                    |
| Reserved                   |                        |                        |                       |
|                            |                        |                        | r                     |
| 15                         | 14                     | 13                     | 12                    |
| 11                         | 10                     | 9                      | 8                     |
| 7                          | 6                      | 5                      | 4                     |
| 3                          | 2                      | 1                      | 0                     |
| Reserved                   |                        |                        |                       |
|                            |                        |                        | r                     |
| FXCLK_SEL                  |                        |                        |                       |
|                            |                        |                        | rw                    |

| Field            | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>FXCLK_SEL</b> | [3:0] | rw   | <p><b>Input clock selection for EN_FXCLK line</b></p> <p>0000<sub>B</sub> CMU_GCLK_EN selected<br/>     0001<sub>B</sub> CMU_CLK0 selected<br/>     0010<sub>B</sub> CMU_CLK1 selected<br/>     0011<sub>B</sub> CMU_CLK2 selected<br/>     0100<sub>B</sub> CMU_CLK3 selected<br/>     0101<sub>B</sub> CMU_CLK4 selected<br/>     0110<sub>B</sub> CMU_CLK5 selected<br/>     0111<sub>B</sub> CMU_CLK6 selected<br/>     1000<sub>B</sub> CMU_CLK7 selected</p> <p><i>Note: This value can only be written, when the CMU_FXCLK generation is disabled. See bits 23...22 in register CMU_CLK_EN.</i></p> <p><i>Note: Other values for FXCLK_SEL are reserved and should not be used, but they behave like FXCLK_SEL = 0.</i></p> |



# PWM Example

## 2. Data sheet 분석 : GTM 내부 Clock 설정 (3)

- ✓ GTM\_CMU\_CLK\_EN Register는 CMU 내부의 클럭에 대한 Enable 설정을 한다.
- ✓ GTM\_CMU\_CLK\_EN Register는 CMU 내부에서 생성된 다양한 클럭에 대한 Enable을 설정할 수 있다.
- ✓ CMU\_FXCLK을 Enable 하기 위해 **EN\_FXCLK bits**를 **10b**로 설정한다.

GTM\_CMU\_CLK\_EN Register 주소: F010\_0300h  
(F0100000h + 300h)

GTM\_CMU\_CLK\_EN Register 구조:

Table 25-63 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| GTM    | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |      |



| Field                  | Bits    | Type | Description                                                          |
|------------------------|---------|------|----------------------------------------------------------------------|
| EN_CLK4                | [9:8]   | rw   | Enable clock source 4<br>see bits [1:0]                              |
| EN_CLK5                | [11:10] | rw   | Enable clock source 5<br>see bits [1:0]                              |
| EN_CLK6                | [13:12] | rw   | Enable clock source 6<br>see bits [1:0]                              |
| EN_CLK7                | [15:14] | rw   | Enable clock source 7<br>see bits [1:0]                              |
| EN_ECLK0               | [17:16] | rw   | Enable ECLK 0 generation subunit<br>see bits [1:0]                   |
| EN_ECLK1               | [19:18] | rw   | Enable ECLK 1 generation subunit<br>see bits [1:0]                   |
| EN_ECLK2               | [21:20] | rw   | Enable ECLK 2 generation subunit<br>see bits [1:0]                   |
| EN_FXCLK               | [23:22] | rw   | Enable all CMU_FXCLK<br>see bits [1:0]                               |
| <i>Note: An enable</i> |         |      | <i>00<sub>B</sub> clock source is disabled (ignore write access)</i> |
| <i>reset int</i>       |         |      | <i>01<sub>B</sub> disable clock signal and reset internal states</i> |
|                        |         |      | <i>10<sub>B</sub> enable clock signal</i>                            |
|                        |         |      | <i>11<sub>B</sub> clock signal enabled (ignore write access)</i>     |



# PWM Example

## 2. Data sheet 분석 : TOM 구조 분석

- ✓ PWM 신호 생성을 위해 GTM 모듈 내부의 TOM을 사용한다.
- ✓ GTM 모듈은 3개의 TOM을 포함하고 있고, 각 TOM은 2개의 TGC (TOM Global Channel Control)와 16개의 TOM Channel을 가지고 있다.
- ✓ **TGC**는 8개의 TOM Channel과 연결되어 있으며 이를 통해 **TOM Channel**을 제어할 수 있다.
- ✓ **TOM Channel**은 TGC의 제어에 따라 동작을 수행하며 출력 신호를 생성한다.
- ✓ 본 실습에서는 **TOM0\_CH1**를 사용한다. (TOUT91과 연결되어 있기 때문이다.)
- ✓ 따라서, **TOM0\_CH1**를 사용하기 위한 설정을 수행한다.



# PWM Example

## 2. Data sheet 분석 : TOM 동작 분석

- ✓ TOM Channel은 **CNO / CM0 / CM1**을 사용해 **PWM** 신호를 생성한다.
  - ✓ CNO : 동작 클럭에 따라 증가하는 Count 값을 저장한다.
  - ✓ CM0 : PWM 신호의 주기를 결정하는 값을 저장한다.
  - ✓ CM1 : PWM 신호의 Duty Ratio를 결정하는 값을 저장한다.
- ✓ CNO는 동작 클럭에 따라 1씩 증가하며 CM0에 도달하면 0으로 초기화된다.
- ✓ CNO가 CM0에 도달했을 때, 출력 신호는 SL 값으로 설정된다.
- ✓ CNO가 CM1에 도달했을 때, 출력 신호는 SL 반전 값으로 설정된다.



Figure 25-39 PWM Output with respect to configuration bit SL in continuos mode

# PWM Example

## 2. Data sheet 분석 : TOM0 – TGC0 설정 (1)

- ✓ GTM\_TOM0\_TGC0\_GLB\_CTRL Register는 Channel 0-7을 제어하는 TGC0에 대한 설정을 한다.
- ✓ Channel에 대한 Enable/Disable 설정 및 Output Enable 설정은 트리거 신호에 의해 일괄적으로 반영된다.
- ✓ **HOST\_TRIG bit**를 1로 설정하여 사용자가 소프트웨어적으로 트리거 신호를 발생시킬 수 있다.

GTM\_TOM0\_TGC0\_GLB\_CTRL Register 주소: F010\_8030h  
(F0100000h + 8030h)

GTM\_TOM0\_TGC0\_GLB\_CTRL Register 구조:

Table 25-63 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| GTM    | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |      |



| Field        | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                    |
|--------------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HOST_TRIGGER | 0     | w    | <p>Trigger request signal (see TGC0, TGC1) to update the register ENDIS_STAT and OUTEN_STAT</p> <p>0<sub>B</sub> no trigger request<br/>1<sub>B</sub> set trigger request<br/>Read as 0.</p> <p>Note: This flag is cleared automatically after triggering the update</p>                                                       |
| Reserved     | [7:1] | r    | <p><b>Reserved</b><br/>Read as zero, should be written as zero</p>                                                                                                                                                                                                                                                             |
| RST_CH0      | 8     | w    | <p><b>Software reset of channel 0</b><br/>0<sub>B</sub> No action<br/>1<sub>B</sub> Reset channel<br/>Read as 0.</p> <p>Note: This bit is cleared automatically after write by CPU. The channel registers are set to their reset values and channel operation is stopped immediately. The S-r FlipFlop SOUR is set to '1'.</p> |

# PWM Example

## 2. Data sheet 분석 : TOM0 – TGC0 설정 (2)

- ✓ TOM 동작을 위한 CM0 / CM1 / CLK\_SRC 값은 먼저 Shadow Register에 저장된다.
- ✓ 업데이트가 Enable 되어 있으면 업데이트를 할 때 Shadow Register에 저장되어 있는 값이 일괄적으로 반영되어 CM0 / CM1 / CLK\_SRC가 설정된다.
- ✓ TOM Channel 5가 동작하기 위해서는 해당 Channel에 대한 CM0 / CM1 / CLK\_SRC 값이 설정되어야 하며 이를 위해 **UPEN\_CTRL5 bits**를 **10b**로 설정하여 업데이트를 Enable 한다.

| GTM_TOMi_TGC0_GLB_CTRL (i=0-2)                   |                 |                 |                 |                 |                 |                 |                 |          |    |    |    |                   |    |    |    |
|--------------------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------|----|----|----|-------------------|----|----|----|
| TOMi TGC0 Global Control Register(08030H+i*800H) |                 |                 |                 |                 |                 |                 |                 |          |    |    |    |                   |    |    |    |
| Reset Value: 00000000H                           |                 |                 |                 |                 |                 |                 |                 |          |    |    |    |                   |    |    |    |
| 31                                               | 30              | 29              | 28              | 27              | 26              | 25              | 24              | 23       | 22 | 21 | 20 | 19                | 18 | 17 | 16 |
| UPEN_CT<br>RL7                                   | UPEN_CT<br>RL6  | UPEN_CT<br>RL5  | UPEN_CT<br>RL4  | UPEN_CT<br>RL3  | UPEN_CT<br>RL2  | UPEN_CT<br>RL1  | UPEN_CT<br>RL0  |          |    |    |    |                   |    |    |    |
| rw                                               | rw              | rw              | rw              | rw              | rw              | rw              | rw              |          |    |    |    |                   |    |    |    |
| 15                                               | 14              | 13              | 12              | 11              | 10              | 9               | 8               | 7        | 6  | 5  | 4  | 3                 | 2  | 1  | 0  |
| RST<br>_CH<br>7                                  | RST<br>_CH<br>6 | RST<br>_CH<br>5 | RST<br>_CH<br>4 | RST<br>_CH<br>3 | RST<br>_CH<br>2 | RST<br>_CH<br>1 | RST<br>_CH<br>0 | Reserved |    |    |    | HOS<br>T_T<br>RIG |    |    | w  |
| w                                                | w               | w               | w               | w               | w               | w               | w               | r        |    |    |    |                   |    |    | w  |

See bits [27:26] Write of following double bit values is possible:  
00<sub>B</sub> don't care, bits 1:0 will not be changed  
01<sub>B</sub> update disabled: is read as 00 (see below)  
10<sub>B</sub> update enabled: is read as 11 (see below)  
11<sub>B</sub> don't care, bits 1:0 will not be changed  
Read of following double values means:  
00<sub>B</sub> channel disabled  
11<sub>B</sub> channel enabled

**UPEN\_CT RL5** [27:26] rw  
**TOM channel 5 enable update of register CM0, CM1 and CLK\_SRC**

# PWM Example

## 2. Data sheet 분석 : TOM0 – TGC0 설정 (3)

- ✓ GTM\_TOM0\_TGC0\_FUPD\_CTRL Register는 트리거 신호에 따른 동작 설정을 한다.
- ✓ FUPD\_CTRLx bits는 CMO / CM1 / CLK\_SRC의 업데이트가 트리거 신호에 의해 실행되도록 설정하며 이를 Channel 1에 적용하기 위해 **FUPD\_CTRL1 bits**를 10b로 설정한다.
- ✓ RSTCN0\_CHx bits는 CN0의 초기화가 트리거 신호에 의해 실행되도록 설정하며 이를 Channel 1에 적용하기 위해 **RSTCN0\_CH1 bits**를 10b로 설정한다.

GTM\_TOM0\_TGC0\_FUPD\_CTRL Register 주소: F010\_8038h  
(F0100000h + 8038h)

GTM\_TOM0\_TGC0\_FUPD\_CTRL Register 구조:

Table 25-63 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| GTM    | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |      |



|                                        |                                                  |    |                                                      |
|----------------------------------------|--------------------------------------------------|----|------------------------------------------------------|
| <b>FUPD_CT RL5</b>                     | [11:10]                                          | rw | Force update of (A)TOM channel 5 operation registers |
| See bits 1                             |                                                  |    | Write of following double bit values is possible:    |
| 00 <sub>B</sub>                        | don't care, bits 1:0 will not be changed         |    |                                                      |
| 01 <sub>B</sub>                        | force update disabled: is read as 00 (see below) |    |                                                      |
| 10 <sub>B</sub>                        | force update enabled: is read as 11 (see below)  |    |                                                      |
| 11 <sub>B</sub>                        | don't care, bits 1:0 will not be changed         |    |                                                      |
| Read of following double values means: |                                                  |    |                                                      |
| 00 <sub>B</sub>                        | force update disabled                            |    |                                                      |
| 11 <sub>B</sub>                        | force channel enabled                            |    |                                                      |

|                                        |                                                              |    |                                                   |
|----------------------------------------|--------------------------------------------------------------|----|---------------------------------------------------|
| <b>RSTCN0_CH5</b>                      | [27:26]                                                      | rw | Reset CN0 of channel 5 on force update event      |
| See bits                               |                                                              |    | Write of following double bit values is possible: |
| 00 <sub>B</sub>                        | don't care, bits 1:0 will not be changed                     |    |                                                   |
| 01 <sub>B</sub>                        | CN0 is not reset on forced update: is read as 00 (see below) |    |                                                   |
| 10 <sub>B</sub>                        | CN0 is reset on forced update: is read as 11 (see below)     |    |                                                   |
| 11 <sub>B</sub>                        | don't care, bits 1:0 will not be changed                     |    |                                                   |
| Read of following double values means: |                                                              |    |                                                   |
| 00 <sub>B</sub>                        | CN0 is not reset on forced update                            |    |                                                   |
| 11 <sub>B</sub>                        | CN0 is reset on forced update                                |    |                                                   |

# PWM Example

## 2. Data sheet 분석 : TOM0 – TGCO 설정 (4)

- ✓ GTM\_TOM0\_TGCO\_ENDIS\_CTRL Register는 트리거 신호에 따른 Enable/Disable을 설정한다.
- ✓ 트리거 신호에 따라 각 Channel을 Enable 할지 Disable 할지 설정할 수 있다.
- ✓ 트리거 신호 발생 시, Channel 1가 Enable 되게 **ENDIS\_CTRL1 bits**를 **10b**로 설정한다.

GTM\_TOM0\_TGCO\_ENDIS\_CTRL Register 주소: F010\_8070h  
(F0100000h + 8070h)

GTM\_TOM0\_TGCO\_ENDIS\_CTRL Register 구조:

Table 25-63 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| GTM    | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |      |

GTM\_TOMi\_TGCO\_ENDIS\_CTRL (i=0-2)

TOMi TGCO Enable/Disable Control Register

(08070<sub>H</sub>+i\*800<sub>H</sub>) Reset Value: 00000000<sub>H</sub>



**ENDIS\_CT RL5** [11:10] rw (A)TOM channel 5 enable/disable update value  
If a TOM channel is disabled, the counter CN0 is stopped and the FlipFlop SOUR is set to the inverse value of control bit SL. On an enable event, the counter CN0 starts counting from its current value.  
Write of following double bit values is possible:  
00<sub>B</sub> don't care, bits 1:0 of register ENDIS\_STAT will not be changed on an update trigger  
01<sub>B</sub> disable channel on an update trigger  
10<sub>B</sub> enable channel on an update trigger  
11<sub>B</sub> don't change bits 1:0 of this register  
Note: if the channel is disabled (ENDIS[0]=0) or the output is disabled (OUTEN[0]=0), the TOM channel 0 output TOM\_OUT[0] is the inverted value of bit SL.



# PWM Example

## 2. Data sheet 분석 : TOM0 – TGC0 설정 (5)

- ✓ GTM\_TOM0\_TGC0\_OUTEN\_CTRL Register는 트리거 신호에 따른 Output Enable을 설정한다.
- ✓ 트리거 신호에 따라 각 Channel의 Output을 Enable 할지 Disable 할지 설정할 수 있다.
- ✓ 트리거 신호 발생 시, Channel 5의 Output0| Enable 되게 OUTEN\_CTRL5 bits를 10b로 설정한다.

GTM\_TOM0\_TGC0\_OUTEN\_CTRL Register 주소: F010\_8078h  
(F0100000h + 8078h)

GTM\_TOM0\_TGC0\_OUTEN\_CTRL Register 구조:

Table 25-63 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| GTM    | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |      |

GTM\_TOMi\_TGC0\_OUTEN\_CTRL (i=0-2)

TOMi TGC0 Output Enable Control Register



| Field        | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OUTEN_C TRL0 | [1:0]   | rw   | Output (A)TOM_OUT(0) enable/disable update value<br>Write of following double bit values is possible:<br>00 <sub>B</sub> don't care, bits 1:0 of register OUTEN_STAT will not be changed on an update trigger<br>01 <sub>B</sub> disable channel output on an update trigger<br>10 <sub>B</sub> enable channel output on an update trigger<br>11 <sub>B</sub> don't change bits 1:0 of this register<br>Note: if the channel is disabled (ENDIS[0]=0) or the output is disabled (OUTEN[0]=0), the TOM channel 0 output TOM_OUT[0] is the inverted value of bit SL. |
| OUTEN_C TRL1 | [3:2]   | rw   | Output (A)TOM_OUT(1)enable/disable update value<br>See bits 1:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| OUTEN_C TRL2 | [5:4]   | rw   | Output (A)TOM_OUT(2) enable/disable update value<br>See bits 1:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| OUTEN_C TRL3 | [7:6]   | rw   | Output (A)TOM_OUT(3) enable/disable update value<br>See bits 1:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| OUTEN_C TRL4 | [9:8]   | rw   | Output (A)TOM_OUT(4) enable/disable update value<br>See bits 1:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| OUTEN_C TRL5 | [11:10] | rw   | Output (A)TOM_OUT(5) enable/disable update value<br>See bits 1:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



# PWM Example

## 2. Data sheet 분석 : TOM0 – Channel 5 설정 (1)

- ✓ GTM\_TOM0\_CHx\_CTRL Register는 TOM0의 각 Channel에 대한 동작 설정을 한다.
- ✓ TOM Channel 1의 동작을 설정하기 위해 **GTM\_TOM0\_CH1\_CTRL Register**를 설정한다.
- ✓ 출력 신호의 Duty Cycle에 대한 Signal level을 High로 설정하기 위해 **SL bit**를 1로 설정한다.

GTM\_TOM0\_CH1\_CTRL Register 주소: F010\_8040h  
(F0100000h + 8040h)

GTM\_TOM0\_CH1\_CTRL Register 구조:

Table 25-63 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| GTM    | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |      |

GTM\_TOM0\_CHx\_CTRL (x=0-14)

TOM0 Channel x Control Register'



| Field | Bits | Type | Description                                                                                                                                                                                            |
|-------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SL    | 11   | rw   | <p>Signal level for duty cycle</p> <p>0<sub>B</sub> Low signal level</p> <p>1<sub>B</sub> High signal level</p> <p>If the output is disabled, the output TOM_OUT[x] is set to inverse value of SL.</p> |

# PWM Example

## 2. Data sheet 분석 : TOM0 – Channel 5 설정 (2)

- ✓ TOM Channel 5의 동작 클럭을 CMU\_FXCLK1로 설정하기 위해 **CLK\_SRC\_SR bits**를 **001b**로 설정한다.
- ✓ CMU\_FXCLK1의 주파수는  $50\text{MHz} / 16 = 3,125\text{kHz}$  이다.
- ✓ CLK\_SRC\_SR bits가 업데이트를 할 때 반영되기 때문에 TOM Channel 1의 동작 클럭 또한 업데이트를 할 때 반영된다.

| GTM_TOM0_CHx_CTRL (x=0-14)<br>TOM0 Channel x Control Register'                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| (08000 <sub>H</sub> +x*0040 <sub>H</sub> ) Reset Value: 00000800 <sub>H</sub> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 31                                                                            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| r                                                                             | rw | rw | r  |
| 15                                                                            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| r                                                                             | rw |



ACE Lab.

|                   |                                                                     |    |                                                                                                                                                                                                             |
|-------------------|---------------------------------------------------------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CLK_SRC_SR</b> | [14:12]                                                             | rw | <b>Clock source select for channel</b>                                                                                                                                                                      |
|                   |                                                                     |    | The register CLK_SRC is updated with the value of CLK_SRC_SR together with the update of register CM0 and CM1.                                                                                              |
|                   |                                                                     |    | The input of the FX clock divider depends on the value of FXCLK_SEL (see CMU).                                                                                                                              |
| 000 <sub>B</sub>  | CMU_FXCLK(0) selected: clock selected by FXCLKSEL                   |    |                                                                                                                                                                                                             |
| 001 <sub>B</sub>  | CMU_FXCLK(1) selected: clock selected by FXCLKSEL / 2 <sup>4</sup>  |    |                                                                                                                                                                                                             |
| 010 <sub>B</sub>  | CMU_FXCLK(2) selected: clock selected by FXCLKSEL / 2 <sup>8</sup>  |    |                                                                                                                                                                                                             |
| 011 <sub>B</sub>  | CMU_FXCLK(3) selected: clock selected by FXCLKSEL / 2 <sup>12</sup> |    |                                                                                                                                                                                                             |
| 100 <sub>B</sub>  | CMU_FXCLK(4) selected: clock selected by FXCLKSEL / 2 <sup>16</sup> |    |                                                                                                                                                                                                             |
| 101 <sub>B</sub>  | no CMU_FXCLK selected, clock of channel stopped                     |    |                                                                                                                                                                                                             |
| 110 <sub>B</sub>  | no CMU_FXCLK selected, clock of channel stopped                     |    |                                                                                                                                                                                                             |
| 111 <sub>B</sub>  | no CMU_FXCLK selected, clock of channel stopped                     |    |                                                                                                                                                                                                             |
|                   |                                                                     |    | Note: if clock of channel is stopped (i.e. CLK_SRC = 101/110/111), the channel can only be restarted by resetting CLK_SRC_SR to a value of 000 to 100 and forcing an update via the force update mechanism. |

# PWM Example

## 2. Data sheet 분석 : TOMO – Channel 5 설정 (3)

- ✓ GTM\_TOMO\_CHx\_SRO Register는 CMO에 대한 Shadow Register이다.
  - ✓ TOM Channel 1의 CMO를 설정하기 위해 **GTM\_TOMO\_CH1\_SRO Register**를 설정한다.
  - ✓ GTM\_TOMO\_CH1\_SRO Register에 설정할 CMO 값을 저장하면 업데이트를 할 때 CMO에 반영된다.
  - ✓ 본 실습에서는 PWM 신호의 주기를 4ms로 설정하기 위해 해당 Register의 값을 **(12500 – 1)**로 설정한다.

## GTM\_TOM0\_CH5\_SRO Register 주소: F010\_8044h (F0100000h + 8044h)

## GTM\_TOMO\_CH5\_SRO Register 구조:

**Table 25-63 Registers Address Space**

| <b>Module</b> | <b>Base Address</b>    | <b>End Address</b>     | <b>Note</b> |
|---------------|------------------------|------------------------|-------------|
| GTM           | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |             |

GTM TOM0 CHx SR0 (x=0-15)

## TOM0 Channel x CCU0 Compare Shadow Register (08004<sub>H</sub>+x\*0040<sub>H</sub>)

**Reset Value: 00000000<sub>H</sub>**

The diagram shows a 32-bit register with bit indices from 31 down to 0 listed above the register. The bits are divided into two main sections: 'Reserved' (bits 23-0) and 'SR0' (bits 24-0). A red box highlights the SR0 section. The bottom of the register has an 'r' label under the 'Reserved' section and an 'rw' label under the 'SR0' section.

$$(Period\ of\ PWM) = \frac{(Value\ of\ CM0) + 1}{(Freq.\ of\ CMU\_FXCLK1)}$$

$$= \frac{12500}{3125\ kHz} = 0.004s$$



# PWM Example

## 2. Data sheet 분석 : TOMO – Channel 5 설정 (4)

- ✓ GTM\_TOMO\_CHx\_SR1 Register는 CM1에 대한 Shadow Register이다.
  - ✓ TOM Channel 1의 CM1을 설정하기 위해 **GTM\_TOMO\_CH1\_SR1 Register**를 설정한다.
  - ✓ GTM\_TOMO\_CH1\_SR1 Register에 설정할 CM1 값을 저장하면 업데이트를 할 때 CM1에 반영된다.
  - ✓ CM1에 의한 **Duty Ratio**는  $\left( \frac{CM1+1}{CM0+1} \times 100 \right) (\%)$  이다.

GTM\_TOM0\_CH5\_SR1 Register 주소: F010\_8048h  
(F0100000h + 8048h)

## GTM\_TOM0\_CH5\_SR1 Register 구조:

**Table 25-63 Registers Address Space**

| <b>Module</b> | <b>Base Address</b>    | <b>End Address</b>     | <b>Note</b> |
|---------------|------------------------|------------------------|-------------|
| GTM           | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |             |

---

GTM TOM0 CHx SR1 (x=0-15)

#### **TOM0 Channel x CCU1 Compare Shadow Register**

(08008<sub>H</sub>+x\*0040<sub>H</sub>)      Reset Value: 00000000<sub>H</sub>



# PWM Example

## 2. Data sheet 분석 : TOUT 설정 (1)

- ✓ GTM 모듈 내 하위 모듈에서 생성한 출력 신호를 외부에 전달하기 위해서는 GTM 모듈의 출력 포트 (TOUT)와 연결 설정을 해야 한다.
- ✓ 하나의 출력 포트에는 하위 모듈에서 생성된 출력 신호 4개가 MUX를 통해 연결되어 있으며 MUX 제어를 통해 하나의 신호가 출력 포트와 연결된다.
- ✓ **GTM\_TOUTSEL Register**는 MUX에 제어 신호를 입력하며 하나의 Register가 16개의 MUX를 제어한다.
- ✓ 따라서, LED가 연결된 TOUT103 (PORT10 Pin 1)은 **GTM\_TOUTSEL1 Register**의 **SEL11 bits**를 통해 설정할 수 있다.

# PWM Example

## 2. Data sheet 분석 : TOUT 설정 (2)

- ✓ GTM\_TOUTSEL Register는 TOUT을 통해 출력될 신호를 설정한다.
- ✓ TOUT103에 대해 설정하기 위해 **GTM\_TOUTSEL6 Register**의 **SEL7 bits**를 설정한다.
- ✓ TOMO Channel 1을 통해 생성한 PWM 신호를 TOUT103로 출력하기 위해 **SEL7 bits**를 **00b**로 설정한다.

GTM\_TOUTSEL5 Register 주소: F019\_FD44h  
(F0100000h + 9FD48h)

GTM\_TOUTSEL5 Register 구조:

Table 25-63 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| GTM    | F010 0000 <sub>H</sub> | F019 FFFF <sub>H</sub> |      |

TOUTSEL<sub>n</sub> (n = 0-14)  
Timer Output Select Register      (9FD30<sub>H</sub>+n\*4<sub>H</sub>)      Reset Value: 0000 0000<sub>H</sub>

|              |              |              |              |              |              |             |             |    |    |    |    |    |    |    |    |
|--------------|--------------|--------------|--------------|--------------|--------------|-------------|-------------|----|----|----|----|----|----|----|----|
| 31           | 30           | 29           | 28           | 27           | 26           | 25          | 24          | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>SEL15</b> | <b>SEL14</b> | <b>SEL13</b> | <b>SEL12</b> | <b>SEL11</b> | <b>SEL10</b> | <b>SEL9</b> | <b>SEL8</b> |    |    |    |    |    |    |    |    |
| rw           | rw           | rw           | rw           | rw           | rw           | rw          | rw          | rw | rw | rw | rw | rw | rw | rw | rw |

|             |             |             |             |             |             |             |             |    |    |    |    |    |    |    |    |
|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|----|----|----|----|----|----|----|----|
| 15          | 14          | 13          | 12          | 11          | 10          | 9           | 8           | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>SEL7</b> | <b>SEL6</b> | <b>SEL5</b> | <b>SEL4</b> | <b>SEL3</b> | <b>SEL2</b> | <b>SEL1</b> | <b>SEL0</b> |    |    |    |    |    |    |    |    |
| rw          | rw | rw | rw | rw | rw | rw | rw | rw |

| Field                     | Bits            | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------|-----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SELx</b><br>(x = 0-15) | [x*2+1:<br>x*2] | rw   | <b>TOUT(n*16+x) Output Selection</b><br>This bit defines which timer out is connected as TOUT(n*16+x). The mapping for each pin is defined by <a href="#">Table 25-67Table 25-68</a> .<br><br>00 <sub>B</sub> Timer A form <a href="#">Table 25-67Table 25-68</a> is connected as TOUT(n*16+x) to the ports<br>01 <sub>B</sub> Timer B form <a href="#">Table 25-67Table 25-68</a> is connected as TOUT(n*16+x) to the ports<br>10 <sub>B</sub> Timer C form <a href="#">Table 25-67Table 25-68</a> is connected as TOUT(n*16+x) to the ports<br>11 <sub>B</sub> Timer D form <a href="#">Table 25-67Table 25-68</a> is connected as TOUT(n*16+x) to the ports |
|                           |                 |      | <i>Note: If TOUT(n*16+x) is not defined in <a href="#">Table 25-67Table 25-68</a> this bit field has to be treated as reserved.</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table 25-67 GTM to Port Mapping for QFP-176

| Port  | Input | Output        | Input Timer Mapped |               | Output Timer Mapped |               |                |                |
|-------|-------|---------------|--------------------|---------------|---------------------|---------------|----------------|----------------|
|       |       |               | A                  | B             | A                   | B             | C              | D              |
| P13.0 | TIN91 | <b>TOUT91</b> | <b>TIM2_5</b>      | <b>TIM3_5</b> | <b>TOM0_5</b>       | <b>TOM2_5</b> | <b>ATOM2_5</b> | <b>ATOM3_5</b> |



# PWM Example

## 3. 프로그래밍

- 1) LED가 연결된 PORT에 대한 설정을 수행하는 함수를 구현한다.

```
74 // PORT10 Registers
75 #define PORT10_BASE      (0xF003B000)
76 #define PORT10_IOCR0     (*(volatile unsigned int*)(PORT10_BASE + 0x10))
77
78 #define PC1              11
```

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

```
109 void init_LED(void)
110 {
111     PORT10_IOCR0 &= ~((0x1F) << PC1);           // PORT10.1 : Alternate output function 1 (push-pull)
112     PORT10_IOCR0 |= ((0x11) << PC1);            // PORT10.1 : GTM_TOUT103
113 }
114 }
```

PORT IO 설정 함수



# PWM Example

## 3. 프로그래밍

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

- ① SCU\_WDTCPUOCON0 Register를 통해 Password/Modify Access를 수행하여 System ENDINIT을 해제한다.
- ② GTM\_CLC Register를 통해 GTM 모듈을 Enable 한다.
- ③ SCU\_WDTCPUOCON0 Register를 통해 Password/Modify Access를 수행하여 System ENDINIT을 설정한다.
- ④ GTM\_CMU\_FXCLK\_CTRL Register와 GTM\_CMU\_CLK\_EN Register를 통해 CMU\_FXCLK를 설정한다.
- ⑤ GTM\_TOM0\_TGCO\_GLB\_CTRL Register를 통해 CMO / CM1 / CLK\_SRC에 대한 업데이트를 Enable 한다.
- ⑥ GTM\_TOM0\_TGCO\_FUPD\_CTRL Register를 통해 트리거 신호에 따른 동작 (Force update, Clear CNO)을 설정한다.
- ⑦ GTM\_TOM0\_TGCO\_ENDIS\_CTRL Register와 GTM\_TOM0\_TGCO\_OUTEN\_CTRL Register를 통해 트리거 신호에 따른 동작 (Channel enable, Output enable)을 설정한다.
- ⑧ GTM\_TOM0\_CH1\_CTRL Register를 통해 Signal level을 설정한다.
- ⑨ GTM\_TOM0\_CH1\_CTRL / GTM\_TOM0\_CH1\_SR0 / GTM\_TOM0\_CH1\_SR1 Register를 통해 CMO / CM1 / CLK\_SRC에 대한 Shadow Register를 설정한다.
- ⑩ GTM\_TOUTSEL5 Register를 통해 TOM0 Channel 1의 PWM 신호가 TOUT103로 출력되도록 설정한다.
- ⑪ GTM\_TOM0\_TGCO\_GLB\_CTRL Register를 통해 모든 설정이 반영되도록 HOST TRIGGER를 발생시킨다.



# PWM Example

## 3. 프로그래밍

### 2) GTM을 설정하기 위한 함수를 구현한다.

```
31/* Address of Registers */
32 // SCU Registers
33 #define SCU_BASE          (0xF0036000)
34 #define SCU_WDT_CPU0CON0 (*(volatile unsigned int*)(SCU_BASE + 0x100))
35
36 #define LCK                1
37 #define ENDINIT             0
38
39// GTM Registers
40 // GTM - CMU
41 #define GTM_BASE           (0xF0100000)
42 #define GTM_CMU_CLK_EN      (*(volatile unsigned int*)(GTM_BASE + 0x00300))
43 #define GTM_CMU_FXCLK_CTRL  (*(volatile unsigned int*)(GTM_BASE + 0x00344))
44
45 #define EN_FXCLK            22
46 #define FXCLK_SEL           0
47
48 // GTM - T0M0
49 #define GTM_T0M0_TGC0_GLB_CTRL  (*(volatile unsigned int*)(GTM_BASE + 0x08030))
50 #define GTM_T0M0_TGC0_ENDIS_CTRL  (*(volatile unsigned int*)(GTM_BASE + 0x08070))
51 #define GTM_T0M0_TGC0_OUTEN_CTRL  (*(volatile unsigned int*)(GTM_BASE + 0x08078))
52 #define GTM_T0M0_TGC0_FUPD_CTRL  (*(volatile unsigned int*)(GTM_BASE + 0x08038))
53 #define GTM_T0M0_CH1_CTRL     (*(volatile unsigned int*)(GTM_BASE + 0x08040))
54 #define GTM_T0M0_CH1_SR0      (*(volatile unsigned int*)(GTM_BASE + 0x08044))
55 #define GTM_T0M0_CH1_SR1      (*(volatile unsigned int*)(GTM_BASE + 0x08048))
56
57 #define UPEN_CTRL5           26
58 #define HOST_TRIG             0
59 #define ENDIS_CTRL1           2
60 #define OUTEN_CTRL1           2
61 #define RSTCN0_CH1            18
62 #define FUPD_CTRL1             2
63 #define CLK_SRC_SR             12
64 #define SL                   11
65
66 // GTM
67 #define GTM_CLC              (*(volatile unsigned int*)(GTM_BASE + 0x9FD00))
68 #define GTM_TOUTSEL6          (*(volatile unsigned int*)(GTM_BASE + 0x9FD48))
69
70 #define DISS                 1
71 #define DISR                 0
72 #define SEL7                  14
```



# PWM Example

## 3. 프로그래밍

### 2) GTM을 설정하기 위한 함수를 구현한다.

```
116 void init_GTM_TOM0_PWM(void)
117 {
118     /* GTM Enable */
119     // Password Access to unlock WDTCPU0CON0
120     ① SCU_WDT_CPU0CON0 = ((SCU_WDT_CPU0CON0 ^ 0xFC) & ~(1 << LCK)) | (1 << ENDINIT);
121     while((SCU_WDT_CPU0CON0 & (1 << LCK)) != 0);
122
123     // Modify Access to clear ENDINIT bit
124     SCU_WDT_CPU0CON0 = ((SCU_WDT_CPU0CON0 ^ 0xFC) | (1 << LCK)) & ~(1 << ENDINIT);
125     while((SCU_WDT_CPU0CON0 & (1 << LCK)) == 0);
126
127     ② GTM_CLC &= ~(1 << DISR);                                // Enable GTM Module
128
129     // Password Access to unlock WDTCPU0CON0
130     ③ SCU_WDT_CPU0CON0 = ((SCU_WDT_CPU0CON0 ^ 0xFC) & ~(1 << LCK)) | (1 << ENDINIT);
131     while((SCU_WDT_CPU0CON0 & (1 << LCK)) != 0);
132
133     // Modify Access to set ENDINIT bit
134     SCU_WDT_CPU0CON0 = ((SCU_WDT_CPU0CON0 ^ 0xFC) | (1 << LCK)) | (1 << ENDINIT);
135     while((SCU_WDT_CPU0CON0 & (1 << LCK)) == 0);
136
137     while((GTM_CLC & (1 << DISS)) != 0);                      // Wait until module is enabled
138
139     /* GTM Clock Setting */
140     ④ GTM_CMU_FXCLK_CTRL &= ~((0xF) << FXCLK_SEL);      // Input clock of CMU_FXCLK : CMU_GCLK_EN
141
142     GTM_CMU_CLK_EN |= ((0x2) << EN_FXCLK);                // Enable all CMU_FXCLK
```



# PWM Example

## 3. 프로그래밍

### 2) GTM을 설정하기 위한 함수를 구현한다.

```
144  /* GTM TOM0 PWM Setting */
145  ⑤ GTM_TOM0_TGC0_GLB_CTRL |= ((0x2) << UPEN_CTRL5);      // TOM channel 5 enable update of
146                                         // register CM0, CM1, CLK_SRC
147
148  ⑥ GTM_TOM0_TGC0_FUPD_CTRL |= ((0x2) << FUPD_CTRL1);    // Enable force update of TOM channel 1
149  GTM_TOM0_TGC0_FUPD_CTRL |= ((0x2) << RSTCN0_CH1);       // Reset CN0 of TOM channel 1 on force update
150
151  ⑦ GTM_TOM0_TGC0_ENDIS_CTRL |= ((0x2) << ENDIS_CTRL1); // Enable channel 1 on an update trigger
152  GTM_TOM0_TGC0_OUTEN_CTRL |= ((0x2) << OUTEN_CTRL1);   // Enable channel 1 output on an update trigger
153
154  ⑧ GTM_TOM0_CH1_CTRL |= (1 << SL);                      // High signal level for duty cycle
155
156  ⑨ GTM_TOM0_CH1_CTRL &= ~((0x7) << CLK_SRC_SR);        // Clock source : CMU_FXCLK(1) = 3125 kHz
157  GTM_TOM0_CH1_CTRL |= (1 << CLK_SRC_SR);
158  GTM_TOM0_CH1_SR0 = 12500 - 1;                            // PWM freq. = 3125 kHz / 12500 = 250 Hz
159  // GTM_TOM0_CH1_SR1 = 0;                                // Duty cycle = 0 / 12500 = 0
160  // GTM_TOM0_CH1_SR1 = 6250-1;                          // Duty cycle = 50 / 12500 = 0
161  GTM_TOM0_CH1_SR1 = 12500 - 1;                          // Duty cycle = 100 / 12500 = 0
162
163  ⑩ GTM_TOUTSEL6 &= ~((0x3) << SEL7);                // TOUT103 : TOM0 channel 1
164
165  ⑪ GTM_TOM0_TGC0_GLB_CTRL |= (1 << HOST_TRIG);       // Trigger request signal to update
166 }
```

GTM 설정 함수



# PWM Example

## 3. 프로그래밍

3) 동작에 따라 'main' 함수를 구현한다. (앞서 구현한 함수들을 호출한다.)

```
31/* Address of Registers */
32// SCU Registers
33#define SCU_BASE          (0xF0036000)
34#define SCU_WDT_CPU0CON0  (*volatile unsigned int*)(SCU_BASE + 0x100)
35
36#define LCK              1
37#define ENDINIT          0
38
39// GTM Registers
40// GTM - CMU
41#define GTM_BASE          (0xF0100000)
42#define GTM_CMU_CLK_EN    (*volatile unsigned int*)(GTM_BASE + 0x00300)
43#define GTM_CMU_FXCLK_CTRL (*volatile unsigned int*)(GTM_BASE + 0x00344)
44
45#define EN_FXCLK          22
46#define FXCLK_SEL         0
47
48// GTM - TOM0
49#define GTM_TOM0_TGC0_GLB_CTRL  (*volatile unsigned int*)(GTM_BASE + 0x08030)
50#define GTM_TOM0_TGC0_ENDIS_CTRL (*volatile unsigned int*)(GTM_BASE + 0x08070)
51#define GTM_TOM0_TGC0_OUTEN_CTRL (*volatile unsigned int*)(GTM_BASE + 0x08078)
52#define GTM_TOM0_TGC0_FUPD_CTRL  (*volatile unsigned int*)(GTM_BASE + 0x08038)
53#define GTM_TOM0_CH1_CTRL     (*volatile unsigned int*)(GTM_BASE + 0x08040)
54#define GTM_TOM0_CH1_SR0      (*volatile unsigned int*)(GTM_BASE + 0x08044)
55#define GTM_TOM0_CH1_SR1      (*volatile unsigned int*)(GTM_BASE + 0x08048)
56
57#define UPEN_CTRL5          26
58#define HOST_TRIG           0
59#define ENDIS_CTRL1          2
60#define OUTEN_CTRL1          2
61#define RSTCN0_CH1           18
62#define FUPD_CTRL1           2
63#define CLK_SRC_SR            12
64#define SL                  11
65
66// GTM
67#define GTM_CLC             (*volatile unsigned int*)(GTM_BASE + 0x9FD00)
68#define GTM_TOUTSEL6          (*volatile unsigned int*)(GTM_BASE + 0x9FD48)
69
70#define DISS                1
71#define DISR                0
72#define SEL7                 14
```

```
74 // PORT10 Registers
75 #define PORT10_BASE        (0xF003B000)
76 #define PORT10_IOCR0      (*volatile unsigned int*)(PORT10_BASE + 0x10)
77
78#define PC1                11
79
80/* Function Prototype */
81void init_LED(void);
82void init_GTM_TOM0_PWM(void);
83
84IfxCpu_syncEvent g_cpuSyncEvent = 0;
85
86int core0_main(void)
87{
88    IfxCpu_enableInterrupts();
89
90    /* !!WATCHDOG0 AND SAFETY WATCHDOG ARE DISABLED HERE!!
91     * Enable the watchdogs and service them periodically if it is required
92     */
93    IfxScuWdt_disableCpuWatchdog(IfxScuWdt_getCpuWatchdogPassword());
94    IfxScuWdt_disableSafetyWatchdog(IfxScuWdt_getSafetyWatchdogPassword());
95
96    /* Wait for CPU sync event */
97    IfxCpu_emitEvent(&g_cpuSyncEvent);
98    IfxCpu_waitEvent(&g_cpuSyncEvent, 1);
99
100    init_LED();
101    init_GTM_TOM0_PWM();
102
103    while(1)
104    {
105    }
106    return (1);
107}
```

# PWM Example

## 4. 동작 확인

- ✓ Build 및 Debug 후 ('Resume' 버튼 클릭), CM1 값을 바꿔보며 Duty Ratio에 따른 LED 밝기를 확인한다.



Duty = 0%



Duty = 50%



Duty = 100%

# Q & A

**Thank you for your attention**



Architecture and  
Compiler  
for Embedded Systems Lab.

**School of Electronics Engineering, KNU**

ACE Lab (hn02301@gmail.com)