

# 임베디드 기반 SW 개발 프로젝트

## Driving Analog World using Digital Time-based Modulation

- PWM-based Energy Transfer Modulation for TC275 Infineon Embedded Processors-

현대자동차 입문교육  
박대진 교수

# 실습 목표

1. 확장 보드의 가변 저항에 의한 전압을 ADC로 읽고,
2. 샘플링된 ADC값의 범위에 따라 LED RED에 대한 GPIO 출력의 PWM duty cycle을 제어해서 LED의 밝기를 변화시켜 본다.

# PWM (Pulse Width Modulation) 이란?

- PWM (Pulse Width Modulation) : One sample → express **ratio of HIGH value** in one cycle  
= duty cycle

sample value : 100



# T축의 변조로, Y값을 제어하는 방법



전압 Y를 고정(5V) 시켜두고  
t축 Edge를 modulation



# T축의 변조로, Y값을 제어하는 방법



전압 Y를 고정(5V) 시켜두고  
t축 Edge를 modulation



# 사용된 약어 정리

- PWM (Pulse Width Modulation)
- GTM (Generic Timer Module)
- CMU (Clock Management Unit)
- EGU (External Generation Unit)
- FXU (Fixed Clock Generation Unit)
- TOM (Timer Output Module)
- TGC (TOM Global Control Unit)



# PWM 신호 생성 flow

## : GTM 모듈의 시스템 clock 사용한 PWM 신호 출력

- GTM (Generic Timer Module) 에는 다양한 기능을 가지는 submodule 들이 존재
  - ATOM, BRC, MCS, PSM, SPE, TIM, TOM 등 ...
- 본 실습에서 사용하는 PWM 기능은 **TOM (Timer Output Module)** 을 사용함



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf  
p.2731

Figure 25-1 GTM Architecture Block Diagram

# GTM (Generic Timer Module) 사용을 위한 레지스터 설정 : GTM 모듈 enable 위해서는 보호 레지스터 잠금 해제 필요

- GTM 모듈 사용을 위해 Clock Control 레지스터에서 **GTM 모듈 enable** 필요
- GTM 레지스터 항목에서
  - **CLC** 레지스터 설정 필요
- GTM\_CLC 레지스터는 System Critical 레지스터이므로 CPU ENDINIT 해제 후 수정해야함
- (CPU0 만을 사용하므로) SCU 레지스터 항목에서
  - **WDTCPU0CON0** 레지스터 설정 필요

[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf](#) p.3469

Table 25-64 Registers Overview - GTM Control Registers

| Short Name | Description                | Offset Addr.       | Access Mode |          | Reset       | Description Sec                 |
|------------|----------------------------|--------------------|-------------|----------|-------------|---------------------------------|
|            |                            |                    | Read        | Write    |             |                                 |
| CLC        | Clock Control Register     | 9FD00 <sub>H</sub> | U, SV       | S, E, P  | Application | <a href="#">Page 25-74</a><br>9 |
| TIMOINSE   | TIMO Input Select Register | 9FD10 <sub>H</sub> | U, SV       | U, SV, D | Application | <a href="#">Page 25-77</a><br>2 |

[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf](#) p.650

- “CE0” - writeable only when CPU0 ENDINIT bit is zero
- “CE1” - writeable only when CPU1 ENDINIT bit is zero
- “CE2” - writeable only when CPU2 ENDINIT bit is zero
- “E” - writeable when any (one or more) CPUx ENDINIT bit is zero
- “SE” - writeable only when Safety ENDINIT bit is zero
- None of the above - accessible at any time

# SCU 레지스터 설정 – WDTCPUOCON0

## : GTM 모듈 사용 설정 과정을 보호하는 레지스터

### 1. SCU 레지스터 영역의 주소 찾기

- 시작 주소 (Base address)
- **= 0xF0036000**



|                              |                                 |         |        |        |
|------------------------------|---------------------------------|---------|--------|--------|
| Reserved                     | $F003\ 5200_H$ - $F003\ 5FFF_H$ | ~       | SPBBE  | SPBBE  |
| System Control Unit (SCU)    | $F003\ 6000_H$ - $F003\ 63FF_H$ | 1 Kbyte | access | access |
| Reserved                     | $F003\ 6400_H$ - $F003\ 67FF_H$ | ~       | SPBBE  | SPBBE  |
| Safety Management Unit (SMU) | $F003\ 6800_H$ - $F003\ 6FFF_H$ | ~       | access | access |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.230

### 2. 사용할 레지스터의 주소 찾기

- **WDTCPUOCON0** 의 Offset Address = **0x100**

$$\rightarrow \text{WDTCPUOCON0 레지스터 주소} = 0xF0036000 + 0x100 = \textcolor{red}{0xF0036100}$$

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

| Short Name  | Long Name                   | Offset Addr.<br>1) | Access Mode |                                 | Reset             | Description See            |
|-------------|-----------------------------|--------------------|-------------|---------------------------------|-------------------|----------------------------|
|             |                             |                    | Read        | Write                           |                   |                            |
| EMSR        | Emergency Stop Register     | $0FC_H$            | U, SV       | SV, SE, P                       | Application Reset | <a href="#">Page 7-291</a> |
| WDTCPUOCON0 | CPU0 WDT Control Register 0 | $100_H$            | U, SV       | U, SV, 32,(CPU 0 <sup>2</sup> ) | Application Reset | <a href="#">Page 7-276</a> |
| WDTCPUOCON1 | CPU0 WDT Control Register 1 | $104_H$            | U, SV       | SV,                             | Application       | <a href="#">Page</a>       |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.697

# SCU 레지스터 설정 – WDTCPUOCONO

## :GTM 모듈 사용하도록 설정 위해 보호 레지스터 잠금 해제

3. Password Access 를 통해 WDTCPUOCONO 레지스터의 Lock 상태를 해제해야 함

- 1) WDTCPUOCONO 레지스터를 읽어 **WDTCPUOCONO.REL**, **WDTCPUOCONO.PW** 영역의 값을 확인



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.661

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.662

|    |        |     |                                                                                                                                                                                                                                                                                                                            |
|----|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PW | [15:2] | rwh | <small>A Modify access does not clear LCK.</small>                                                                                                                                                                                                                                                                         |
|    |        |     | <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. |

단, PW 영역의 일부 PW[7:2] 는 반전해서 읽어야 함

- 2) Write 할 값은 1)에서 읽은 REL 과 PW 의 조합으로 결정

**[31:16] = REL, [15:2] = PW, [1] = “0”, [0] = “1”**

- 3) 결정한 32bit 값을 WDTCPUOCONO 레지스터에 한 번에 write
- 4) WDTCPUOCONO 레지스터의 1번째 bit LCK 를 읽어서 Lock 상태가 해제되었는지 확인  
**Lock 상태가 해제되면 LCK bit 가 0으로 읽힘**

# Lab1: 헤더 파일 작성

## :GTM 레지스터의 각 영역(필드) LSB 비트 시작 위치 define 정의

- 레지스터에 값을 write할 때 shift되는 offset을 쉽게 사용하기 위한 define 작성

```
--  
26 // *****  
27 #include "Ifx_Types.h"  
28 #include "IfxCpu.h"  
29 #include "IfxScuWdt.h"  
30  
31 #include "IfxCcu6_reg.h"  
32 #include "IfxVadc_reg.h"  
33 #include "IfxGtm_reg.h"  
34
```

→ 헤더 파일 참조 추가

```
89 // GTM registers  
90 #define DISS_BIT_LSB_IDX 1  
91 #define DISR_BIT_LSB_IDX 0  
92 #define SEL7_BIT_LSB_IDX 14  
93 #define EN_FXCLK_BIT_LSB_IDX 22  
94 #define FXCLK_SEL_BIT_LSB_IDX 0  
95  
96 // GTM - TDM0 registers  
97 #define UPEN_CTRL1_BIT_LSB_IDX 18  
98 #define HOST_TRIG_BIT_LSB_IDX 0  
99 #define ENDIS_CTRL1_BIT_LSB_IDX 2  
100 #define OUTEN_CTRL1_BIT_LSB_IDX 2  
101 #define CLK_SRC_SR_BIT_LSB_IDX 12  
102 #define OSM_BIT_LSB_IDX 26  
103 #define TRIGOUT_BIT_LSB_IDX 24  
104 #define SL_BIT_LSB_IDX 11  
105  
106
```



GTM 레지스터 bit shift offset

# Lab2: SCU 레지스터 설정 – WDTCPU0CON0

## :GTM 모듈 사용하도록 설정 위해 보호 레지스터 잠금 해제

```
70@ void initGTM(void)
71{
72    // Password Access to unlock SCU_WDTSCON0
73    SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74    while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76    // Modify Access to clear ENDINIT
77    SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78    while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80    GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82    // Password Access to unlock SCU_WDTSCON0
83    SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84    while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86    // Modify Access to set ENDINIT
87    SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88    while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90    while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93    // GTM clock configuration
94    GTM_CMU_FXCLK_CTRL.U &=~(0xF << FXCLK_SEL_BIT_LSB_IDX);    // input clock of CMU_FXCLK --> CMU_GCLK_EN
95    GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;    // enable all CMU_FXCLK
96
97    // GTM T0M0 PWM configuration
98    GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;    // T0M channel 1 update enable
99
100   GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;    // enable channel 1 on update trigger
101
102   GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;    // enable channel 1 output on update trigger
103
104   GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;    // high signal level for duty cycle
105   GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;    // clock source --> CMU_FXCLK(1) = 6250 kHz
106   GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;    // continuous mode enable
107   GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);    // TRIG[x] = TRIG[x-1]
108
109   GTM_TOM0_CH1_SR0.U = 12500 - 1;    // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111   GTM_TOM0_CH1_SR1.U = 1250 - 1;    // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113   GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);    // TOUT103 --> T0M0 channel 1
114
115 }
```

# GTM 레지스터 설정 – CLC

## 1. GTM 레지스터 영역의 주소 찾기

- 시작 주소 (Base address)
- = **0xF0100000**



[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf p.232](#)

| (I2CU)                    | F00D 00FF <sub>H</sub>                          | byte      |        |        |
|---------------------------|-------------------------------------------------|-----------|--------|--------|
| Reserved                  | F00D 0100 <sub>H</sub> - F00F FFFF <sub>H</sub> | -         | SPBBE  | SPBBE  |
| Global Timer Module (GTM) | F010 0000 <sub>H</sub> - F019 FFFF <sub>H</sub> | 640 Kbyte | access | access |
| Reserved                  | F01A 0000 <sub>H</sub> - F7FF FFFF <sub>H</sub> |           | SPBBE  | SPBBE  |
| Default                   | F800 0000                                       |           | SPIDE  | SPIDE  |

## 2. 사용할 레지스터의 주소 찾기

- CLC 의 Offset Address = **0x9FD00**

$$\rightarrow \text{CLC 레지스터 주소} = 0xF0100000 + 0x9FD00 = \textcolor{red}{\mathbf{0xF019FD00}}$$

Table 25-64 | Registers Overview - GTM Control Registers

| Short Name | Description                | Offset Addr.       | Access Mode |          | Reset       | Description See              |
|------------|----------------------------|--------------------|-------------|----------|-------------|------------------------------|
|            |                            |                    | Read        | Write    |             |                              |
| CLC        | Clock Control Register     | 9FD00 <sub>H</sub> | U, SV       | SV, E, P | Application | <a href="#">Page 25-74 9</a> |
| TIM0INSEL  | TIM0 Input Select Register | 9FD10 <sub>H</sub> | U, SV       | U, SV, P | Application | <a href="#">Page 25-77 3</a> |
| TIM1INSEL  | TIM1 Input Select Register | 9FD14 <sub>H</sub> | U, SV       | U, SV, P | Application | <a href="#">Page 25-77 2</a> |

[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf p.3469](#)

# GTM 레지스터 설정 – CLC

## :GTM 모듈 사용 설정

### 3. 레지스터 write 값 결정

- GTM 모듈을 enable 하기 위해 **DISR** 영역에 **0x1 write**
- GTM 모듈을 enable 된 것을 확인하기 위해 **DISS** 영역의 값이 “0”인지 확인 (만약 **enable** 되지 않았다면 “1”의 값 유지)

### CLC 레지스터 @ 0xF019FD00



| Field | Bits | Type | Description                                                                                                                                                                           |
|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DISR  | 0    | rw   | <b>Module Disable Request Bit</b><br>Used for enable/disable control of the module.<br>0 <sub>B</sub> Module disable is not requested.<br>1 <sub>B</sub> Module disable is requested. |
| DISS  | 1    | rh   | <b>Module Disable Status Bit</b><br>Bit indicates the current status of the module.<br>0 <sub>B</sub> Module is enabled.<br>1 <sub>B</sub> Module is disabled.                        |
| EDIS  | 3    | rw   | <b>Sleep Mode Enable Control</b>                                                                                                                                                      |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.3476

# Lab3: GTM 레지스터 설정 – CLC

## :GTM 모듈 사용 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                      // enable all CMU_FXCLK
96
97     // GTM T0M0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;           // T0M channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;          // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;          // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                          // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                  // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;                        // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);                 // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                         // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                         // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                         // TOUT103 --> T0M0 channel 1
114
115 }
116 }
```

# SCU 레지스터 설정 – WDTCPUOCONO

## :GTM 모듈 사용 설정 후, 보호 레지스터 잠금 설정

4. **Modify Access** 를 통해 WDTCPUOCONO 레지스터의 CPUO ENDINIT을 set/clear 함

- 1) WDTCPUOCONO 레지스터를 읽어 **WDTCPUOCONO.REL**, **WDTCPUOCONO.PW** 영역의 값을 확인



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.662

|    |        |     |                                                                                                                                                                                                                                                             |
|----|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PW | [15:2] | rwh | User-Definable Password Field for Access to WDTxCONO                                                                                                                                                                                                        |
|    |        |     | 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. |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.661

단, PW 영역의 일부 PW[7:2] 는 반전해서 읽어야 함

- 2) Write 할 값은 1)에서 읽은 REL 과 PW 의 조합으로 결정

**[31:16] = REL, [15:2] = PW, [1] = “1”**

- 3) 0번째 bit **ENDINIT**을 설정하려면 **[0] = “1”**, 해제하려면 **“0”** 값을 write

- 4) 결정한 32bit 값을 WDTCPUOCONO 레지스터에 한 번에 write

- 5) WDTCPUOCONO 레지스터의 1번째 bit LCK 를 읽어서 Lock 상태가 설정되었는지 확인  
Lock 상태가 설정되면 LCK bit 가 1로 읽힘

5. **Modify Access** 를 통해 CPUO ENDINIT을 해제하면 레지스터 수정 후 반드시 CPUO ENDINIT을 재설정해줘야 함

# Lab4: SCU 레지스터 설정 – WDTCPU0CON0

## :GTM 모듈 사용 설정 후, 보호 레지스터 잠금 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                      // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;            // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;          // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;          // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                          // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                  // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;                        // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);                 // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                         // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                         // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                         // TOUT103 --> TOM0 channel 1
114
115 }
```

# PWM 신호 생성 flow

## :CMU 내부에 FXU에서 TOM이 사용할 clock 생성

- GTM – TOM에서 사용되는 clock 신호의 생성은 **CMU (Clock Management Unit)** 가 담당
  - TOM은 CMU에서 생성되는 clock 신호 중, **FXU (Fixed Clock Generation Unit)**에서 생성되는 clock들을 사용함
- FXU에 입력되는 clock 신호, FXU에서 TOM으로 공급되는 clock 신호에 대한 설정 필요



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2829



Figure 25-17 CMU Block Diagram

# GTM 사용을 위한 레지스터 설정

## :FXU에서 GTM 내부 TOM이 사용할 clock 생성

- GTM 모듈에서 TOM으로 clock 을 전달해주는 역할은 CMU 가 담당하며, **TOM은 FXU에서 생성하는 FXCLK를 사용함**  
→ FXU가 사용할 Clock, FXCLK의 주파수, 번호 등의 결정 필요
- GTM 레지스터 항목에서
  - **CMU\_CLK\_EN** 레지스터 설정 필요
  - **CMU\_FXCLK\_CTRL** 레지스터 설정 필요

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2829



Figure 25-17 CMU Block Diagram

# GTM 레지스터 설정 – CMU\_FXCLK\_CTRL

1. GTM 레지스터 영역의 주소 찾기
  - 시작 주소 (Base address) = **0xF0100000**
2. 사용할 레지스터의 주소 찾기
  - **CMU\_FXCLK\_CTRL** 의 Offset Address = **0x344**  
→ CMU\_FXCLK\_CTRL 레지스터 주소 = 0xF0100000 + 0x344 = **0xF0100344**

## CMU\_FXCLK\_CTRL 레지스터 @ 0xF0100344



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2844

# GTM 레지스터 설정 – CMU\_FXCLK\_CTRL

## :FXU에서 생성할 clock에 대한 설정

### 3. 레지스터 write 값 결정

- CMU 내부의 FXU에 대한 clock으로 GTM 모듈의 입력 clock인 **CMU\_GCLK\_EN**을 사용하기 위해 **FXCLK\_SEL** 영역에 **0x0 write**

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2829

### CMU\_FXCLK\_CTRL 레지스터 @ 0xF0100344



GTM 모듈에  
입력되는 system  
clock을 FXU로 입력



Figure 25-17 CMU Block Diagram

# Lab5: GTM 레지스터 설정 – CMU\_FXCLK\_CTRL

## :FXU에서 생성할 clock에 대한 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM 3.1 config
94     GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);    // input clock of CMU_FXCLK --> CMU_GCLK EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                // enable all CMU_FXCLK
96
97     // GTM_TOM0_PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;      // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;    // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;    // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                  // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;            // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << OSM_BIT_LSB_IDX);              // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);           // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                 // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                // TOUT103 --> TOM0 channel 1
114
115 }
116 }
```

```
#define FXCLK_SEL_BIT_LSB_IDX
```

# GTM 레지스터 설정 – CMU\_CLK\_EN

1. GTM 레지스터 영역의 주소 찾기
  - 시작 주소 (Base address) = **0xF0100000**
2. 사용할 레지스터의 주소 찾기
  - **CMU\_CLK\_EN** 의 Offset Address = **0x300**  
→ CMU\_CLK\_EN 레지스터 주소 = 0xF0100000 + 0x300 = **0xF0100300**

## CMU\_CLK\_EN 레지스터 @ 0xF0100300

| GTM_CMU_CLK_EN<br>CMU Clock Enable Register                                                                                                                                                                                                                                                                                                                                           |  |         |  |         |   |          |          |          |  |                                    |  |         |  |         |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|---------|--|---------|---|----------|----------|----------|--|------------------------------------|--|---------|--|---------|--|--|--|--|--|----------|--|--|--|--|---|----------|----------|----------|--|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| offset<br>(00300 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                       |  |         |  |         |   |          |          |          |  | Reset Value: 00000000 <sub>H</sub> |  |         |  |         |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16                                                                                                                                                                                                                                                                                                                                       |  |         |  |         |   |          |          |          |  |                                    |  |         |  |         |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table border="1"><tr><td colspan="10">Reserved</td></tr><tr><td colspan="5" style="text-align: center;">EN_FXCLK</td><td style="text-align: center;">K</td><td style="text-align: center;">EN_ECLK2</td><td style="text-align: center;">EN_ECLK1</td><td style="text-align: center;">EN_ECLK0</td><td></td></tr><tr><td colspan="10" style="text-align: center;">r</td></tr></table> |  |         |  |         |   |          |          |          |  | Reserved                           |  |         |  |         |  |  |  |  |  | EN_FXCLK |  |  |  |  | K | EN_ECLK2 | EN_ECLK1 | EN_ECLK0 |  | r |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reserved                                                                                                                                                                                                                                                                                                                                                                              |  |         |  |         |   |          |          |          |  |                                    |  |         |  |         |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| EN_FXCLK                                                                                                                                                                                                                                                                                                                                                                              |  |         |  |         | K | EN_ECLK2 | EN_ECLK1 | EN_ECLK0 |  |                                    |  |         |  |         |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| r                                                                                                                                                                                                                                                                                                                                                                                     |  |         |  |         |   |          |          |          |  |                                    |  |         |  |         |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                 |  |         |  |         |   |          |          |          |  |                                    |  |         |  |         |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| EN_CLK7                                                                                                                                                                                                                                                                                                                                                                               |  | EN_CLK6 |  | EN_CLK5 |   | EN_CLK4  |          | EN_CLK3  |  | EN_CLK2                            |  | EN_CLK1 |  | EN_CLK0 |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| rw                                                                                                                                                                                                                                                                                                                                                                                    |  | rw      |  | rw      |   | rw       |          | rw       |  | rw                                 |  | rw      |  | rw      |  |  |  |  |  |          |  |  |  |  |   |          |          |          |  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2835

# GTM 레지스터 설정 – CMU\_CLK\_EN

## :FXU에서 생성할 clock에 대한 설정

### 3. 레지스터 write 값 결정

- TOM은 FXU에서 생성하는 FXCLK를 사용
- FXCLK를 사용하기 위해 **EN\_FXCLK\_SEL** 영역에 **0x2 write**

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2829

### CMU\_CLK\_EN 레지스터 @ 0xF0100300



|          |         |    |                                                                                                |
|----------|---------|----|------------------------------------------------------------------------------------------------|
| 2        |         |    | see bits [1:0]                                                                                 |
| EN_FXCLK | [23:22] | RW | Enable all CMU_FXCLK<br>see bits [1:0]                                                         |
| K        |         |    | Note: An enable to EN_FXCLK from disable state will be<br>reset internal fixed clock counters. |
| Reserved | [31:24] | r  | Reserved                                                                                       |

- 00<sub>B</sub> clock source is disabled (ignore write access)
- 01<sub>B</sub> disable clock signal and reset internal states
- 10<sub>B</sub> enable clock signal
- 11<sub>B</sub> clock signal enabled (ignore write access)

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2835



# Lab6: GTM 레지스터 설정 – CMU\_CLK\_EN

## :FXU에서 생성할 clock에 대한 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);    // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;    // enable all CMU_FXCLK
96
97     // GTM_TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;    // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;    // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;    // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;    // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;    // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;    // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);    // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;    // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;    // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);    // TOUT103 --> TOM0 channel 1
114
115 }
116 }
```

| 94 #define EN\_FXCLK\_BIT\_LSB\_IDX      22

# PWM 신호 생성 flow

## :TOM에서 PWM 출력 신호 생성

- PWM 기능을 사용하기 위한 TOM의 구조
- TOM은 TGC (TOM Global Channel Control)의 제어를 받아 출력 신호를 생성  
→ TOM의 기능 중, PWM 기능을 사용하기 위한 설정 필요
- TOM의 출력은 MCU의 핀으로 바로 출력 가능, 사용하려는 핀이 TOM의 어떤 Channel과 연결되어 있는지 확인 필요



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2918



# GTM 사용을 위한 레지스터 설정

## :GPIO 출력을 GTM 출력으로 사용하는 설정

- PWM 신호를 통해 밝기를 제어할 LED RED가 연결된 핀은 P10.1

Table 13-16 Port 10 Functions (cont'd)

| Port Pin | I/O | Pin Functionality      | Associated Reg./ I/O Line | Port I/O Control Select. |                    |
|----------|-----|------------------------|---------------------------|--------------------------|--------------------|
|          |     |                        |                           | Reg./Bit Field           | Value              |
| P10.1    | I   | General-purpose input  | P10_IN.P1                 | P10_IOCR0.<br>PC1        | 0XXXX <sub>B</sub> |
|          |     | GTM input              | TIN103                    |                          |                    |
|          |     | QSPI1 input            | MRST1A                    |                          |                    |
|          |     | GPT120 input           | T5EUDB                    |                          |                    |
|          |     | General-purpose output | P10_OUT.P1                |                          | 1X000 <sub>B</sub> |
|          | O   | GTM output             | TOUT103                   |                          | 1X001 <sub>B</sub> |
|          |     | QSPI1 output           | MTSR1                     |                          | 1X010 <sub>B</sub> |
|          |     | QSPI1 output           | MRST1                     |                          | 1X011 <sub>B</sub> |
|          |     | MSC0                   | EN01                      |                          | 1X100 <sub>B</sub> |
|          |     | VADC output            | VADCG6BFL1                |                          | 1X101 <sub>B</sub> |
|          |     | MSC0 output            | END03                     |                          | 1X110 <sub>B</sub> |
|          |     | Reserved               | -                         |                          | 1X111 <sub>B</sub> |



P10.1 핀의 GPIO 출력을 GTM 출력으로 사용하기 위해 →  
포트의 I/O Control 레지스터 설정 필요

- GPIO P10 레지스터 항목에서
  - IOCR0 레지스터 설정 필요

# GPIO 레지스터 설정 – P10 Address 계산

## : Port 10의 각 레지스터가 위치한 주소 확인

### 3. 사용할 특정 레지스터의 주소 찾기

– P10\_IOCRO Offset Address = 0x0010

→ P10\_IOCRO 레지스터 주소

→ = 0xF003B000 + 0x0010 = **0xF003B010**

Table 13-4 Registers Overview

| Register Short Name | Register Long Name                     | Offset Address    | Access Mode |          | Reset             | Desc. see                   |
|---------------------|----------------------------------------|-------------------|-------------|----------|-------------------|-----------------------------|
|                     |                                        |                   | Read        | Write    |                   |                             |
| Pn_OUT              | Port n Output Register                 | 0000 <sub>H</sub> | U, SV       | U, SV, P | Application Reset | <a href="#">Page 13-3 8</a> |
| Pn_OMR              | Port n Output Modification Register    | 0004 <sub>H</sub> | U, SV       | U, SV, P | Application Reset | <a href="#">Page 13-3 9</a> |
| ID                  | Module Identification Register         | 0008 <sub>H</sub> | U, SV       | BE       | Application Reset | <a href="#">Page 13-1 3</a> |
| Pn_IOCRO            | Port n Input/Output Control Register 0 | 0010 <sub>H</sub> | U, SV       | U, SV, P | Application Reset | <a href="#">Page 13-1 4</a> |
| Pn_IOCRA            | Port n Input/Output Control Register A | 0014 <sub>H</sub> | U, SV       | U, SV, P | Application Reset | <a href="#">Page 13-1 4</a> |



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.1074

# GPIO 레지스터 설정 – P10 I/O 모드

## : Port 10의 핀 1을 GTM 출력 모드로 사용

- P10.1 을 General Purpose Output (push-pull)가 아닌 GTM 모듈의 출력으로 사용하기 위해 P10\_IOCRO 레지스터에 어떤 값을 써야 하는지 확인 → 0x11 write (예전에 단순 GPIO 출력으로 쓸 때는 0x10를 썼다)

P10\_IOCRO 레지스터 @ 0xF003B010

|     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |
|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|
| 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  |    | PC0 |    | 0  |    |    |    |    |    |    |    |    |    |
| rw  |    |    |    | r   |    |    |    | rw |    |    |    | r  |    |    |    |

| 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 (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<br>Read as 0; should be written with 0.                                                                                                          |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.1080

Table 13-16 Port 10 Functions (cont'd)

| Port Pin | I/O | Pin Functionality      | Associated Reg./I/O Line | Port I/O Control Select. |
|----------|-----|------------------------|--------------------------|--------------------------|
|          |     |                        |                          | Reg./Bit Field           |
| P10.1    | I   | General-purpose input  | P10_IN.P1                | P10_IOCRO.<br>PC1        |
|          |     | GTM input              | TIN103                   |                          |
|          |     | QSPI1 input            | MRST1A                   |                          |
|          |     | GPT120 input           | T5EUDB                   |                          |
|          | O   | General-purpose output | P10_OUT.P1               | 1X000 <sub>B</sub>       |
|          |     | GTM output             | TOUT103                  |                          |
|          |     | QSPI1 output           | MTSR1                    |                          |
|          |     | QSPI1 output           | MRST1                    |                          |
|          |     | MSC0                   | EN01                     |                          |
|          |     | VADC output            | VADCG6BFL1               |                          |
|          |     | MSC0 output            | END03                    | 1X110 <sub>B</sub>       |
|          |     | Reserved               | -                        | 1X111 <sub>B</sub>       |

what?

- GTM 출력 모드로 사용하기 위해 0x11 (10001b) 값을 PC1 영역에 write

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.1163

# Lab7: P10 레지스터 설정 – IOCRO

## :GPIO 출력 모드를 GTM 생성 출력으로 설정

```
void initLED(void)
{
    P10_IOCR0.U &= ~(0x1F << PC1_BIT_LSB_IDX);      // reset P10_IOCR0 PC1
    P10_IOCR0.U &= ~(0x1F << PC2_BIT_LSB_IDX);      // reset P10_IOCR0 PC2

    P10_IOCR0.U |= 0x10 << PC1_BIT_LSB_IDX;           // set P10.1 push-pull general output
    P10_IOCR0.U |= 0x10 << PC2_BIT_LSB_IDX;           // set P10.2 push-pull general output
}

void initPWMLED(void)
{
    P10_IOCR0.U &= ~(0x1F << PC1_BIT_LSB_IDX);      // reset P10_IOCR0 PC1
    P10_IOCR0.U &= ~(0x1F << PC2_BIT_LSB_IDX);      // reset P10_IOCR0 PC2

    P10_IOCR0.U |= 0x11 << PC1_BIT_LSB_IDX;           // set P10.1 GTM Out, (PWM Generation)
    P10_IOCR0.U |= 0x10 << PC2_BIT_LSB_IDX;           // set P10.2 push-pull general output
}
```

# GTM 사용을 위한 레지스터 설정

## :GTM 모듈의 PWM 출력을 MCU 외부 핀으로 연결

- PWM 신호를 통해 밝기를 제어할 LED RED가 연결된 핀은 **P10.1**
- 핀 P10.1에 **GPIO 대신 GTM 출력으로** 연결 필요 → **TOUT103**

Table 13-16 Port 10 Functions (cont'd)

| Port Pin | I/O | Pin Functionality      | Associated Reg./ I/O Line | Port I/O Control Select. |                    |
|----------|-----|------------------------|---------------------------|--------------------------|--------------------|
|          |     |                        |                           | Reg./Bit Field           | Value              |
| P10.1    | I   | General-purpose input  | P10_IN.P1                 | P10_IOCR0.<br>PC1        | 0XXXX <sub>B</sub> |
|          |     | GTM input              | TIN103                    |                          | 1X000 <sub>B</sub> |
|          |     | QSPI1 input            | MRST1A                    |                          | 1X001 <sub>B</sub> |
|          |     | GPT120 input           | T5EUDB                    |                          | 1X010 <sub>B</sub> |
|          | O   | General purpose output | P10_OUT.P1                |                          | 1X011 <sub>B</sub> |
|          |     | GTM output             | TOUT103                   |                          | 1X100 <sub>B</sub> |
|          |     | QSPI1 output           | MTCR1                     |                          | 1X101 <sub>B</sub> |
|          |     | QSPI1 output           | MRST1                     |                          | 1X110 <sub>B</sub> |
|          |     | MSC0                   | EN01                      |                          | 1X111 <sub>B</sub> |
|          |     | VADC output            | VADCG6BFL1                |                          |                    |
|          |     | MSC0 output            | END03                     |                          |                    |
|          |     | Reserved               | -                         |                          |                    |

→ GTM 출력으로 사용하기 위해  
TOUT103 관련 레지스터 설정 필요

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.1163

# GTM 사용을 위한 레지스터 설정

## :사용하는 GPIO 핀이 TOM의 어느 출력과 연결되는지 확인

- 앞서 핀 P10.1에 연결되는 GTM의 출력은 TOUT103인 것을 확인
- TOUT 출력은 GTM – TOM에서 사용하는 TOM 번호와 채널이 정해져 있음

→ P10.1은 TOUT103



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.3484

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       |
| P02.2 | TIN2   | TOUT2   | TIM0_2             | TIM1_2 | TOM0_10             | TOM1_10 | ATOM0_2 | ATOM1_2 |
| P02.3 | TIN3   | TOUT3   | TIM0_3             | TIM1_3 | TOM0_11             | TOM1_11 | ATOM0_3 | ATOM1_3 |
| P02.4 | TIN4   | TOUT4   | TIM0_4             | TIM1_4 | TOM0_12             | TOM1_12 | ATOM0_4 | ATOM1_4 |
| P02.5 | TIN5   | TOUT5   | TIM0_5             | TIM1_5 | TOM0_13             | TOM1_13 | ATOM0_5 | ATOM1_5 |
| P02.6 | TIN6   | TOUT6   | TIM0_6             | TIM1_6 | TOM0_14             | TOM1_14 | ATOM0_6 | ATOM1_6 |
| P02.7 | TIN7   | TOUT7   | TIM0_7             | TIM1_7 | TOM0_15             | TOM1_15 | ATOM0_7 | ATOM1_7 |
| P02.8 | TIN8   | TOUT8   | TIM2_0             | TIM3_0 | TOM0_8              | TOM1_0  | ATOM0_0 | ATOM1_0 |
| P10.0 | TIN102 | TOUT102 | TIM0_4             | TIM1_4 | TOM0_4              | TOM2_12 | ATOM1_4 | ATOM4_4 |
| P10.1 | TIN103 | TOUT103 | TIM0_1             | TIM1_1 | TOM0_1              | TOM2_9  | ATOM1_1 | ATOM4_1 |
| P10.2 | TIN104 | TOUT104 | TIM0_2             | TIM1_2 | TOM0_2              | TOM2_10 | ATOM    | ATOM    |

# GTM 레지스터 설정

## : Timer Output Selection Register (TOUTSELx)

### 1. GTM 레지스터 영역의 주소 찾기

- 시작 주소 (Base address) = **0xF0100000**

### 2. 사용할 레지스터의 주소 찾기

- 1개의 TOUTSELx 레지스터는 16개의 TOUT 핀을 제어함
- TOUT0 부터 16개씩 묶을 때 핀 **TOUT103** (P10.1)은 **TOUTSEL6**에 포함되어 있음(**TOUT96~ TOUT111** 안에 **TOUT103**이 포함)
- TOUTSEL6** 의 Offset Address = **0x9FD48**  
→ TOUTSEL6 레지스터 주소 = 0xF0100000 + 0x9FD48 = **0xF019FD48**

TOUTSEL0 → TOUT00 ~ TOUT15  
TOUTSEL1 → TOUT16 ~ TOUT31  
TOUTSEL2 → TOUT32 ~ TOUT47  
TOUTSEL3 → TOUT48 ~ TOUT63  
TOUTSEL4 → TOUT64 ~ TOUT79  
TOUTSEL5 → TOUT80 ~ TOUT95  
TOUTSEL6 → TOUT96 ~ TOUT103

Table 25-64 Registers Overview - GTM Control Registers

| Short Name | Description                    | Offset Addr.       | Access Mode |          | Reset       | Description See              |
|------------|--------------------------------|--------------------|-------------|----------|-------------|------------------------------|
|            |                                |                    | Read        | Write    |             |                              |
| TOUTSEL5   | Timer Output Select 5 Register | 9FD44 <sub>H</sub> | U, SV       | U, SV, P | Application | <a href="#">Page 25-81 4</a> |
| TOUTSEL6   | Timer Output Select 6 Register | 9FD48 <sub>H</sub> | U, SV       | U, SV, P | Application | <a href="#">Page 25-81 4</a> |
| TOUTSEL7   | Timer Output Select 7 Register | 9FD4C <sub>H</sub> | U, SV       | U, SV    | Application | <a href="#">Page 25-81 1</a> |

# GTM 레지스터 설정 – TOUTSEL6

## :TOM에서 출력되는 PWM 신호를 MCU 핀에 연결 설정

### 3. 레지스터 write 값 결정

- TOM0 채널1로부터 생성된 PWM 신호를 TOUT103 핀으로 출력하기 위한 설정
- **TOUTSEL6은 TOUT96부터 TOUT111까지 제어함.**
- **TOUT103 핀은 7번째임**
  - Output Timer Mapped에서 A 항목을 사용하도록 설정하기 위해 SEL7 영역에 0x0 write

### TOUTSEL6 레지스터 @ 0xF019FD48

| 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 | SEL15                                                                | SEL14 | SEL13 | SEL12 | SEL11 | SEL10 | SEL9 | SEL8 |                                     |  |  |  |  |  |  |  |
|                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                      |       |       |       |       |       |      |      |                                     |  |  |  |  |  |  |  |
| 15                              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  | SEL7                                                                 | SEL6  | SEL5  | SEL4  | SEL3  | SEL2  | SEL1 | SEL0 |                                     |  |  |  |  |  |  |  |
|                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                      |       |       |       |       |       |      |      |                                     |  |  |  |  |  |  |  |

| Field                          | Bits            | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------|-----------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SEL <sub>x</sub><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-67</a> <a href="#">Table 25-68</a><br><br>00 <sub>B</sub> Timer A form <a href="#">Table 25-67</a> <a href="#">Table 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-67</a> <a href="#">Table 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-67</a> <a href="#">Table 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-67</a> <a href="#">Table 25-68</a> is connected as TOUT(n*16+x) to the ports<br><br>Note: If TOUT(n*16+x) is not defined in <a href="#">Table 25-67</a> <a href="#">Table 25-68</a> this bit field has to be treated as reserved. |

# GTM 사용을 위한 레지스터 설정

: P10.1은 TOUT3에 연결되어 있으며, TOM0 모듈의 채널 1을 사용하도록 설정됨

→ P10.1 (TOUT103)은 TOM0 의 채널 1 사용

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.3484



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       |
| P02.2 | TIN2   | TOUT2   | TIM0_2             | TIM1_2 | TOM0_10             | TOM1_10 | ATOM0_2 | ATOM1_2 |
| P02.3 | TIN3   | TOUT3   | TIM0_3             | TIM1_3 | TOM0_11             | TOM1_11 | ATOM0_3 | ATOM1_3 |
| P02.4 | TIN4   | TOUT4   | TIM0_4             | TIM1_4 | TOM0_12             | TOM1_12 | ATOM0_4 | ATOM1_4 |
| P02.5 | TIN5   | TOUT5   | TIM0_5             | TIM1_5 | TOM0_13             | TOM1_13 | ATOM0_5 | ATOM1_5 |
| P02.6 | TIN6   | TOUT6   | TIM0_6             | TIM1_6 | TOM0_14             | TOM1_14 | ATOM0_6 | ATOM1_6 |
| P02.7 | TIN7   | TOUT7   | TIM0_7             | TIM1_7 | TOM0_15             | TOM1_15 | ATOM0_7 | ATOM1_7 |
| P02.8 | TIN8   | TOUT8   | TIM2_0             | TIM3_0 | TOM0_8              | TOM1_0  | ATOM0_0 | ATOM1_0 |
| P10.0 | TIN102 | TOUT102 | TIM0_4             | TIM1_4 | TOM0_4              | TOM2_12 | ATOM1_4 | ATOM4_4 |
| P10.1 | TIN103 | TOUT103 | TIM0_1             | TIM1_1 | TOM0_1              | TOM2_9  | ATOM1_1 | ATOM4_1 |
| P10.2 | TIN104 | TOUT104 | TIM0_2             | TIM1_2 | TOM0_2              | TOM2_10 | ATOM    | ATOM    |

Output Timer Mapped 의 A 항목 사용하도록 설정시  
→ 0번째 TOM (TOM0)의 채널 1 사용

# Lab8: GTM 레지스터 설정 – TOUTSEL6

:TOM에서 출력되는 (TOM0모듈의 채널1) PWM 신호를 MCU 핀에 연결 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                      // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;           // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;          // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;          // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                          // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                  // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;                        // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);                 // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                         // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                         // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                         // TOUT103 --> TOM0 channel 1
114    // 103 = 16 * 6 + 7
115 }
116 }
```

93 #define SEL7\_BIT\_LSB\_IDX

14

# GTM 사용을 위한 레지스터 설정

## :TOM에서 출력으로 사용할 채널 설정

- TOM 설정은 TGC (TOM Global Control Unit) 가 담당

### 25.11.2 TOM Global Channel Control (TGC0, TGC1)

#### 25.11.2.1 Overview

There exist two global channel control units (TGC0 and TGC1) to drive a number of individual TOM channels synchronously by external or internal events.

Each TGC[y] can drive up to eight TOM channels where TGC0 controls TOM channels 0 to 7 and TGC1 controls TOM channels 8 to 15.

The TOM submodule supports four different kinds of signalling mechanisms:

[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf p.2919](#)

- 본 실습에서는 **TOM0**의 채널 1을 사용하기 위해 **TGC0**에 해당하는 레지스터 설정 필요

- GTM 레지스터 항목에서
  - TOM0\_TGCO\_GLB\_CTRL** 레지스터 설정 필요
  - TOM0\_TGCO\_ENDIS\_CTRL** 레지스터 설정 필요
  - TOM0\_TGCO\_OUTEN\_CTRL** 레지스터 설정 필요

[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf p.2918](#)



Figure 25-32 TOM Block diagram

# GTM 레지스터 설정 – TOMO\_TGCO\_GLB\_CTRL

## 1. GTM 레지스터 영역의 주소 찾기

- 시작 주소 (Base address) = **0xF0100000**

## 2. 사용할 레지스터의 주소 찾기 (TOM0 이므로 i = 0)

- TOM0\_TGCO\_GLB\_CTRL** 의 Offset Address =  $0x8030 + (i * 0x800) = 0x8030$
- **TOM0\_TGCO\_GLB\_CTRL** 레지스터 주소 =  $0xF0100000 + 0x8030 = 0xF0108030$

**TOM0\_TGCO\_GLB\_CTRL** 레지스터 @ **0xF0108030**

| GTM_TOMi_TGC0_GLB_CTRL (i=0~2)<br>TOMi TGC0 Global Control Register (08030 <sub>H</sub> +i*800 <sub>H</sub> ) |                 |                 |                 |                 |                 |                 |                 |    |    |    |    |    |    |    |    | offset            | Reset Value: 00000000 <sub>H</sub> |
|---------------------------------------------------------------------------------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----|----|----|----|----|----|----|----|-------------------|------------------------------------|
| 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              | 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 |    |    |    |    |    |    |    |    | HOS<br>T_T<br>RIG |                                    |
| W                                                                                                             | W               | W               | W               | W               | W               | W               | W               |    |    |    |    |    |    |    |    | W                 |                                    |

# GTM 설정 레지스터의 write 구조

## :shadow 레지스터 write되어 update 신호 발생해야 실제 write

Update Trigger 신호

PWM 동작 설정에 필요한  
shadow 레지스터

- SW에서 레지스터 write를 하면 CM0, CM1에 write 되기 전에 먼저, shadow 레지스터에 저장
- Update Trigger 신호 발생하면 실제 레지스터로 옮겨 write 해야 함



# GTM 레지스터 설정 – TOMO\_TGCO\_GLB\_CTRL

## :TOM에서 사용할 채널 설정

### 3. 레지스터 write 값 결정

- TOM0의 채널 1이 동작하기 위해서는 해당 채널에서 PWM 설정 값들이 update 되어야 함
- Update가 가능하도록 설정하기 위해 **UPEN\_CTRL1** 영역에 **0x2 write**

### TOMO\_TGCO\_GLB\_CTRL 레지스터 @ 0xF0108030

| GTM_TOMi_TGCO_GLB_CTRL (i=0-2)                   |                |                |                |                |                |                |                |    |    |    |    |    |    |    |    | Reset Value: 00000000H |
|--------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----|----|----|----|----|----|----|----|------------------------|
| TOMi TGC0 Global Control Register(08030H+i*800H) |                |                |                |                |                |                |                |    |    |    |    |    |    |    |    |                        |
| 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_CH7                                          | RST_CH6        | RST_CH5        | RST_CH4        | RST_CH3        | RST_CH2        | RST_CH1        | RST_CH0        |    |    |    |    |    |    |    |    | HOST_TTRIG             |
| W                                                | W              | W              | W              | W              | W              | W              | W              |    |    |    |    |    |    |    |    | W                      |
| Reserved                                         |                |                |                |                |                |                |                |    |    |    |    |    |    |    |    |                        |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2937

|                |         |    |                                                                                |
|----------------|---------|----|--------------------------------------------------------------------------------|
| UPEN_CT<br>RL1 | [19:18] | rw | TOM channel 1 enable update of register CM0, CM1 and CLK_SRC<br>See bits 17:16 |
|----------------|---------|----|--------------------------------------------------------------------------------|

00B don't care, bits 1:0 will not be changed  
01B update disabled: is read as 00 (see below)  
10B update enabled: is read as 11 (see below)  
11B don't care, bits 1:0 will not be changed

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2923



# Lab9: GTM 레지스터 설정 – TOMO\_TGCO\_GLB\_CTRL

## :TOM에서 사용할 채널1의 update enable 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                      // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGCO_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;           // TOM channel 1 update enable
99
100    GTM_TOM0_TGCO_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;          // enable channel 1 on update trigger
101
102    GTM_TOM0_TGCO_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;          // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                          // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                  // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;                        // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);                 // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                         // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                         // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                         // TOUT103 --> TOM0 channel 1
114
115 }
116 
```

97 // GTM - TOM0 registers  
98 #define UPEN\_CTRL1\_BIT\_LSB\_IDX

# GTM 레지스터 update 하는 Trigger 신호 생성

## :1) SW에서 생성하는 Update Trigger 신호

- 앞으로 설정할 GTM 레지스터들이 실제 하드웨어에 적용될 수 있도록 하는 **Update Trigger** 신호를
- 1) SW에서 생성할 수 있음
- 2) PWM의 1주기에 도달했을 때 생성할 수 있음 (뒤에서 설명)
- Update Trigger 신호 발생 전까지는 레지스터에 write 해도 실제 하드웨어에 적용되지 않음 (shadow register 개념)

### 25.11.2.2 TGC Subunit

Each of the first three individual mechanisms (enable/disable of the channel, output enable and force update) can be driven by three different trigger sources.

The three trigger sources are:

- the host CPU (bit HOST\_TRIG of register TOMi\_TGCr\_GLB\_CTRL)
- the TBU time stamp (signal TBU\_TS0, TBU\_TS1, TBU\_TS2)
- the internal trigger signal TRIG (bunch of trigger signals TRIG\_[x])

Note: The trigger signal is only active for one configured CMU clock period.



# GTM 레지스터 설정 – TOMO\_TGCO\_GLB\_CTRL

## :TOM 레지스터 설정이 적용되도록 update trigger event 발생

### 3. 레지스터 write 값 결정

- TOM0의 채널 1에 대한 레지스터 설정이 shadow 레지스터로부터 하드웨어에 적용되도록 하기 위해 **HOST\_TRIG** 영역에 **0x1 write** (GTM 레지스터 설정 후 마지막에 수행)

**TOM0\_TGCO\_GLB\_CTRL** 레지스터@ 0xF0108030

| GTM_TOMi_TGC0_GLB_CTRL (i=0-2) |                 |                 |                 |                 |                 |                 |                 |          |    |    |    |    |    |    |    | 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 |    |    |    |    |    |    |    |                        |  |  |  |
| W                              | W               | W               | W               | W               | W               | W               | W               |          |    |    |    |    |    |    |    |                        |  |  |  |

| Field         | Bits | Type | Description                                                                                                                                                                                                                                                                    |
|---------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HOST_TRI<br>G | 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</p> <p>1<sub>B</sub> set trigger request</p> <p>Read as 0.</p> <p>Note: This flag is cleared automatically after triggering the update</p> |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2937

# Lab10: GTM 레지스터 설정 – TOMO\_TGC0\_GLB\_CTRL

## :TOM에서 출력 생성 시작하도록 trigger event 발생

99 #define HOST\_TRIG\_BIT\_LSB\_IDX 0

```
//initERU();
initCCU60();
//initLED();
initPWMLED();
initRGBLED();
initVADC();
InitGTM();
//initButton();

// trigger update request signal
GTM_TOM0_TGC0_GLB_CTRL.U |= 0x1 << HOST_TRIG_BIT_LSB_IDX;

while(1)
{
    VADC_startConversion();
    unsigned int adcResult = VADC_readResult();
    for(unsigned int i = 0; i < 100; i++);

    if( adcResult >= 3096 )
    {
        P02_OUT.U |= 0x1 << P7_BIT_LSB_IDX;
        P10_OUT.U &= ~(0x1 << P5_BIT_LSB_IDX);
        P10_OUT.U &= ~(0x1 << P3_BIT_LSB_IDX);
```

PWM 신호가 생성되기 원하는 시점에  
trigger 발생시켜야 함 (ADC conversion  
start와 비슷한 개념임)

# GTM 레지스터 설정 – TOMO\_TGCO\_ENDIS\_CTRL

1. GTM 레지스터 영역의 주소 찾기
  - 시작 주소 (Base address) = **0xF0100000**
2. 사용할 레지스터의 주소 찾기 (TOM0 이므로 i = 0)
  - **TOMO\_TGCO\_ENDIS\_CTRL** 의 Offset Address =  $0x8070 + (i * 0x800) = 0x8070$
  - TOMO\_TGCO\_ENDIS\_CTRL 레지스터 주소 =  $0xF0100000 + 0x8070 = \textcolor{red}{0xF0108070}$



# GTM 레지스터 설정 – TOMO\_TGCO\_ENDIS\_CTRL

## :TOM에서 사용할 채널에 대한 설정

### 3. 레지스터 write 값 결정

- TOMO\_TGCO\_GLB\_CTRL 레지스터에서 Update Trigger 신호 발생 시, 하드웨어에 적용되어 **TOMO 채널 1이 enable 되도록** 하기 위해 **ENDIS\_CTRL1 영역에 0x2 write**

### TOMO\_TGCO\_ENDIS\_CTRL 레지스터 @ 0xF0108070

| GTM_TOMi_TGCO_ENDIS_CTRL (i=0-2)                |                 |                 |                 |                 |                 |                 |                 |   |   |   |   |   |   |   |   |
|-------------------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|---|---|---|---|---|---|---|---|
| TOMi TGC0 Enable/Disable Control Register       |                 |                 |                 |                 |                 |                 |                 |   |   |   |   |   |   |   |   |
| (08070 <sub>H</sub> +i*800 <sub>H</sub> )       |                 |                 |                 |                 |                 |                 |                 |   |   |   |   |   |   |   |   |
| Reset Value: 00000000 <sub>H</sub>              |                 |                 |                 |                 |                 |                 |                 |   |   |   |   |   |   |   |   |
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                 |                 |                 |                 |                 |                 |                 |   |   |   |   |   |   |   |   |
| Reserved                                        |                 |                 |                 |                 |                 |                 |                 |   |   |   |   |   |   |   |   |
| 15                                              | 14              | 13              | 12              | 11              | 10              | 9               | 8               | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ENDIS_CT<br>RL7                                 | ENDIS_CT<br>RL6 | ENDIS_CT<br>RL5 | ENDIS_CT<br>RL4 | ENDIS_CT<br>RL3 | ENDIS_CT<br>RL2 | ENDIS_CT<br>RL1 | ENDIS_CT<br>RL0 |   |   |   |   |   |   |   |   |
| rw                                              | rw              | rw              | rw              | rw              | rw              | rw              | rw              |   |   |   |   |   |   |   |   |

|                 |       |    |                                                                                             |
|-----------------|-------|----|---------------------------------------------------------------------------------------------|
| ENDIS_CT<br>RL1 | [3:2] | rw | (A)TOM channel 1 enable/disable update value<br>See bits 1:0                                |
|                 |       |    | 00 <sub>B</sub> don't care, bits 1:0 of register ENDIS_ 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                                      |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2940

# Lab11: GTM 레지스터 설정 – TOMO\_TGCO\_ENDIS\_CTRL

## :TOM에서 사용할 채널에 대한 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~0xF << FXCLK_SEL_BIT_LSB_IDX;           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                   // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGCO_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;        // TOM channel 1 update enable
99
100    GTM_TOM0_TGCO_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;      // enable channel 1 on update trigger 2
101
102    GTM_TOM0_TGCO_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;       // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                      // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;               // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;                    // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);             // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                     // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                      // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                     // TOUT103 --> TOM0 channel 1
114
115 } 116
116
117 #define ENDIS_CTRL1_BIT_LSB_IDX 2
```

# GTM 레지스터 설정 – TOMO\_TGCO\_OUTEN\_CTRL

1. GTM 레지스터 영역의 주소 찾기
  - 시작 주소 (Base address) = **0xF0100000**
2. 사용할 레지스터의 주소 찾기 (TOM0 이므로 i = 0)
  - **TOMO\_TGCO\_OUTEN\_CTRL** 의 Offset Address =  $0x8078 + (i * 0x800) = 0x8078$
  - TOMO\_TGCO\_OUTEN\_CTRL 레지스터 주소 =  $0xF0100000 + 0x8078 = \textcolor{red}{0xF0108078}$



# GTM 레지스터 설정 – TOMO\_TGCO\_OUTEN\_CTRL

## :TOM의 출력이 trigger 이벤트에 반응하도록 설정

### 3. 레지스터 write 값 결정

- TOMO\_TGCO\_GLB\_CTRL 레지스터에서 Update Trigger 신호 발생 시, 하드웨어에 적용되어 **TOM0** 채널 1의 출력이 **enable** 되도록 하기 위해 **OUTEN\_CTRL1** 영역에 **0x2 write**

### TOMO\_TGCO\_OUTEN\_CTRL 레지스터 @ 0xF0108078

| GTM_TOMi_TGCO_OUTEN_CTRL (i=0-2)                |    |              |    |              |    |              |    |              |    |              |    |              |    |              |    |
|-------------------------------------------------|----|--------------|----|--------------|----|--------------|----|--------------|----|--------------|----|--------------|----|--------------|----|
| TOMi TGC0 Output Enable Control Register        |    |              |    |              |    |              |    |              |    |              |    |              |    |              |    |
| (08078 <sub>H</sub> +i*800 <sub>H</sub> )       |    |              |    |              |    |              |    |              |    |              |    |              |    |              |    |
| Reset Value: 00000000 <sub>H</sub>              |    |              |    |              |    |              |    |              |    |              |    |              |    |              |    |
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |              |    |              |    |              |    |              |    |              |    |              |    |              |    |
| I I I I I I I I I I I I I I I I                 |    |              |    |              |    |              |    |              |    |              |    |              |    |              |    |
| Reserved                                        |    |              |    |              |    |              |    |              |    |              |    |              |    |              |    |
| 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           |    |              |    |              |    |              |    |              |    |              |    |              |    |              |    |
| OUTEN_C TRL7                                    |    | OUTEN_C TRL6 |    | OUTEN_C TRL5 |    | OUTEN_C TRL4 |    | OUTEN_C TRL3 |    | OUTEN_C TRL2 |    | OUTEN_C TRL1 |    | OUTEN_C TRL0 |    |
| IW                                              | IW | IW           | IW | IW           | IW | IW           | IW | IW           | IW | IW           | IW | IW           | IW | IW           | IW |

| Field        | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OUTEN_C TRL0 | [1:0] | rw   | <p><b>Output (A)TOM_OUT(0) enable/disable update value</b></p> <p>Write of following double bit values is possible:</p> <ul style="list-style-type: none"> <li>00<sub>B</sub> don't care, bits 1:0 of register OUTEN_STAT will not be changed on an update trigger</li> <li>01<sub>B</sub> disable channel output on an update trigger</li> <li><b>10<sub>B</sub></b> enable channel output on an update trigger</li> <li>11<sub>B</sub> don't change bits 1:0 of this register</li> </ul> <p>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.</p> |
| OUTEN_C TRL1 | [3:2] | rw   | <p><b>Output (A)TOM_OUT(1)enable/disable update value</b></p> <p>See bits 1:0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2945

# Lab12: GTM 레지스터 설정 – TOMO\_TGCO\_OUTEN\_CTRL

## :TOM의 출력이 trigger 이벤트에 반응하도록 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                      // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGCO_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;           // TOM channel 1 update enable
99
100    GTM_TOM0_TGCO_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;          // enable channel 1 on update trigger
101
102    GTM_TOM0_TGCO_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX; // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                          // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                  // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;                        // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);                 // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                         // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                         // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                         // TOUT103 --> TOM0 channel 1
114    // 103 = 16 * 6 + 7
115 }
116 }
```

101 #define OUTEN\_CTRL1\_BIT\_LSB\_IDX 2

# PWM 신호 생성 flow

## :PWM 생성과정의 counter와 duty cycle 관계



- TOM에서 이루어지는 PWM 동작 개요
- TOM Channel은 PWM 신호를 생성하기 위해 3가지 값 사용
  - CNO : TOM clock 주기마다 1씩 증가하는 counter 값
  - CM0 : PWM 신호의 주기를 결정하는 값
  - CM1 : PWM 신호의 Duty Cycle 을 결정하는 값
- CNO 이 clock 주기마다 증가하다가  
→ **CM1 (PWM Duty Cycle 길이)**에 도달하면 출력 값 반전  
→ **CM0 (PWM 1주기 길이)**에 도달하면 0으로 초기화



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

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2930

# GTM 사용을 위한 레지스터 설정

## :원하는 PWM 신호 생성 위한 TOM 설정

- 본 실습에서 사용하는 **TOM0**의 **채널 1**에 대한  
레지스터 설정 필요
  - TOM0에 입력될 FXCLK 주파수 선택
  - PWM 신호의 주기 및 Duty Cycle 결정을 위한 값
  - Duty Cycle 동안 출력될 신호의 HIGH 또는 LOW 선택
- GTM 레지스터 항목에서
  - TOM0\_CH1\_CTRL** 레지스터 설정 필요
  - TOM0\_CH1\_SRO** 레지스터 설정 필요
  - TOM0\_CH1\_SR1** 레지스터 설정 필요

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf  
p.2930



# GTM 레지스터 설정 – TOMO\_CH1\_CTRL

1. GTM 레지스터 영역의 주소 찾기
  - 시작 주소 (Base address) = **0xF0100000**
2. 사용할 레지스터의 주소 찾기 (채널 1 이므로 x = 1)
  - **TOMO\_CH1\_CTRL** 의 Offset Address =  $0x8000 + (x * 0x40) = 0x8040$
  - **TOMO\_CH1\_CTRL** 레지스터 주소 =  $0xF0100000 + 0x8040 = 0xF0108040$

**TOMO\_CH1\_CTRL** 레지스터 @ 0xF0108040



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2953

# GTM 레지스터 설정 – TOMO\_CH1\_CTRL

## :PWM 신호 중 duty cycle을 어떤 값으로 출력할 지 설정

### 3. 레지스터 write 값 결정

- TOM0 채널1의 동작을 설정
- PWM 신호의 Duty Cycle 영역에서 신호의 값을 HIGH로 출력하기 위해 **SL** 영역에 **0x1** write

**TOMO\_CH1\_CTRL** 레지스터 @ 0xF0108040



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

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2953

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2930



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

# Lab13: GTM 레지스터 설정 – TOMO\_CH1\_CTRL

## :PWM 신호 중 duty cycle을 어떤 값으로 출력할지 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &=~(0xF << FXCLK_SEL_BIT_LSB_IDX);           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                      // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;           // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;          // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;          // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                          // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SEL_BIT_LSB_IDX;                  // clock source -> CMU_FXCLK[1] -> 500 kHz
106
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << OSM_BIT_LSB_IDX);                      // continuous mode enable
108    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);                  // TRIG[x] = TRIG[x-1]
109
110    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                         // PWM freq. = 6250 kHz / 12500 = 500 Hz
111
112    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                         // duty cycle = 1250 / 12500 = 10 % (temporary)
113
114    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                         // TOUT103 --> TOM0 channel 1
115
116 }
```

# GTM 레지스터 설정 – TOMO\_CH1\_CTRL

## :FXU에서 생성하고 TOM에서 사용할 clock 주파수 설정

### 3. 레지스터 write 값 결정

- TOM0 채널1의 동작을 설정
- TOM0에서 사용할 FXCLK clock 신호의 주파수를 결정하기 위해 **CLK\_SRC\_SR** 영역에 **0x0 write**
- 현재 GTM에서 사용하는 system clock 주파수는 100 MHz → **FXCLK = 6250 kHz**

[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf p.2953](#)

| GTM_TOM0_CHx_CTRL (x=0-14)<br>TOM0 Channel x Control Register |            |       |           |          |           |          |          |            |          |    |    |    |    |    |    | Reset Value: 00000800 <sub>H</sub> |  |  |  |
|---------------------------------------------------------------|------------|-------|-----------|----------|-----------|----------|----------|------------|----------|----|----|----|----|----|----|------------------------------------|--|--|--|
| (08000 <sub>H</sub> +x*0040 <sub>H</sub> )                    |            |       |           |          |           |          |          |            |          |    |    |    |    |    |    |                                    |  |  |  |
| 31                                                            | 30         | 29    | 28        | 27       | 26        | 25       | 24       | 23         | 22       | 21 | 20 | 19 | 18 | 17 | 16 |                                    |  |  |  |
| Reserved                                                      | GCM        | SPE M | Rese rved | OSM      | Rese rved | TRIG OUT | Reserved | RST _CC U0 | Reserved |    |    |    |    |    |    |                                    |  |  |  |
| I                                                             | RW         | RW    | I         | RW       | I         | RW       | I        | RW         | I        | RW | I  | RW | I  | RW | I  |                                    |  |  |  |
| 15                                                            | 14         | 13    | 12        | 11       | 10        | 9        | 8        | 7          | 6        | 5  | 4  | 3  | 2  | 1  | 0  | Reserved                           |  |  |  |
| Rese rved                                                     | CLK_SRC_SR |       | SL        | Reserved |           |          |          |            |          |    |    |    |    |    |    |                                    |  |  |  |
| I                                                             | RW         | RW    |           | I        |           |          |          |            |          |    |    |    |    |    |    |                                    |  |  |  |

FXU로 입력되는  
system clock을  
 $2^4 (= 16)$ 으로  
나눠서 FXCLK로  
사용  
→ 100 MHz / 16  
= 6250 kHz

|                                                                                                                                                                                                             |                                                                     |    |                                                                                                                                                                                                                                                                                                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CLK_SRC_SR</b>                                                                                                                                                                                           | [14:12]                                                             | rw | Clock source select for channel<br>The register CLK_SRC is updated with the value of CLK_SRC_SR together with the update of register CM0 and CM1.<br>The input of the FX clock divider depends on the value of FXCLK_SEL (see CMU).<br>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>  | →  | 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>  | →  | 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> | →  | 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> | →  | 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                     | →  | 101 <sub>B</sub> no CMU_FXCLK selected, clock of channel stopped                                                                                                                                                                                                                                          |
| 110 <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                     | →  | 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. |                                                                     |    |                                                                                                                                                                                                                                                                                                           |

TOMO\_CH1\_CTRL 레지스터  
@ 0xF0108040

# Lab14: GTM 레지스터 설정 – TOMO\_CH1\_CTRL :FXU에서 생성하고 TOM에서 사용할 clock 주파수 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~0xF << FXCLK_SEL_BIT_LSB_IDX;           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                   // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;        // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;      // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;       // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SI_BTT_LSB_IDX;                      // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;               // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSR_BIT_LSB_IDX;                    // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);             // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                     // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                      // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                     // TOUT103 --> TOM0 channel 1
114
115 }
116 }
```

102 #define CLK\_SRC\_SR\_BIT\_LSB\_IDX 12

# GTM 레지스터 설정 – TOMO\_CH1\_CTRL

## :연속적으로 PWM 신호가 생성되는 Continuous 모드

### 3. 레지스터 write 값 결정

- TOMO 채널1에서 생성되는 PWM 신호를 continuous 모드로 사용하기 위해 OSM 영역에 0x0 write

PWM 주기가 연속으로 생성되는 모드



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

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2953

|            |            |       |            |     |            |          |          |           |          |    |    |    |    |    |          |
|------------|------------|-------|------------|-----|------------|----------|----------|-----------|----------|----|----|----|----|----|----------|
| 31         | 30         | 29    | 28         | 27  | 26         | 25       | 24       | 23        | 22       | 21 | 20 | 19 | 18 | 17 | 16       |
| Reserved   | GCM        | SPE M | Reser rved | OSM | Reser rved | TRIG OUT | Reserved | RST CC U0 | Reserved |    |    |    |    |    |          |
| r          | rw         | rw    | r          | rw  | r          | rw       | r        | rw        | r        |    |    |    |    |    |          |
| 15         | 14         | 13    | 12         | 11  | 10         | 9        | 8        | 7         | 6        | 5  | 4  | 3  | 2  | 1  | 0        |
| Reser rved | CLK_SRC_SR | SL    |            |     |            |          |          |           |          |    |    |    |    |    | Reserved |
| r          | rw         | rw    |            |     |            |          |          |           |          |    |    |    |    |    |          |

TOMO\_CH1\_CTRL 레지스터 @ 0xF0108040

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2930

|     |    |    |                                                                                                                                                                                                                                                                                 |
|-----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSM | 26 | rw | <b>One-shot mode</b><br>In this mode the counter CN0 counts for only one period<br>The length of period is defined by CM0 A write access to<br>the register CN0 triggers the start of counting<br>0 <sub>B</sub> One-shot mode disabled<br>1 <sub>B</sub> One-shot mode enabled |
|-----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

One-shot 모드 disable  
= Continuous 모드

# Lab15: GTM 레지스터 설정 – TOMO\_CH1\_CTRL

## :연속적으로 PWM 신호가 생성되는 Continuous 모드

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~0xF << FXCLK_SEL_BIT_LSB_IDX;           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                   // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;        // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;      // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;       // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                      // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;               // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << OSM_BIT_LSB_IDX);                  // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U |= (0x3 << TRIGOUT_BIT_LSB_IDX);                // TOUT[ ] --> TRIG[ ]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                     // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                      // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                    // TOUT103 --> TOM0 channel 1
114
115 } // 103 #define OSM_BIT_LSB_IDX
116
```

26

# GTM 레지스터 update 하는 Trigger 신호 생성

## :PWM의 1주기에서 생성하는 Update Trigger 신호

- 앞으로 설정할 GTM 레지스터 (SR0, SR1 등...) 들이 실제 하드웨어에 적용될 수 있도록 하는 **Update Trigger** 신호를
- 1) SW에서 생성할 수 있음
- 2) PWM의 1주기에 도달했을 때 생성할 수 있음

[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf p.2923](#)



### 25.11.2.2 TGC Subunit

Each of the first three individual mechanisms (enable/disable of the channel, output enable and force update) can be driven by three different trigger sources.

The three trigger sources are:

- the host CPU (bit HOST\_TRIG of register TOMi\_TGKy\_GLB\_CTRL)
- the TBU time stamp (signal TBU\_TS0..TBU\_TS1, TBU\_TS2)
- the internal trigger signal TRIG (bunch of trigger signals TRIG\_[x])

Note: The trigger signal is only active for one configured CMU clock period.

[Infineon-TC27x\\_D-step-UM-v02\\_02-EN.pdf p.2919](#)

# GTM 레지스터 update 하는 Trigger 신호

## :Continuous 모드에서 PWM 주기, duty cycle 적용

- PWM의 1주기에 도달할 때마다 update trigger 신호 발생  
= CNO 카운터 값이 CM0에 도달하는 시점



최초 SW에서 발생한  
Update Trigger에 의해  
시작

PWM 1주기 도달  
→ SR0, SR1 레지스터 (shadow)에  
저장된 값을 각각 CM0, CM1로 copy

새로 업데이트된  
CM0, CM1 값으로  
PWM 출력



Figure 25-37 synchronous update of duty cycle

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2928

# GTM 레지스터 설정 – TOMO\_CH1\_CTRL

## :PWM 신호에서 발생하는 trigger 신호 설정

### 3. 레지스터 write 값 결정

- PWM 신호의 1주기 도달 (CNO = CMO) 시 발생하는 trigger (= TRIG) 신호를 Next trigger 신호로 사용하기 위해 TRIGOUT 영역에 0x0 write

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2923



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2953

|           |            |       |           |     |           |          |          |           |          |    |    |    |    |    |    |
|-----------|------------|-------|-----------|-----|-----------|----------|----------|-----------|----------|----|----|----|----|----|----|
| 31        | 30         | 29    | 28        | 27  | 26        | 25       | 24       | 23        | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved  | GCM        | SPE M | Rese rved | OSM | Rese rved | TRIG OUT | Reserved | RST CC U0 | Reserved |    |    |    |    |    |    |
|           | r          | rw    | rw        | r   | rw        | r        | rw       | r         |          |    |    |    |    |    |    |
| 15        | 14         | 13    | 12        | 11  | 10        | 9        | 8        | 7         | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
| Rese rved | CLK_SRC_SR | SL    |           |     |           |          |          |           |          |    |    |    |    |    |    |
|           | r          | rw    | rw        |     |           |          |          |           |          |    |    |    |    |    |    |

TOMO\_CH1\_CTRL 레지스터 @ 0xF0108040

|         |    |    |                                                                        |
|---------|----|----|------------------------------------------------------------------------|
| TRIGOUT | 24 | rw | Trigger output selection (output signal TRIG_[x]) of module TOMO_CH[x] |
|         |    |    | 0 <sub>B</sub> TRIG_[x] is TRIG_[x-1]                                  |
|         |    |    | 1 <sub>B</sub> TRIG_[x] is TRIG_CCU0                                   |

TRIG 신호 선택

# Lab16: GTM 레지스터 설정 – TOMO\_CH1\_CTRL

## :PWM 신호에서 발생하는 trigger 신호 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~0xF << FXCLK_SEL_BIT_LSB_IDX;           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                   // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;        // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;      // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;       // enable channel 1 output on update trigger
103
104    #define TRIGOUT BIT LSB IDX
105
106    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                      // high signal level for duty cycle
107    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                // clock source --> CMU_FXCLK(1) = 6250 kHz
108    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << OSM_BIT_LSB_IDX);                  // continuous mode enable
109    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);               // TRIG[x] = TRIG[x-1]
110
111    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                       // PWM freq. = 6250 kHz / 12500 = 500 Hz
112    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                         // duty cycle = 1250 / 12500 = 10 % (temporary)
113
114    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                      // TOUT103 --> TOM0 channel 1
115    // 103 = 16 * 6 + 7
116 }
```

# GTM 레지스터 설정 – TOMO\_CH1\_SR0

1. GTM 레지스터 영역의 주소 찾기
  - 시작 주소 (Base address) = **0xF0100000**
2. 사용할 레지스터의 주소 찾기 (채널 1 이므로 x = 1)
  - **TOMO\_CH1\_SR0** 의 Offset Address =  $0x8004 + (x * 0x40) = 0x8044$
  - TOMO\_CH1\_SR0 레지스터 주소 =  $0xF0100000 + 0x8044 = \textcolor{red}{0xF0108044}$

**TOMO\_CH1\_SR0 레지스터 @ 0xF0108044**



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2962

# GTM 레지스터 설정 – TOMO\_CH1\_SRO

## :PWM 신호의 주기 설정

### 3. 레지스터 write 값 결정

- TOM0 채널1의 동작을 설정
- 1초 후 CN0= 6250k-1, 1ms → CN0=6250-1, 2ms 후 → CN0=6250\*2-1 값이 됨
- PWM 신호의 주기를 2ms로 설정하기 위해 **SRO 영역에 10진수 (12500 – 1) write**
- SRO 레지스터에 설정할 CM0 값을 저장하면 Trigger로 update 시 CM0에 반영됨

### TOMO\_CH1\_SRO 레지스터@ 0xF0108044



| Field    | Bits    | Type | Description                                                          |
|----------|---------|------|----------------------------------------------------------------------|
| SR0      | [15:0]  | rw   | TOM channel x shadow register SR0 for update of compare register CM0 |
| Reserved | [31:16] | r    | Reserved<br>Read as zero, should be written as zero                  |

$$\begin{aligned} \text{PWM Period} &= \frac{\text{CM0} + 1}{\text{Freq. of CMU_FXCLK1}} \\ &= \frac{12500}{6250 \text{ kHz}} = 2\text{ms} \end{aligned}$$

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2930



CN0 값이 0부터 증가하기 시작하여 CM0 값에 만나기 까지의 시간이 PWM 신호의 1주기

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2962

# Lab17: GTM 레지스터 설정 – TOMO\_CH1\_SR0 :PWM 신호의 주기 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~0xF << FXCLK_SEL_BIT_LSB_IDX;           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                   // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;        // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;      // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;       // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                      // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;                     // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);             // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                     // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                      // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                    // TOUT103 --> TOM0 channel 1
114    // 103 = 16 * 6 + 7
115 }
116 }
```

# GTM 레지스터 설정 – TOMO\_CH1\_SR1

1. GTM 레지스터 영역의 주소 찾기
  - 시작 주소 (Base address) = **0xF0100000**
2. 사용할 레지스터의 주소 찾기 (채널 1 이므로 x = 1)
  - **TOMO\_CH1\_SR1** 의 Offset Address =  $0x8008 + (x * 0x40) = 0x8048$
  - TOMO\_CH1\_SR1 레지스터 주소 =  $0xF0100000 + 0x8048 = \textcolor{red}{0xF0108048}$

**TOMO\_CH1\_SR1 레지스터@ 0xF0108048**



Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2964

# GTM 레지스터 설정 – TOMO\_CH1\_SR1

## :PWM 신호의 duty cycle % 설정

### 3. 레지스터 write 값 결정

- TOM0 채널1의 동작을 설정
- PWM 신호의 Duty Cycle을 설정하기 위해 **SR1** 영역에 **write**
- SR1 레지스터에 설정할 CM1 값을 저장하면 Trigger로 update 시 CM1에 반영됨

$$PWM\ Duty\ Cycle = \frac{CM1 + 1}{CM0 + 1} \times 100 [\%]$$

### TOMO\_CH1\_SR1 레지스터@ 0xF0108048



| Field    | Bits    | Type | Description                                                          |
|----------|---------|------|----------------------------------------------------------------------|
| SR1      | [15:0]  | rw   | TOM channel x shadow register SR1 for update of compare register CM1 |
| Reserved | [31:16] | r    | Reserved<br>Read as zero, should be written as zero                  |

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2964

Infineon-TC27x\_D-step-UM-v02\_02-EN.pdf p.2930



CN0 값이 0부터 증가하여 CM1 값에  
만나기 까지의 시간이, PWM 신호의 1주기 시간 중  
차지하는 비율이 Duty Cycle (%)

# Lab18: GTM 레지스터 설정 – TOMO\_CH1\_SR1

## :PWM 신호의 duty cycle % 설정

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);    // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);    // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);    // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~0xF << FXCLK_SEL_BIT_LSB_IDX;           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                   // enable all CMU_FXCLK
96
97     // GTM TOM0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;        // TOM channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;      // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;       // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                      // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;               // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~0x1 << OSM_BIT_LSB_IDX;                    // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);             // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                     // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                     // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                  // TOUT103 --> TOM0 channel 1
114    // 103 = 16 * 6 + 7
115 }
116 }
```

# SW 프로그래밍

## :GTM 레지스터의 각 영역(필드) LSB 비트 시작 위치 define 정의

- 레지스터에 값을 write할 때 shift되는 offset을 쉽게 사용하기 위한 define 작성

```
26 ****  
27 #include "Ifx_Types.h"  
28 #include "IfxCpu.h"  
29 #include "IfxScuWdt.h"  
30  
31 #include "IfxCcu6_reg.h"  
32 #include "IfxVadc_reg.h"  
33 #include "IfxGtm_reg.h"  
34
```

→ 헤더 파일 참조 추가

```
89 // GTM registers  
90 #define DISS_BIT_LSB_IDX 1  
91 #define DISR_BIT_LSB_IDX 0  
92 #define SEL7_BIT_LSB_IDX 14  
93 #define EN_FXCLK_BIT_LSB_IDX 22  
94 #define FXCLK_SEL_BIT_LSB_IDX 0  
95  
96 // GTM - TOM0 registers  
97 #define UPEN_CTRL1_BIT_LSB_IDX 18  
98 #define HOST_TRIG_BIT_LSB_IDX 0  
99 #define ENDIS_CTRL1_BIT_LSB_IDX 2  
100 #define OUTEN_CTRL1_BIT_LSB_IDX 2  
101 #define CLK_SRC_SR_BIT_LSB_IDX 12  
102 #define OSM_BIT_LSB_IDX 26  
103 #define TRIGOUT_BIT_LSB_IDX 24  
104 #define SL_BIT_LSB_IDX 11  
105  
106
```



GTM 레지스터 bit shift offset

# SW 프로그래밍

- GTM 모듈 사용을 위한 초기화 함수 *initGTM()*

```
70 void initGTM(void)
71 {
72     // Password Access to unlock SCU_WDTSCON0
73     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
74     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);      // wait until unlocked
75
76     // Modify Access to clear ENDINIT
77     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
78     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);      // wait until locked
79
80     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX);      // enable GTM
81
82     // Password Access to unlock SCU_WDTSCON0
83     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
84     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0);      // wait until unlocked
85
86     // Modify Access to set ENDINIT
87     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
88     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
89
90     while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled
91
92
93     // GTM clock configuration
94     GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);           // input clock of CMU_FXCLK --> CMU_GCLK_EN
95     GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                      // enable all CMU_FXCLK
96
97     // GTM T0M0 PWM configuration
98     GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;            // T0M channel 1 update enable
99
100    GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;          // enable channel 1 on update trigger
101
102    GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;          // enable channel 1 output on update trigger
103
104    GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                          // high signal level for duty cycle
105    GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                  // clock source --> CMU_FXCLK(1) = 6250 kHz
106    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << OSM_BIT_LSB_IDX);                     // continuous mode enable
107    GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);                 // TRIG[x] = TRIG[x-1]
108
109    GTM_TOM0_CH1_SR0.U = 12500 - 1;                                         // PWM freq. = 6250 kHz / 12500 = 500 Hz
110
111    GTM_TOM0_CH1_SR1.U = 1250 - 1;                                         // duty cycle = 1250 / 12500 = 10 % (temporary)
112
113    GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                         // TOUT103 --> T0M0 channel 1
114
115 }
116 }
```

# SW 프로그래밍

:GTM 모듈 사용 설정 전, 보호 레지스터 잠금 해제 필요

:GTM 모듈 사용 설정 후, 보호 레지스터 잠금 재설정 필요

- GTM 모듈 사용을 위한 초기화 함수 *initGTM()*

```
370 void initGTM(void)
371 {
372     // Password Access to unlock SCU_WDTSCON0
373     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
374     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0); // wait until unlocked
375
376     // Modify Access to clear ENDINIT
377     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) & ~(1 << ENDINIT_BIT_LSB_IDX);
378     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0); // wait until locked
379
380     GTM_CLC.U &= ~(1 << DISR_BIT_LSB_IDX); // enable GTM
381
382     // Password Access to unlock SCU_WDTSCON0
383     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) & ~(1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
384     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) != 0); // wait until unlocked
385
386     // Modify Access to set ENDINIT
387     SCU_WDTCPU0_CON0.U = ((SCU_WDTCPU0_CON0.U ^ 0xFC) | (1 << LCK_BIT_LSB_IDX)) | (1 << ENDINIT_BIT_LSB_IDX);
388     while((SCU_WDTCPU0_CON0.U & (1 << LCK_BIT_LSB_IDX)) == 0);
```

PW[7:2] 반전시켜  
레지스터 read

LCK bit clear ENDINIT set

LCK bit "0" 될 때까지 대기

LCK bit "1" 될 때까지 대기

ENDINIT set

} Lock 상태를 해제하기 위한  
**Password Access**

} CPUO ENDINIT clear 위한  
**Modify Access**

} ENDINIT clear Lock 상태를 해제하기 위한  
**Password Access**

} CPUO ENDINIT set 위한  
**Modify Access**

# SW 프로그래밍

## :GTM 모듈 설정

- GTM 모듈 사용을 위한 초기화 함수 *initGTM()*

```
while((GTM_CLC.U & (1 << DISS_BIT_LSB_IDX)) != 0); // wait until GTM module enabled

// GTM clock configuration
GTM_CMU_FXCLK_CTRL.U &= ~(0xF << FXCLK_SEL_BIT_LSB_IDX);                                // input clock of CMU_FXCLK --> CMU_GCLK_EN
GTM_CMU_CLK_EN.U |= 0x2 << EN_FXCLK_BIT_LSB_IDX;                                         // enable all CMU_FXCLK

// GTM TOM0 PWM configuration
GTM_TOM0_TGC0_GLB_CTRL.U |= 0x2 << UPEN_CTRL1_BIT_LSB_IDX;                            // TOM channel 1 update enable
GTM_TOM0_TGC0_ENDIS_CTRL.U |= 0x2 << ENDIS_CTRL1_BIT_LSB_IDX;                          // enable channel 1 on update trigger
GTM_TOM0_TGC0_OUTEN_CTRL.U |= 0x2 << OUTEN_CTRL1_BIT_LSB_IDX;                           // enable channel 1 output on update trigger

GTM_TOM0_CH1_CTRL.U |= 0x1 << SL_BIT_LSB_IDX;                                         // high signal level for duty cycle
GTM_TOM0_CH1_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX;                                // clock source --> CMU_FXCLK(1) = 6250 kHz
GTM_TOM0_CH1_CTRL.U &= ~(0x1 << OSM_BIT_LSB_IDX);                                 // continuous mode enable
GTM_TOM0_CH1_CTRL.U &= ~(0x1 << TRIGOUT_BIT_LSB_IDX);                             // TRIG[x] = TRIG[x-1]

GTM_TOM0_CH1_SR0.U = 12500 - 1;                                                 // PWM freq. = 6250 kHz / 12500 = 500 Hz
GTM_TOM0_CH1_SR1.U = 1250 - 1;                                              // duty cycle = 1250 / 12500 = 10 % (temporary)

GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);                                // TOUT103 --> TOM0 channel 1
                                                                           // 103 = 16 * 6 + 7
```

### GTM 모듈 설정

- GTM 모듈 enable
- TOM에서 사용하는 FXCLK 주파수 설정
- TOM을 제어하는 TGC에 대한 설정
- TOM0의 채널1에 대한 설정
- PWM 신호의 주기, Duty Cycle 설정
- PWM 신호가 출력될 핀 설정

# SW 프로그래밍

## :VADC 모듈에서 변환된 디지털 값 사용 PWM Duty Cycle 제어

- main 함수 작성

가변 저항에서 읽은  
ADC 값의 범위에 따라  
RGB LED on/off 결정

```
14b
147 //initERU();
148 initCCU60();
149 initLED();
150 initRGBLED();
151 initVADC();
152 initGTM();
153 //initButton();
154
155 GTM_TOM0_TGCO_GLB_CTRL.U |= 0x1 << HOST_TRIG_BIT_LSB_IDX; // trigger update request signal
156 while(1)
157 {
158     VADC_startConversion();
159     unsigned int adcResult = VADC_readResult();
160     for(unsigned int i = 0; i < 100; i++)
161     {
162         if( adcResult >= 3096 )
163         {
164             P02_OUT.U |= 0x1 << P7_BIT_LSB_IDX;
165             P10_OUT.U &= ~(0x1 << P5_BIT_LSB_IDX);
166             P10_OUT.U &= ~(0x1 << P3_BIT_LSB_IDX);
167
168             GTM_TOM0_CH1_SR1.U = 0;
169         }
170         else if( adcResult >= 2048 )
171         {
172             P02_OUT.U &= ~(0x1 << P7_BIT_LSB_IDX);
173             P10_OUT.U |= 0x1 << P5_BIT_LSB_IDX;
174             P10_OUT.U &= ~(0x1 << P3_BIT_LSB_IDX);
175
176             GTM_TOM0_CH1_SR1.U = 1000;
177         }
178         else if( adcResult >= 1024 )
179         {
180             P02_OUT.U &= ~(0x1 << P7_BIT_LSB_IDX);
181             P10_OUT.U &= ~(0x1 << P5_BIT_LSB_IDX);
182             P10_OUT.U |= 0x1 << P3_BIT_LSB_IDX;
183
184             GTM_TOM0_CH1_SR1.U = 7000;
185         }
186         else
187         {
188             P02_OUT.U |= 0x1 << P7_BIT_LSB_IDX;
189             P10_OUT.U |= 0x1 << P5_BIT_LSB_IDX;
190             P10_OUT.U |= 0x1 << P3_BIT_LSB_IDX;
191
192             GTM_TOM0_CH1_SR1.U = 12500;
193         }
194     }
195     return (1);
196 }
197
198 }
```

초기화 함수 호출 ←

147  
148  
149  
150  
151  
152  
153  
154  
155

```
//initERU();
initCCU60();
initLED();
initRGBLED();
initVADC();
initGTM();
//initButton();
```

처음 update trigger  
발생

→ 이후에는 continuous  
모드이므로 자동으로  
trigger 발생

가변 저항에서 읽은  
ADC 값의 범위에 따라  
LED RED에 연결된  
PWM 신호 Duty Cycle  
변경

- RGB LED는 지난주 그대로.
- Red LED는 가변저항 전압 범위  
에 따라 계단형 밝기 변화 제어

# Build 및 Debug

- 프로젝트 빌드 (ctrl + b)
- 디버그 수행하여 보드에 실행 파일 flash



# 동작 확인

- 가변 저항을 돌리면 변화하는 ADC 값에 따라 RGB LED 색 뿐만 아니라, PWM 신호 Duty Cycle 변화에 의해 LED RED의 밝기 또한 변하는 모습 확인 가능

P10.2 (TMR 0.5s ISR)



P10.1 (PWM  
Duty Control)



adcValue >= 3096

adcValue >= 2048

adcValue >= 1024

adcValue < 1024

# 보충 Lab: 가변저항값에 따라 연속적인 LED Dimming

```
GTM_TOM0_TGC0_GLB_CTRL.U |= 0x1 << HOST_TRIG_BIT_LSB_IDX;  
unsigned short duty = 0;  
  
while(1)  
{  
    VADC_startConversion();  
    unsigned int adcResult = VADC_readResult();  
  
    duty = 12500 * adcResult / 4096;  
    GTM_TOM0_CH1_SR1.U = duty;  
  
}  
return (1);
```

# 보충 Lab: RGB LED에 대해 Dimming을 시도해보자 (1/3)

```
// set TGC0 to enable GTM TOM0 channel 2, 3, 15
GTM_TOM0_TGC0_GLB_CTRL.B.UPEN_CTRL2 |= 0x2; // TOM0 channel 2 enable
GTM_TOM0_TGC0_GLB_CTRL.B.UPEN_CTRL3 |= 0x2; // TOM0 channel 3 enable
GTM_TOM0_TGC1_GLB_CTRL.B.UPEN_CTRL7 |= 0x2; // TOM0 channel 15 enable

GTM_TOM0_TGC0_ENDIS_CTRL.B.ENDIS_CTRL2 |= 0x2; // enable channel 2 on update trigger
GTM_TOM0_TGC0_ENDIS_CTRL.B.ENDIS_CTRL3 |= 0x2; // enable channel 3 on update trigger
GTM_TOM0_TGC1_ENDIS_CTRL.B.ENDIS_CTRL7 |= 0x2; // enable channel 15 on update trigger

GTM_TOM0_TGC0_OUTEN_CTRL.B.OUTEN_CTRL2 |= 0x2; // enable channel 2 output on update trigger
GTM_TOM0_TGC0_OUTEN_CTRL.B.OUTEN_CTRL3 |= 0x2; // enable channel 3 output on update trigger
GTM_TOM0_TGC1_OUTEN_CTRL.B.OUTEN_CTRL7 |= 0x2; // enable channel 15 output on update trigger
```

# 보충 Lab: RGB LED에 대해 Dimming을 시도해보자 (2/3)

```
// TOM 0_2
GTM_TOM0_CH2_CTRL.U |= 0x1 << SL_BIT_LSB_IDX; // high signal level selection
GTM_TOM0_CH2_CTRL.U &= ~(0x7 << CLK_SRC_SR_BIT_LSB_IDX);
GTM_TOM0_CH2_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX; // clock source selection

GTM_TOM0_CH2_SR0.U = 12500 - 1; // PWM duty cycle selection
//GTM_TOM0_CH2_SR1.U = 12500 - 1; // duty cycle selection

// TOM 0_3
GTM_TOM0_CH3_CTRL.U |= 0x1 << SL_BIT_LSB_IDX; // high signal level selection
GTM_TOM0_CH3_CTRL.U &= ~(0x7 << CLK_SRC_SR_BIT_LSB_IDX);
GTM_TOM0_CH3_CTRL.U |= 0x1 << CLK_SRC_SR_BIT_LSB_IDX; // clock source selection

GTM_TOM0_CH3_SR0.U = 12500 - 1; // PWM duty cycle selection
//GTM_TOM0_CH3_SR1.U = 125 - 1; // duty cycle selection

// TOM 0_15
GTM_TOM0_CH15_CTRL.B.SL |= 0x1; // high signal level selection
GTM_TOM0_CH15_CTRL.B.CLK_SRC_SR |= 0x1; // clock source selection

GTM_TOM0_CH15_SR0.U = 12500 - 1; // PWM duty cycle selection
//GTM_TOM0_CH15_SR1.U = 125 - 1; // duty cycle selection

// TOUT pin selection
GTM_TOUTSEL6.U &= ~(0x3 << SEL7_BIT_LSB_IDX);
GTM_TOUTSEL0.U &= ~(0x3 << SEL7_BIT_LSB_IDX);
GTM_TOUTSEL6.U &= ~(0x3 << SEL11_BIT_LSB_IDX);
GTM_TOUTSEL6.U &= ~(0x3 << SEL9_BIT_LSB_IDX);
```

# 보충 Lab: RGB LED에 대해 Dimming을 시도해보자 (3/3)

```
GTM_TOM0_TGC0_GLB_CTRL.U |= 0x1 << HOST_TRIG_BIT_LSB_IDX;
GTM_TOM0_TGC1_GLB_CTRL.U |= 0x1 << HOST_TRIG_BIT_LSB_IDX;

unsigned short duty = 0;

while(1)
{
    VADC_startConversion();
    unsigned int adcResult = VADC_readResult();

    duty = 12500 * adcResult / 4096;

    GTM_TOM0_CH2_SR1.U = duty;
    GTM_TOM0_CH3_SR1.U = duty;
    GTM_TOM0_CH15_SR1.U = duty;

}
return (1);
```

# 보충 Lab: Buzzer를 Drive해보자 (1/2)

```
void initBuzzer(void)
{
    P02_IOCR0.B.PC3 = 0x11;
}
```

PWM에 인가되는 클럭은  
6250KHz

```
void initGTM(void)
{
    // ...
    // set GTM TOM0 channel 11 - Buzzer
    GTM_TOM0_TGC1_GLB_CTRL.B.UPEN_CTRL3 |= 0x2;           // TOM0 channel 11 enable
    GTM_TOM0_TGC1_ENDIS_CTRL.B.ENDIS_CTRL3 |= 0x2;         // enable channel 11 on update trigger
    GTM_TOM0_TGC1_OUTEN_CTRL.B.OUTEN_CTRL3 |= 0x2;          // enable channel 11 output on update trigger

    // TOM 0_11
    GTM_TOM0_CH11_CTRL.B.SL = 0x1;                          // high signal level for duty cycle
    GTM_TOM0_CH11_CTRL.B.CLK_SRC_SR = 0x1;                  // clock source --> CMU_FXCLK(1) = 6250 kHz
    GTM_TOM0_CH11_SR0.B.SR0 = 12500 - 1;                   // PWM freq. = 6250 kHz / 12500 = 500 Hz
    GTM_TOM0_CH11_SR1.B.SR1 = 6250 - 1;                     // duty cycle = 6250 / 12500 = 50 %

    // TOUT pin selection
    GTM_TOUTSEL0.B.SEL3 = 0x0;                             // TOUT3 --> TOM0 channel 11
}
```

# 보충 Lab: Buzzer를 Drive해보자 (1/2)

```
// from 3 octave C ~ 4 octave C {C, D, E, F, G, A, B, C}  
unsigned int duty[8] = {130, 146, 164, 174, 195, 220, 246, 262};
```

```
while(1)  
{  
    for(unsigned int i = 0; i < 10000000000; i++)  
        GTM_TOM0_CH11_SR0.B.SR0 = 6250000 / duty[0];  
        GTM_TOM0_CH11_SR1.B.SR1 = 3125000 / duty[0];  
  
    for(unsigned int i = 0; i < 10000000000; i++)  
        GTM_TOM0_CH11_SR0.B.SR0 = 6250000 / duty[1];  
        GTM_TOM0_CH11_SR1.B.SR1 = 3125000 / duty[1];  
  
    for(unsigned int i = 0; i < 10000000000; i++)  
        GTM_TOM0_CH11_SR0.B.SR0 = 6250000 / duty[2];  
        GTM_TOM0_CH11_SR1.B.SR1 = 3125000 / duty[2];  
  
    for(unsigned int i = 0; i < 10000000000; i++)  
        GTM_TOM0_CH11_SR0.B.SR0 = 6250000 / duty[3];  
        GTM_TOM0_CH11_SR1.B.SR1 = 3125000 / duty[3];  
  
    for(unsigned int i = 0; i < 10000000000; i++)  
        GTM_TOM0_CH11_SR0.B.SR0 = 6250000 / duty[4];  
        GTM_TOM0_CH11_SR1.B.SR1 = 3125000 / duty[4];  
  
    for(unsigned int i = 0; i < 10000000000; i++)  
        GTM_TOM0_CH11_SR0.B.SR0 = 6250000 / duty[5];  
        GTM_TOM0_CH11_SR1.B.SR1 = 3125000 / duty[5];  
  
    for(unsigned int i = 0; i < 10000000000; i++)  
        GTM_TOM0_CH11_SR0.B.SR0 = 6250000 / duty[6];  
        GTM_TOM0_CH11_SR1.B.SR1 = 3125000 / duty[6];  
  
    for(unsigned int i = 0; i < 10000000000; i++)  
        GTM_TOM0_CH11_SR0.B.SR0 = 6250000 / duty[7];  
        GTM_TOM0_CH11_SR1.B.SR1 = 3125000 / duty[7];  
}
```

6250khz → 초당 카운터값 6250000번 증가  
→ SR0 (period) 6250000 설정시 1초 지나면  
period match됨, 따라서 주기 1Hz PWM 생성됨

따라서 SR0 = 1/130인가시, 카운터 match값이  
1/130로 줄어들므로, 130배 빠른속도로  
match된다 따라서 130Hz PWM만들어진다.

SR1은 50%로 해서 duty 50%로 설정

# 감사합니다. 휴식~~