

# Infineon TC275 ADC (Analog-to-Digital Converter)

Hyeongrae Kim

Architecture and Compiler for Embedded System LAB.

School of Electronics Engineering, KNU, KOREA

2021-05-11



# Hitex ShieldBuddy TC275



# RGB LED Example

- GPIO를 통한 LED Blink
  1. 새로운 예제를 위한 프로젝트를 생성한다.
  2. 원하는 동작을 위해 레지스터와 메모리에 직접 접근해서 값을 써야한다.
  3. LED 사용을 위해 Board Schematic과 Datasheet에서 LED 연결 정보를 파악한다.
  4. LED가 연결된 PORT의 메모리 맵을 분석한다.
  5. 분석 결과를 활용해 임베디드 프로그래밍을 한다.

# RGB LED Example

## 1. RGB LED 연결 정보 파악

- ✓ Easy Module Shield V1 확장 보드의 RGB LED를 사용한다.



# RGB LED Example

## 1. RGB LED 연결 정보 파악

- ✓ RGB LED는 Easy Module Shield V1 확장 보드의 Pin D9/D10/D11과 연결되어 있다.
- ✓ 타겟 보드는 Easy Module Shield V1 확장 보드의 Pin D9/D10/D11을 통해 RGB LED 출력을 보낼 수 있다.

(정상적인 Potentiometer 동작을 위해 VCC 및 GND도 연결해야 한다.)



# RGB LED Example

## 1. RGB LED 연결 정보 파악

- ✓ TC275 보드의 Schematic과 Datasheet를 확인했을 때, Easy Module Shield V1 확장 보드의 Pin D9/D10/D11과 연결되는 IO는 PORT2의 Pin 7과 PORT10의 Pin 5/Pin3다.
- ✓ 해당 Pin의 출력이 High-level 일 때 LED는 켜지고, Low-level 일 때 LED는 꺼진다.



# RGB LED Example

## 2. Data sheet 분석 : IO 설정

- ✓ RGB LED RED를 사용하기 위해 연결된 Pin의 IO 설정이 필요하다.
- ✓ RGB LED RED 제어를 위한 출력 신호를 내보내기 위해 해당 Pin을 **General-purpose output**으로 설정해야 한다.

| Port Pin | I/O | Pin Functionality      | Associated Reg./ I/O Line | Port I/O Control Select. |           |
|----------|-----|------------------------|---------------------------|--------------------------|-----------|
|          |     |                        |                           | Reg./Bit Field           | Value     |
| P02.7    | I   | General-purpose input  | P02_IN.P7                 | P02_IOCR4.<br>PC7        | $0XXXX_B$ |
|          |     | GTM input              | TIN7                      |                          |           |
|          |     | QSPI3 input            | SCLK3A                    |                          |           |
|          |     | PSI5 input             | PSIRX2B                   |                          |           |
|          |     | SENT input             | SENT1C                    |                          |           |
|          |     | CCU60 input            | CC61INC                   |                          |           |
|          |     | CCU60 input            | CCPOS1A                   |                          |           |
|          |     | CCU61 input            | T13HRB                    |                          |           |
|          |     | GPT120 input           | T3EUDA                    |                          |           |
|          |     | DSADC input            | DSCIN3B                   |                          |           |
|          | O   | CIF input              | CIFD7                     |                          |           |
|          |     | DSADC input            | DSITR4E                   |                          |           |
|          |     | General-purpose output | P02_OUT.P7                |                          | $1X000_B$ |
|          |     | GTM output             | TOUT7                     |                          | $1X001_B$ |
|          |     | Reserved               | -                         |                          | $1X010_B$ |
|          |     | QSPI3 output           | SCLK3                     |                          | $1X011_B$ |
|          |     | DSADC output           | DSCOUT3                   |                          | $1X100_B$ |
|          |     | VADC output            | VADCEMUX01                |                          | $1X101_B$ |
|          |     | SENT output            | SPC1                      |                          | $1X110_B$ |
|          |     | CCU60 output           | CC61                      |                          | $1X111_B$ |

# RGB LED Example

## 2. Data sheet 분석 : IO 설정

- ✓ RGB LED GREEN를 사용하기 위해 연결된 Pin의 IO 설정이 필요하다.
- ✓ RGB LED GREEN 제어를 위한 출력 신호를 내보내기 위해 해당 Pin을 **General-purpose output**으로 설정해야 한다.

| Port Pin | I/O | Pin Functionality      | Associated Reg./ I/O Line | Port I/O Control Select.                                                             |           |
|----------|-----|------------------------|---------------------------|--------------------------------------------------------------------------------------|-----------|
|          |     |                        |                           | Reg./Bit Field                                                                       | Value     |
| P10.5    | I   | General-purpose input  | P10_IN.P5                 | P10_IOCR4.<br>PC5                                                                    | $0XXXX_B$ |
|          |     | GTM input              | TIN107                    |                                                                                      |           |
|          |     | SCU input              | HWCFG4                    |                                                                                      |           |
|          |     | MSC0 input             | INJ01                     |                                                                                      |           |
|          | O   | General-purpose output | P10_OUT.P5                | 1X000_B<br>1X001_B<br>1X010_B<br>1X011_B<br>1X100_B<br>1X101_B<br>1X110_B<br>1X111_B | 1X000_B   |
|          |     | GTM output             | TOUT107                   |                                                                                      | 1X001_B   |
|          |     | ASCLIN2 output         | ATX2                      |                                                                                      | 1X010_B   |
|          |     | QSPI3 output           | SLSO38                    |                                                                                      | 1X011_B   |
|          |     | QSPI1 output           | SLSO19                    |                                                                                      | 1X100_B   |
|          |     | GPT120 output          | T6OUT                     |                                                                                      | 1X101_B   |
|          |     | ASCLIN2 output         | ASLSO2                    |                                                                                      | 1X110_B   |
|          |     | Reserved               | -                         |                                                                                      | 1X111_B   |

# RGB LED Example

## 2. Data sheet 분석 : IO 설정

- ✓ RGB LED BLUE를 사용하기 위해 연결된 Pin의 IO 설정이 필요하다.
- ✓ RGB LED BLUE제어를 위한 출력 신호를 내보내기 위해 해당 Pin을 **General-purpose output**으로 설정해야 한다.

| Port Pin | I/O | Pin Functionality      | Associated Reg./ I/O Line | Port I/O Control Select. |           |
|----------|-----|------------------------|---------------------------|--------------------------|-----------|
|          |     |                        |                           | Reg./Bit Field           | Value     |
| P10.3    | I   | General-purpose input  | P10_IN.P3                 | P10_IOCR0.<br>PC3        | $0XXXX_B$ |
|          |     | GTM input              | TIN105                    |                          | $1X000_B$ |
|          |     | QSPI1 input            | MTSR1A                    |                          | $1X001_B$ |
|          |     | SCU input              | REQ3                      |                          | $1X010_B$ |
|          |     | GPT120 input           | T5INB                     |                          | $1X011_B$ |
|          | O   | General-purpose output | P10_OUT.P3                |                          | $1X100_B$ |
|          |     | GTM output             | TOUT105                   |                          | $1X101_B$ |
|          |     | VADC output            | VADCG6BFL3                |                          | $1X110_B$ |
|          |     | QSPI1 output           | MTSR1                     |                          | $1X111_B$ |
|          |     | MSC0 output            | EN00                      |                          |           |

# RGB LED Example

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

- ✓ P02\_IOCR Register는 PORT02의 Input/Output을 설정한다.
- ✓ LED RED 가 PORT02의 Pin 7에 연결되어 있기 때문에 **P02\_IOCR4 Register의 PC7 bits**를 설정한다.

Table 13-3 Registers Address Space

| Module     | Base Address                 | End Address                  | Note           |
|------------|------------------------------|------------------------------|----------------|
| P00        | F003 A000 <sub>H</sub>       | F003 A0FF <sub>H</sub>       | 13 pins        |
| P01        | F003 A100 <sub>H</sub>       | F003 A1FF <sub>H</sub>       | 5 pins         |
| <b>P02</b> | <b>F003 A200<sub>H</sub></b> | <b>F003 A2FF<sub>H</sub></b> | <b>12 pins</b> |
| P10        | F003 B000 <sub>H</sub>       | F003 B0FF <sub>H</sub>       | 9 pins         |
| P11        | F003 B100 <sub>H</sub>       | F003 B1FF <sub>H</sub>       | 16 pins        |

P02\_IOCR4 Register 주소: F003\_A214h (F003A200h + 14h)

P02\_IOCR4 Register 구조:



| Field                       | Bits                                      | Type | Description                                                                                                                                                                |
|-----------------------------|-------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PC4,<br>PC5,<br>PC6,<br>PC7 | [7:3],<br>[15:11],<br>[23:19],<br>[31:27] | rw   | Port Control for Port n Pin 4 to 7<br>This bit field determines the Port n line x functionality (x = 4-7) according to the coding table (see <a href="#">Table 13-5</a> ). |
| 0                           | [2:0],<br>[10:8],<br>[18:16],<br>[26:24]  | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                    |



# RGB LED Example

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

- ✓ P10\_IOCR Register는 PORT10의 Input/Output을 설정한다.
- ✓ LED GREEN이 PORT10의 Pin 5에 연결되어 있기 때문에 **P10\_IOCR4 Register의 PC5 bits**를 설정한다.

Table 13-3 Registers Address Space

| Module     | Base Address                 | End Address                  | Note          |
|------------|------------------------------|------------------------------|---------------|
| P00        | F003 A000 <sub>H</sub>       | F003 A0FF <sub>H</sub>       | 13 pins       |
| P01        | F003 A100 <sub>H</sub>       | F003 A1FF <sub>H</sub>       | 5 pins        |
| P02        | F003 A200 <sub>H</sub>       | F003 A2FF <sub>H</sub>       | 12 pins       |
| <b>P10</b> | <b>F003 B000<sub>H</sub></b> | <b>F003 B0FF<sub>H</sub></b> | <b>9 pins</b> |
| P11        | F003 B100 <sub>H</sub>       | F003 B1FF <sub>H</sub>       | 16 pins       |

P10\_IOCR4 Register 주소: F003\_B014h (F003B000h + 14h)

P10\_IOCR4 Register 구조:



| Field                       | Bits                                      | Type | Description                                                                                                                                                                |
|-----------------------------|-------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PC4,<br>PC5,<br>PC6,<br>PC7 | [7:3],<br>[15:11],<br>[23:19],<br>[31:27] | rw   | Port Control for Port n Pin 4 to 7<br>This bit field determines the Port n line x functionality (x = 4-7) according to the coding table (see <a href="#">Table 13-5</a> ). |
| 0                           | [2:0],<br>[10:8],<br>[18:16],<br>[26:24]  | r    | Reserved<br>Read as 0; should be written with 0.                                                                                                                           |



# RGB LED Example

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

- ✓ P10\_IOCR Register는 PORT10의 Input/Output을 설정한다.
- ✓ LED BLUE가 PORT10의 Pin 3에 연결되어 있기 때문에 **P10\_IOCRO Register**의 **PC3 bits**를 설정한다.

Table 13-3 Registers Address Space

| Module     | Base Address                 | End Address                  | Note          |
|------------|------------------------------|------------------------------|---------------|
| P00        | F003 A000 <sub>H</sub>       | F003 A0FF <sub>H</sub>       | 13 pins       |
| P01        | F003 A100 <sub>H</sub>       | F003 A1FF <sub>H</sub>       | 5 pins        |
| P02        | F003 A200 <sub>H</sub>       | F003 A2FF <sub>H</sub>       | 12 pins       |
| <b>P10</b> | <b>F003 B000<sub>H</sub></b> | <b>F003 B0FF<sub>H</sub></b> | <b>9 pins</b> |
| P11        | F003 B100 <sub>H</sub>       | F003 B1FF <sub>H</sub>       | 16 pins       |

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

P10\_IOCRO Register 구조:



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



# RGB LED Example

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

- ✓ PORT02의 Pin7과 PORT10의 Pin5/Pin3를 General-purpose output (push-pull)으로 설정하기 위해 각 IOCR Register의 **PC7, PC5, PC3 bits**를 **10000b**로 설정한다.

Table 13-5 PCx Coding

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



# RGB LED Example

## 2. Data sheet 분석 : PORT 출력 설정

- ✓ P02\_OMR Register는 PORT02의 출력을 설정한다.
- ✓ PORT02의 Pin 7 출력을 설정하기 위해 **P02\_OMR Register**의 **PCL7 bit**와 **PS7 bit**를 설정한다.
  - ✓ PCL7 bit만 Set 하면 P02.7 출력이 '0 (Low-level)'으로 Clear 된다.
  - ✓ PS7 bit만 Set 하면 P02.7 출력이 '1 (High-level)'로 Set 된다.
  - ✓ PCL7 bit와 PS7 bit를 동시에 Set 하면 P02.7 출력이 Toggle 된다.

P10\_OMR Register 주소: F003\_A204h (F003A200h + 4h)

P10\_OMR Register 구조:

| P0n_OMR (n=0-2)<br>Port On Output Modification Register (F003 A004 <sub>H</sub> + n*100 <sub>H</sub> ) |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          | Reset Value:<br>0000 0000 <sub>H</sub> |
|--------------------------------------------------------------------------------------------------------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------------------------------------|
| 31                                                                                                     | 30        | 29        | 28        | 27        | 26        | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |                                        |
| PCL<br>15                                                                                              | PCL<br>14 | PCL<br>13 | PCL<br>12 | PCL<br>11 | PCL<br>10 | PCL<br>9 | PCL<br>8 | PCL<br>7 | PCL<br>6 | PCL<br>5 | PCL<br>4 | PCL<br>3 | PCL<br>2 | PCL<br>1 | PCL<br>0 |                                        |
| W                                                                                                      | W         | W         | W         | W         | W         | W        | W        | W        | W        | W        | W        | W        | W        | W        | W        |                                        |
| 15                                                                                                     | 14        | 13        | 12        | 11        | 10        | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |                                        |
| PS<br>15                                                                                               | PS<br>14  | PS<br>13  | PS<br>12  | PS<br>11  | PS<br>10  | PS<br>9  | PS<br>8  | PS<br>7  | PS<br>6  | PS<br>5  | PS<br>4  | PS<br>3  | PS<br>2  | PS<br>1  | PS<br>0  |                                        |
| W                                                                                                      | W         | W         | W         | W         | W         | W        | W        | W        | W        | W        | W        | W        | W        | W        | W        |                                        |

Table 13-9 Function of the Bits PCLx and PSx

| PCLx | PSx | Function                      |
|------|-----|-------------------------------|
| 0    | 0   | Bit Pn_OUT.Px is not changed. |
| 0    | 1   | Bit Pn_OUT.Px is set.         |
| 1    | 0   | Bit Pn_OUT.Px is reset.       |
| 1    | 1   | Bit Pn_OUT.Px is toggled.     |

# RGB LED Example

## 2. Data sheet 분석 : PORT 출력 설정

- ✓ P10\_OMR Register는 PORT10의 출력을 설정한다.
- ✓ PORT10의 Pin 5/3 출력을 설정하기 위해 **P10\_OMR Register**의 **PCL5/3 bit**와 **PS5/3 bit**를 설정한다.
  - ✓ PCL5, PCL3 bit만 Set 하면 P10.5, P10.3 출력이 '0 (Low-level)'으로 Clear 된다.
  - ✓ PS5, PS3 bit만 Set 하면 P10.5, P10.3 출력이 '1 (High-level)'로 Set 된다.
  - ✓ PCL5, PCL3 bit와 PS5, PS3 bit를 동시에 Set 하면 P10.5, P10.3 출력이 Toggle 된다.

P10\_OMR Register 주소: F003\_B004h (F003B000h + 4h)

### P10\_OMR Register 구조:

| Pn_OMR (n=10-15)<br>Port n Output Modification Register (F003 A604 <sub>H</sub> + n*100 <sub>H</sub> ) |           |           |           |           |           |          |          |          |          |          |          |          |          |          |          | Reset Value:<br>0000 0000 <sub>H</sub> |
|--------------------------------------------------------------------------------------------------------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------------------------------------|
| 31                                                                                                     | 30        | 29        | 28        | 27        | 26        | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |                                        |
| PCL<br>15                                                                                              | PCL<br>14 | PCL<br>13 | PCL<br>12 | PCL<br>11 | PCL<br>10 | PCL<br>9 | PCL<br>8 | PCL<br>7 | PCL<br>6 | PCL<br>5 | PCL<br>4 | PCL<br>3 | PCL<br>2 | PCL<br>1 | PCL<br>0 |                                        |
| W                                                                                                      | W         | W         | W         | W         | W         | W        | W        | W        | W        | W        | W        | W        | W        | W        | W        |                                        |
| PS<br>15                                                                                               | PS<br>14  | PS<br>13  | PS<br>12  | PS<br>11  | PS<br>10  | PS<br>9  | PS<br>8  | PS<br>7  | PS<br>6  | PS<br>5  | PS<br>4  | PS<br>3  | PS<br>2  | PS<br>1  | PS<br>0  |                                        |
| W                                                                                                      | W         | W         | W         | W         | W         | W        | W        | W        | W        | W        | W        | W        | W        | W        | W        |                                        |

Table 13-9 Function of the Bits PCLx and PSx

| PCLx | PSx | Function                      |
|------|-----|-------------------------------|
| 0    | 0   | Bit Pn_OUT.Px is not changed. |
| 0    | 1   | Bit Pn_OUT.Px is set.         |
| 1    | 0   | Bit Pn_OUT.Px is reset.       |
| 1    | 1   | Bit Pn_OUT.Px is toggled.     |

# RGB LED Example

## 3. 프로그래밍

- 1) RGB LED가 연결된 PORG02 Pin7과 PORT10 Pin 5/3에 대한 IO 설정을 한다.

```
31 #define PORT10_BASE      (0xF003B000)
32 #define PORT10_IOCR0     (*(volatile unsigned int*)(PORT10_BASE + 0x10))
33 #define PORT10_OMR       (*(volatile unsigned int*)(PORT10_BASE + 0x04))
34
35 #define PC1              11
36 #define PC2              19
37
38 #define PCL1             17
39 #define PCL2             18
40 #define PS1              1
41 #define PS2              2
```

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

```
45 /* Initialize LED (RED & BLUE) */
46 void init_LED(void)
47 {
48     /* Reset PC1 & PC2 in IOCR0*/
49     PORT10_IOCR0 &= ~((0x1F) << PC1);
50     PORT10_IOCR0 &= ~((0x1F) << PC2);
51
52     /* Set PC1 & PC2 with push-pull(2b10000) */
53     PORT10_IOCR0 |= ((0x10) << PC1);
54     PORT10_IOCR0 |= ((0x10) << PC2);
55 }
```

POR13 IO 설정 초기화 코드



# ADC Example

- ADC로 읽은 전압 값의 범위에 따른 RGB LED 출력 제어
  1. 새로운 예제를 위한 프로젝트를 생성한다.
  2. 원하는 동작을 위해 레지스터와 메모리에 직접 접근해서 값을 써야한다.
  3. Potentiometer 사용을 위해 Board Schematic과 Datasheet에서 Potentiometer 연결 정보를 파악한다.
  4. ADC 모듈의 동작 원리를 파악하고 메모리 맵을 분석한다.
  5. 분석 결과를 활용해 임베디드 프로그래밍을 한다.



# ADC Example

## 1. Potentiometer 연결 정보 파악

- ✓ 타겟 보드인 ShieldBuddy TC275에는 사용 가능한 Potentiometer가 없기 때문에 **Easy Module Shield V1 확장 보드**의 Potentiometer를 사용한다.



# ADC Example

## 1. Potentiometer 연결 정보 파악

- ✓ Potentiometer는 Easy Module Shield V1 확장 보드의 **Pin A0**과 연결되어 있다.
- ✓ Potentiometer에 따라 Pin A0의 전압 값이 달라진다.
- ✓ 타겟 보드는 Easy Module Shield V1 확장 보드의 Pin A0을 통해 아날로그 전압 값을 입력 받을 수 있다.  
(정상적인 Potentiometer 동작을 위해 VCC 및 GND도 연결해야 한다.)



# ADC Example

## 1. Potentiometer 연결 정보 파악

- ✓ TC275 보드의 Schematic과 Datasheet를 확인했을 때, Easy Module Shield V1 확장 보드의 **Pin A0**와 연결되는 IO는 SAR4의 **Pin 7**이다.



# ADC Example

## 2. Data sheet 분석 : 아날로그 입력 Pin

- ✓ Potentiometer에 의한 아날로그 전압 값을 입력 받기 위해서는 아날로그 입력 Pin이 필요하다.
- ✓ Potentiometer가 연결된 Pin AN0은 아날로그 전압 값을 측정하여 디지털 값으로 변환하는 **VADC** (**Versatile Analog-to-Digital Converter**)의 **Channel 7 of Group 4**과 연결되어 있는 아날로그 입력 Pin이다.
- ✓ 해당 Pin은 아날로그 입력 전용 Pin이기 때문에 추가적인 IO 설정이 필요하지 않다.



# ADC Example

## 2. Data sheet 분석 : VADC 구조 분석 (1)

- ✓ VADC는 여러 개의 **Group**으로 구성되며 각 Group은 **ADC Kernel**로 구성된다.
- ✓ Group은 Request Control에 의한 Conversion Request에 따라 동작을 수행한다.
- ✓ Conversion Request는 여러 Analog Input Channels 중 하나를 선택하여 AD Converter는 해당 Channel을 디지털 값으로 변환한다.
- ✓ 변환된 값은 Result Handling으로 전달되며 정해진 위치에 저장된다.



Figure 28-2 ADC Kernel Block Diagram

# ADC Example

## 2. Data sheet 분석 : VADC 구조 분석 (2)

- ✓ **Request Control**은 Conversion Request를 생성하는 2개의 **Request Source**와 각 Request Source에서 생성된 Conversion Request를 관리하는 **Request Source Arbiter**로 구성된다.
- ✓ Request Source는 Timer Unit / External Request / Software에 따라 Conversion Request를 생성한다.
- ✓ 각 Request Source는 필요에 따라 Enable / Disable 할 수 있다.



Figure 28-3 Conversion Request Unit

# ADC Example

## 2. Data sheet 분석 : VADC 구조 분석 (3)

- ✓ **Result Handling**은 변환된 결과인 디지털 값을 설정된 위치에 저장한다.
- ✓ 디지털 값은 추가적으로 압축 및 필터링 될 수 있다.
- ✓ 디지털 값은 **Global Result Register** 또는 **Group Result Register**에 저장될 수 있으며 각 Result Register는 디지털 값 뿐만 아니라 새로운 결과 값이 저장되었음을 나타내는 Valid Flag도 포함한다.
- ✓ Valid Flag는 새로운 디지털 값이 저장되면 Set 되고, 해당 Result Register가 읽히면 Clear 된다.



Figure 28-18 Conversion Result Storage

# ADC Example

## 2. Data sheet 분석 : VADC 구조 분석 (4)

- ✓ VADC의 변환된 결과인 디지털 값은 **8-bit**에서 **12-bit**의 크기를 가진다.
- ✓ 설정에 따라 디지털 값은 Result Register 내에 **Right-Aligned** 또는 **Left-Aligned**로 저장된다.
- ✓ 따라서, 설정에 따라 결과값을 적절하게 읽어 처리해야 한다.

| Standard<br>Conversions | Bit in Result Register | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |
|-------------------------|------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
|                         | 12-Bit                 | 0  | 0  | 0  | 0  | 1  | 1  | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                         | 10-Bit Left-Aligned    | 0  | 0  | 0  | 0  | 9  | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 0 | 0 |   |
|                         | 10-Bit Right-Aligned   | 0  | 0  | 0  | 0  | 0  | 0  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |
|                         | 8-Bit Left-Aligned     | 0  | 0  | 0  | 0  | 7  | 6  | 5 | 4 | 3 | 2 | 1 | 0 | 0 | 0 | 0 | 0 |   |
|                         | 8-Bit Right-Aligned    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |



# ADC Example

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

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

VADC\_CLC Register 주소: F002\_0000h (F0020000h + 0h)

VADC\_CLC Register 구조:

Table 28-10 Registers Address Space

| Module                 | Base Address           | End Address            | Note |    |    |    |    |    |    |    |    |    |     |    |       |       |
|------------------------|------------------------|------------------------|------|----|----|----|----|----|----|----|----|----|-----|----|-------|-------|
| VADC                   | F002 0000 <sub>H</sub> | F002 3FFF <sub>H</sub> |      |    |    |    |    |    |    |    |    |    |     |    |       |       |
| <b>CLC</b>             |                        |                        |      |    |    |    |    |    |    |    |    |    |     |    |       |       |
| Clock Control Register |                        |                        |      |    |    |    |    |    |    |    |    |    |     |    |       |       |
| 31                     | 30                     | 29                     | 28   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16    |       |
| 0                      | 0                      | 0                      | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0     | 0     |
| r                      | r                      | r                      | r    | r  | r  | r  | r  | r  | r  | r  | r  | r  | r   | r  | r     | r     |
| 15                     | 14                     | 13                     | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1  | 0     |       |
| 0                      | 0                      | 0                      | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | E  | DIS | 0  | DIS S | DIS R |
| r                      | r                      | r                      | r    | r  | r  | r  | r  | r  | r  | r  | r  | rw | r   | r  | r     | rw    |

| Field | Bits   | Type | Description                                                                                                                                                                                                                                           |
|-------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DISR  | 0      | rw   | <b>Module Disable Request Bit</b><br>Used for enable/disable control of the module. Also the analog section is disabled by clearing ANONS.<br>0 <sub>B</sub> On request: enable the module clock<br>1 <sub>B</sub> Off request: stop the module clock |
| DISS  | 1      | r    | <b>Module Disable Status Bit</b><br>0 <sub>B</sub> Module clock is enabled<br>1 <sub>B</sub> Off: module is not clocked                                                                                                                               |
| 0     | 2      | r    | Reserved, write 0, read as 0                                                                                                                                                                                                                          |
| EDIS  | 3      | rw   | <b>Sleep Mode Enable Control</b><br>Used to control module's reaction to sleep mode.<br>0 <sub>B</sub> Sleep mode request is enabled and functional<br>1 <sub>B</sub> Module disregards the sleep mode control signal                                 |
| 0     | [31:4] | r    | Reserved, write 0, read as 0                                                                                                                                                                                                                          |



# ADC Example

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

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

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

SCU\_WDTCPU0CON0 Register 구조:

Table 7-27 Registers Address Spaces - SCU Kernel Registers

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



# ADC Example

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

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

| Field          | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PW | [15:2] | rwh | User-Definable Password Field for Access to WDTxCON0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ENDINIT</b> | 0    | rwh  | <b>End-of-Initialization Control Bit</b><br>0 <sub>B</sub> Access to Endinit-protected registers is permitted.<br>1 <sub>B</sub> Access to Endinit-protected registers is not permitted.<br>This bit must be written with a '1' during a Password Access or Check Access (although this write is only used for the password-protection mechanism and is not stored). This bit must be written with the required ENDINIT update value during a Modify Access.                                                                                                                                                                                                                                                                        |    |        |     | This bit field is written with an initial password value during a Modify Access.<br>A read from this bitfield returns this initial password, but bits [7:2] are inverted (toggled) to ensure that a simple read/write is not sufficient to service the WDT.<br><br>If corresponding WDTxSR.PAS = 0 then this bit field must be written with its current contents during a Password Access or Check Access.<br>If corresponding WDTxSR.PAS = 1 then this bit field must be written with the next password in the LFSR sequence during a Password Access or Check Access<br><br>The default password after Application Reset is 00000000111100 <sub>B</sub> |
| <b>LCK</b>     | 1    | rwh  | <b>Lock Bit to Control Access to WDTxCON0</b><br>0 <sub>B</sub> Register WDTxCON0 is unlocked<br>1 <sub>B</sub> Register WDTxCON0 is locked (default after ApplicationReset)<br>The current value of LCK is controlled by hardware. It is cleared after a valid Password Access to WDTxCON0 when WDTxSR.US is 0 (or when WDTxSR.US is 1 and the SMU is in RUN mode), and it is automatically set again after a valid Modify Access to WDTxCON0. During a write to WDTxCON0, the value written to this bit is only used for the password-protection mechanism and is not stored.<br>This bit must be cleared during a Password Access to WDTxCON0, and set during a Modify Access to WDTxCON0.<br>A Check Access does not clear LCK. |    |        |     | A-step silicon: Bits [7:2] must be written with 111100 <sub>B</sub> during Password Access and Modify Access. Read returns 000011 <sub>B</sub> for these bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



A

# ADC Example

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

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



# ADC Example

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

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



# ADC Example

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

- ✓ VADC\_GxARBPR Register는 Group의 Request Source Arbiter에 대한 설정을 한다.
- ✓ VADC의 여러 Group 중, Potentiometer와 연결된 Pin AN0이 Group 4에 입력되기 때문에 **VADC\_G4ARBPR Register**를 설정한다.
- ✓ Pin AN0에 대한 Conversion Request만 생성하면 되기 때문에 Request Source Arbiter는 **Request Source 0**에 대한 설정 (**PRI00 bits / CSM0 bit / ASEN0 bit**)만 수행한다.

VADC\_G4ARBPR Register 주소: F002\_1484h (F0020000h + 1484h)

VADC\_G4ARBPR Register 구조:

Table 28-10 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| VADC   | F002 0000 <sub>H</sub> | F002 3FFF <sub>H</sub> |      |

GxARBPR (x = 0 - 7)

Arbitration Priority Register, Group x

(x \* 0400<sub>H</sub> + 0484<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 |
| 0  | 0  | 0  | 0  | 0  | AS<br>EN2 | AS<br>EN1 | AS<br>EN0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

|    |    |    |    |          |    |           |          |   |           |          |   |          |   |           |   |
|----|----|----|----|----------|----|-----------|----------|---|-----------|----------|---|----------|---|-----------|---|
| 15 | 14 | 13 | 12 | 11       | 10 | 9         | 8        | 7 | 6         | 5        | 4 | 3        | 2 | 1         | 0 |
| 0  | 0  | 0  | 0  | CSM<br>2 | 0  | PRI0<br>2 | CSM<br>1 | 0 | PRI0<br>1 | CSM<br>0 | 0 | CSM<br>0 | 0 | PRI0<br>0 |   |



# ADC Example

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

- ✓ Request Source 0의 우선 순위를 가장 높게 설정하기 위해 **PRI00 bits**를 **11b**로 설정한다.
- ✓ Request Source 0의 Conversion Request가 현재 수행하고 있는 Conversion이 끝날 때까지 기다린 후에 실행되도록 설정하기 위해 **CSM0 bit**를 **0b**로 설정한다.
- ✓ Request Source 0을 Enable 하기 위해 **ASEN0 bit**를 **1b**로 설정한다.

| GxARBPR (x = 0 - 7)<br>Arbitration Priority Register, Group x                    |    |    |    |          |           |           |           |    |           |          |    |           |    |    |    |
|----------------------------------------------------------------------------------|----|----|----|----------|-----------|-----------|-----------|----|-----------|----------|----|-----------|----|----|----|
| (x * 0400 <sub>H</sub> + 0484 <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 |
| 0                                                                                | 0  | 0  | 0  | 0        | AS<br>EN2 | AS<br>EN1 | AS<br>EN0 | 0  | 0         | 0        | 0  | 0         | 0  | 0  | 0  |
| r                                                                                | r  | r  | r  | r        | rw        | rw        | rw        | r  | r         | r        | r  | r         | r  | r  | r  |
| 15                                                                               | 14 | 13 | 12 | 11       | 10        | 9         | 8         | 7  | 6         | 5        | 4  | 3         | 2  | 1  | 0  |
| 0                                                                                | 0  | 0  | 0  | CSM<br>2 | 0         | PRI<br>O2 | CSM<br>1  | 0  | PRI<br>O1 | CSM<br>0 | 0  | PRI<br>O0 | 0  | 0  | 0  |
| r                                                                                | r  | r  | r  | rw       | r         | rw        | rw        | r  | rw        | r        | r  | rw        | r  | rw | r  |

| Field                     | Bits                      | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------|---------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRI00,<br>PRI01,<br>PRI02 | [1:0],<br>[5:4],<br>[9:8] | rw   | Priority of Request Source x<br>Arbitration priority of request source x (in slot x)<br>00 <sub>B</sub> Lowest priority is selected.<br>...<br>11 <sub>B</sub> Highest priority is selected.                                                                                                                                                                                                                                                                                            |
| CSM0,<br>CSM1,<br>CSM2    | 3,<br>7,<br>11            | rw   | Conversion Start Mode of Request Source x<br>0 <sub>B</sub> Wait-for-start mode<br>1 <sub>B</sub> Cancel-inject-repeat mode, i.e. this source can cancel conversion of other sources.                                                                                                                                                                                                                                                                                                   |
| 0                         | 2, 6,<br>10,<br>[23:12]   | r    | Reserved, write 0, read as 0                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ASENy<br>(y = 0 - 2)      | 24 + y                    | rw   | Arbitration Slot y Enable<br>Enables the associated arbitration slot of an arbiter round. The request source bits are not modified by write actions to ASENR.<br>0 <sub>B</sub> The corresponding arbitration slot is disabled and considered as empty. Pending conversion requests from the associated request source are disregarded.<br>1 <sub>B</sub> The corresponding arbitration slot is enabled. Pending conversion requests from the associated request source are arbitrated. |
| 0                         | [31:27]                   | r    | Reserved, write 0, read as 0                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



# ADC Example

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

- ✓ VADC\_GxQMR Register는 Group의 Request Source에 대한 설정을 한다.
- ✓ Group 4의 Request Source 0을 사용하기 때문에 **VADC\_G4QMRO Register**를 설정한다.
- ✓ Software를 통해 Request Source 0의 Conversion Request 생성을 가능하게 하기 위해 **ENGT bit**를 **01b**로 설정한다.
- ✓ 초기화시, Request Source 0에 의한 Conversion Request를 Clear 하기위해 **FLUSH bit**를 **1**로 설정한다.

VADC\_G4QMRO Register 주소: F002\_1504h  
(F0020000h + 1504h)

VADC\_G4QMRO Register 구조:

Table 28-10 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| VADC   | F002 0000 <sub>H</sub> | F002 3FFF <sub>H</sub> |      |

GxQMR0 (x = 0 - 7)

Queue 0 Mode Register, Group x

| (x * 0400 <sub>H</sub> + 0504 <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 | 0                                   | 0  | 0   | RPT DIS |
| r                                            | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | r  | rw                                  |    |     |         |
| 15                                           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  | 0                                   | 0  | CEV | FLUSH   |
| r                                            | r  | r  | r  | w  | w  | w  | w  | w  | r  | r  | r  | r  | r  | rw | rw | rw                                  | rw | rw  | rw      |

| Field        | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ENGT</b>  | [1:0] | rw   | <b>Enable Gate</b><br>Selects the gating functionality for source 0/2.<br>00 <sub>B</sub> No conversion requests are issued<br>01 <sub>B</sub> Conversion requests are issued if a valid conversion request is pending in the queue 0 register or in the backup register<br>10 <sub>B</sub> Conversion requests are issued if a valid conversion request is pending in the queue 0 register or in the backup register and REQGTx = 1<br>11 <sub>B</sub> Conversion requests are issued if a valid conversion request is pending in the queue 0 register or in the backup register and REQGTx = 0 |
|              |       |      | <i>Note: REQGTx is the selected gating signal.</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>FLUSH</b> | 10    | w    | <b>Flush Queue</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Clear all queue entries (including backup stage) and the event flag EV. The queue contains no more valid entry.                                                                                                                                                                                                                                                                                                                                                                                                                 |

# ADC Example

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

- ✓ **TREV bit**는 Conversion Request를 생성하는 트리거 이벤트를 소프트웨어적으로 발생시킨다.
- ✓ 따라서, Conversion Request를 생성하고자 할 때 해당 bit를 1로 설정한다.

| GxQMR0 (x = 0 - 7)                                                               |    |    |    |     |       |       |       |    |    |    |    |    |       |      |    |         |
|----------------------------------------------------------------------------------|----|----|----|-----|-------|-------|-------|----|----|----|----|----|-------|------|----|---------|
| Queue 0 Mode Register, Group x                                                   |    |    |    |     |       |       |       |    |    |    |    |    |       |      |    |         |
| (x * 0400 <sub>H</sub> + 0504 <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 |         |
| 0                                                                                | 0  | 0  | 0  | 0   | 0     | 0     | 0     | 0  | 0  | 0  | 0  | 0  | 0     | 0    | 0  | RPT DIS |
| r                                                                                | r  | r  | r  | r   | r     | r     | r     | r  | r  | r  | r  | r  | r     | r    | r  | rw      |
| 15                                                                               | 14 | 13 | 12 | 11  | 10    | 9     | 8     | 7  | 6  | 5  | 4  | 3  | 2     | 1    | 0  |         |
| 0                                                                                | 0  | 0  | 0  | CEV | FLUSH | TR EV | CLR V | 0  | 0  | 0  | 0  | 0  | EN TR | ENGT | -  |         |
| r                                                                                | r  | r  | r  | w   | w     | w     | w     | r  | r  | r  | r  | r  | rw    | -    | rw |         |

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                                                |
|-------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLRV  | 8    | w    | <b>Clear Valid Bit</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> The next pending valid queue entry in the sequence and the event flag EV are cleared. If there is a valid entry in the queue backup register (QBUR.V = 1), this entry is cleared, otherwise the entry in queue register 0 is cleared. |
| TREV  | 9    | w    | <b>Trigger Event</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Generate a trigger event by software                                                                                                                                                                                                    |
| FLUSH | 10   | w    | <b>Flush Queue</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Clear all queue entries (including backup stage) and the event flag EV. The queue contains no more valid entry.                                                                                                                           |



# ADC Example

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

- ✓ VADC\_GxARBCFG Register는 Group의 AD Converter에 대한 설정을 한다.
- ✓ Group 4을 사용하기 때문에 **VADC\_G4ARBCFG Register**를 설정한다.
- ✓ AD Converter를 Normal Operation Mode로 동작시키기 위해 **ANONC bits**를 **11b**로 설정한다.

VADC\_G4ARBCFG Register 주소: F002\_1480h  
(F0020000h + 1480h)

VADC\_G4ARBCFG Register 구조:

Table 28-10 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| VADC   | F002 0000 <sub>H</sub> | F002 3FFF <sub>H</sub> |      |

| GxARBCFG (x = 0 - 7)<br>Arbitration Configuration Register, Group x<br>(x * 0400 <sub>H</sub> + 0480 <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 |                                     |  |  |  |  |  |
| SAMPLE                                                                                                              | BUSY | CALS | CAL | 0  | 0  | SYNRUN | CHNR |       |    |        | CSRC |    | ANONS |    |    |                                     |  |  |  |  |  |
| rh                                                                                                                  | rh   | rh   | rh  | r  | r  | rh     | rh   | rh    | rh | rh     | rh   | rh | rh    | rh | rh |                                     |  |  |  |  |  |
| 15                                                                                                                  | 14   | 13   | 12  | 11 | 10 | 9      | 8    | 7     | 6  | 5      | 4    | 3  | 2     | 1  | 0  |                                     |  |  |  |  |  |
| 0                                                                                                                   | 0    | 0    | 0   | 0  | 0  | 0      | 0    | ARB M | 0  | ARBRND | 0    | 0  | ANONC |    |    |                                     |  |  |  |  |  |
| r                                                                                                                   | r    | r    | r   | r  | r  | r      | r    | rw    | r  | rw     | r    | r  | rw    |    |    |                                     |  |  |  |  |  |

• **ANONS = 11<sub>B</sub>: Normal Operation**  
The converter is active, conversions are started immediately.  
Requires no wakeup time.

| Field         | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ANONC</b>  | [1:0] | rw   | Analog Converter Control<br>Defines the value of bitfield ANONS in a stand-alone converter or a converter in master mode.<br>Coding see ANONS or <a href="#">Section 28.4.1</a> .                                                                                                                                                                                                                                                                                     |
| 0             | [3:2] | r    | Reserved, write 0, read as 0                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>ARBRND</b> | [5:4] | rw   | Arbitration Round Length<br>Defines the number of arbitration slots per arb. round (arbitration round length = $t_{ARB}$ ). <sup>1)</sup><br>00 <sub>B</sub> 4 arbitration slots per round ( $t_{ARB} = 4 / f_{ADCD}$ )<br>01 <sub>B</sub> 8 arbitration slots per round ( $t_{ARB} = 8 / f_{ADCD}$ )<br>10 <sub>B</sub> 16 arbitration slots per round ( $t_{ARB} = 16 / f_{ADCD}$ )<br>11 <sub>B</sub> 20 arbitration slots per round ( $t_{ARB} = 20 / f_{ADCD}$ ) |
| 0             | 6     | r    | Reserved, write 0, read as 0                                                                                                                                                                                                                                                                                                                                                                                                                                          |



# ADC Example

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

- ✓ VADC\_GxICLASS Register는 Group의 Input Class에 대한 설정을 한다.
- ✓ Analog Input Channel은 미리 설정된 Input Class 중 하나에 속하게 되며 해당 Input Class의 설정이 반영된다.
- ✓ Group 4의 Input Class 0을 설정하기 위해 **VADC\_G4ICLASS0 Register**를 설정한다.
- ✓ Sample Time과 Conversion Mode를 설정하기 위해 **STCS bits / CMS bits**를 설정한다.

VADC\_G4ICLASS0 Register 주소: F002\_14A0h  
(F0020000h + 14A0h)

VADC\_G4ICLASS0 Register 구조:

Table 28-10 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| VADC   | F002 0000 <sub>H</sub> | F002 3FFF <sub>H</sub> |      |

GxICLASS0 (x = 0 - 7)

Input Class Register 0, Group x

| (x * 0400 <sub>H</sub> + 04A0 <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                                  |  |  |  |  |
| 0                                            | 0  | 0  | 0  | 0  |    | CME |    | 0  | 0  | 0  |    |    |    |    | STCE                                |  |  |  |  |
| r                                            | r  | r  | r  | r  | r  |     | rw | r  | r  | r  | r  |    |    |    | rw                                  |  |  |  |  |
| 15                                           | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                   |  |  |  |  |
| 0                                            | 0  | 0  | 0  | 0  | 0  | CMS |    | 0  | 0  | 0  | 0  |    |    |    | STCS                                |  |  |  |  |
| r                                            | r  | r  | r  | r  | r  |     | rw | r  | r  | r  | r  |    |    |    | rw                                  |  |  |  |  |

# ADC Example

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

- ✓ Conversion Mode를 12-bit Conversion으로 설정하기 위해 CMS bits를 000b로 설정한다.

| GxICLASS0 (x = 0 - 7)<br>Input Class Register 0, Group x                         |    |    |    |    |     |     |    |    |    |    |      |    |      |    |    |
|----------------------------------------------------------------------------------|----|----|----|----|-----|-----|----|----|----|----|------|----|------|----|----|
| (x * 0400 <sub>H</sub> + 04A0 <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 |
| 0                                                                                | 0  | 0  | 0  | 0  |     | CME |    | 0  | 0  | 0  |      |    | STCE |    |    |
| r                                                                                | r  | r  | r  | r  | r   |     | rw | r  | r  | r  |      |    | rw   |    |    |
| 15                                                                               | 14 | 13 | 12 | 11 | 10  | 9   | 8  | 7  | 6  | 5  | 4    | 3  | 2    | 1  | 0  |
| 0                                                                                | 0  | 0  | 0  | 0  | CMS |     | 0  | 0  | 0  |    | STCS |    |      |    |    |
| r                                                                                | r  | r  | r  | r  | r   |     | rw | r  | r  | r  |      | rw |      |    |    |

| Field | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                       |
|-------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STCS  | [4:0]   | rw   | <b>Sample Time Control for Standard Conversions</b><br>Number of additional clock cycles to be added to the minimum sample phase of 2 analog clock cycles:<br>Coding and resulting sample time see <a href="#">Table 28-4</a> .<br>For conversions of external channels, the value from bitfield STCE can be used.                |
| 0     | [7:5]   | r    | <b>Reserved, write 0, read as 0</b>                                                                                                                                                                                                                                                                                               |
| CMS   | [10:8]  | rw   | <b>Conversion Mode for Standard Conversions</b><br>000 <sub>B</sub> 12-bit conversion<br>001 <sub>B</sub> 10-bit conversion<br>010 <sub>B</sub> 8-bit conversion<br>011 <sub>B</sub> Reserved<br>100 <sub>B</sub> Reserved<br>101 <sub>B</sub> 10-bit fast compare mode<br>110 <sub>B</sub> Reserved<br>111 <sub>B</sub> Reserved |
| 0     | [15:11] | r    | <b>Reserved, write 0, read as 0</b>                                                                                                                                                                                                                                                                                               |

# ADC Example

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

- ✓ VADC\_GxCHCTR Register는 Group의 Analog Input Channel에 대한 설정을 한다.
- ✓ Potentiometer가 연결된 Pin AN00| Group 4의 Input Channel 7에 입력되기 때문에 **VADC\_G4CHCTR7 Register**를 설정한다.
- ✓ 해당 Input Channel에 대한 Input Class / Result Register / Result Align을 설정하기 위해 **ICLSEL bits / RESREG bits / RESPOS bit**를 설정한다.

VADC\_G4CHCTR7 Register 주소: F002\_161Ch  
(F0020000h + 161Ch)

VADC\_G4CHCTR7 Register 구조:

Table 28-10 Registers Address Space

| Module | Base Address           | End Address            | Note |
|--------|------------------------|------------------------|------|
| VADC   | F002 0000 <sub>H</sub> | F002 3FFF <sub>H</sub> |      |

| G0CHCTR <sub>y</sub> (y = 0 - 7)<br>Group 0, Channel y Ctrl. Reg. (0600 <sub>H</sub> + y * 0004 <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 |
| 0                                                                                                                                                  | BWD EN | BWD CH | 0  | 0  | 0  | 0  | 0  | 0  | 0  | RES POS | RES TBS | RESREG |    |    |    |

|         |    |    |    |         |       |           |         |   |         |   |   |        |   |   |   |
|---------|----|----|----|---------|-------|-----------|---------|---|---------|---|---|--------|---|---|---|
| 15      | 14 | 13 | 12 | 11      | 10    | 9         | 8       | 7 | 6       | 5 | 4 | 3      | 2 | 1 | 0 |
| BNDSELX |    |    |    | REF SEL | SY NC | CHEV MODE | BNDSELU |   | BNDSELL | 0 | 0 | ICLSEL |   |   |   |

# ADC Example

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

- ✓ Analog Input Channel 7의 Input Class를 앞서 설정한 Group 4의 Input Class 0으로 설정하기 위해 **ICLSEL bits**를 **00b**로 설정한다.
- ✓ Analog Input Channel 0의 디지털 값을 Group 0의 Result Register 0에 저장하기 위해 **RESREG bits**를 **0000b**로 설정한다.
- ✓ Analog Input Channel 0의 디지털 값을 Right-Aligned로 저장하기 위해 **RESPOS bit**를 **1**로 설정한다.

| G4CHCTRY ( $y = 0 - 7$ )                                    |           |           |            |          |              |         |         |    |    |            |            |        |    |    |    | Reset Value: 0000 0000 <sub>H</sub> |
|-------------------------------------------------------------|-----------|-----------|------------|----------|--------------|---------|---------|----|----|------------|------------|--------|----|----|----|-------------------------------------|
| Group 4, Channel $y$ Ctrl. Reg. ( $(1600_H + y * 0004_H)$ ) |           |           |            |          |              |         |         |    |    |            |            |        |    |    |    |                                     |
| 31                                                          | 30        | 29        | 28         | 27       | 26           | 25      | 24      | 23 | 22 | 21         | 20         | 19     | 18 | 17 | 16 | Reset Value: 0000 0000 <sub>H</sub> |
| 0                                                           | BWD<br>EN | BWD<br>CH | 0          | 0        | 0            | 0       | 0       | 0  | 0  | RES<br>POS | RES<br>TBS | RESREG |    |    |    |                                     |
| r                                                           | rw        | rw        | r          | r        | r            | r       | r       | r  | r  | rw         | rw         | rw     |    |    |    |                                     |
| 15                                                          | 14        | 13        | 12         | 11       | 10           | 9       | 8       | 7  | 6  | 5          | 4          | 3      | 2  | 1  | 0  |                                     |
| BNDSELX                                                     |           |           | REF<br>SEL | SY<br>NC | CHEV<br>MODE | BNDSELU | BNDSELL | 0  | 0  | ICLSEL     |            |        |    |    |    |                                     |
| rw                                                          |           |           | rw         | rw       | rw           | rw      | rw      | rw | rw | rw         |            |        |    |    |    |                                     |

| Field  | Bits    | Type | Description                                                                                                                                                                                           |
|--------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ICLSEL | [1:0]   | rw   | <b>Input Class Select</b><br><br>00 <sub>B</sub> Use group-specific class 0<br>01 <sub>B</sub> Use group-specific class 1<br>10 <sub>B</sub> Use global class 0<br>11 <sub>B</sub> Use global class 1 |
| RESREG | [19:16] | rw   | <b>Result Register</b><br><br>0000 <sub>B</sub> Store result in group result register GxRES0<br>...<br>1111 <sub>B</sub> Store result in group result register GxRES15                                |
| Field  | Bits    | Type | Description                                                                                                                                                                                           |
| RESPOS | 21      | rw   | <b>Result Position</b><br><br>0 <sub>B</sub> Store results left-aligned<br>1 <sub>B</sub> Store results right-aligned                                                                                 |

# ADC Example

## 2. Data sheet 분석 : Conversion Request 설정

- ✓ VADC\_GxQINR Register는 Request Source의 Conversion Request에 대한 설정을 한다.
- ✓ Group 4의 Request Source 0을 사용하기 때문에 **VADC\_G4QINR0 Register**를 설정한다.
- ✓ Analog Input Channel 7을 입력으로 설정하기 위해 **REQCHNR bits**를 7으로 설정한다.
- ✓ Continuous Mode로 설정하기 위해 **RF bit**를 1b로 설정한다. (해당 bit를 1b로 설정하면 Conversion이 끝난 후 다시 Conversion Request가 발생하여 Continuous Mode로 동작한다.)

VADC\_G4QINR0 Register 주소: F002\_1510h  
 (F0020000h + 1510h)

VADC\_G4QINR0 Register 구조:

Table 28-10 Registers Address Space

| Module                                       | Base Address           | End Address            | Note    |
|----------------------------------------------|------------------------|------------------------|---------|
| VADC                                         | F002 0000 <sub>H</sub> | F002 3FFF <sub>H</sub> |         |
| <b>GxQINR0 (x = 0 - 7)</b>                   |                        |                        |         |
| Queue 0 Input Register, Group x              |                        |                        |         |
| (x * 0400 <sub>H</sub> + 0510 <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      |
| 0                                            | 0                      | 0                      | 0       |
| r                                            | r                      | r                      | r       |
| 15                                           | 14                     | 13                     | 12      |
| 11                                           | 10                     | 9                      | 8       |
| 7                                            | 6                      | 5                      | 4       |
| 3                                            | 2                      | 1                      | 0       |
| 0                                            | 0                      | 0                      | 0       |
| r                                            | r                      | r                      | r       |
| EX TR                                        | EN SI                  | RF                     | REQCHNR |
| w                                            | w                      | w                      | w       |

| Field          | Bits  | Type | Description                                                                                                                                                                                                                         |
|----------------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>REQCHNR</b> | [4:0] | w    | <b>Request Channel Number</b><br>Defines the channel number to be converted                                                                                                                                                         |
| <b>RF</b>      | 5     | w    | <b>Refill</b><br>0 <sub>B</sub> No refill: this queue entry is converted once and then invalidated<br>1 <sub>B</sub> Automatic refill: this queue entry is automatically reloaded into QINR0 when the related conversion is started |
| <b>ENSI</b>    | 6     | w    | <b>Enable Source Interrupt</b><br>0 <sub>B</sub> No request source interrupt<br>1 <sub>B</sub> A request source event interrupt is generated upon a request source event (related conversion is finished)                           |

# ADC Example

## 2. Data sheet 분석 : Result Register 설정

- ✓ VADC\_GxRES Register는 변환된 디지털 값에 대한 정보를 저장한다.
- ✓ Analog Input Channel 0의 디지털 값을 Result Register 0에 저장하도록 설정했기 때문에 **VADC\_G4RES0 Register**를 확인한다.
- ✓ 변환이 끝나 새로운 디지털 값이 저장되었는지 확인하기 위해 **VF bit**가 1인지 확인한다.
- ✓ 변환된 디지털 값을 확인하기 위해 Align을 고려하여 **RESULT bits**를 확인한다.

VADC\_G4RES0 Register 주소: F002\_1700h  
(F0020000h + 1700h)

VADC\_G4RES0 Register 구조:

Table 28-10 Registers Address Space

| Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Base Address           | End Address            | Note |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|------------------------|------|----|----|------|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|--|----|--|----|--|----|--|----|--|----|--|----|--|----|----|-----|-----|------|--|--|------|--|--|--|-----|--|--|--|--|--|--|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| VADC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | F002 0000 <sub>H</sub> | F002 3FFF <sub>H</sub> |      |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| G0RESy (y = 0 - 15)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                        |      |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Group 0 Result Register y (0700 <sub>H</sub> + y * 0004 <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |                        |      |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset Value: 0000 0000 <sub>H</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                        |      |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <table><tr><td>31</td><td>30</td><td>29</td><td>28</td><td>27</td><td>26</td><td>25</td><td>24</td><td>23</td><td>22</td><td>21</td><td>20</td><td>19</td><td>18</td><td>17</td><td>16</td></tr><tr><td>rh</td><td>rh</td><td>rh</td><td></td><td>rh</td><td></td><td>rh</td><td></td><td>rh</td><td></td><td>rh</td><td></td><td>rh</td><td></td><td>rh</td><td></td><td>rh</td></tr><tr><td>VF</td><td>FCR</td><td>CRS</td><td>EMUX</td><td></td><td></td><td>CHNR</td><td></td><td></td><td></td><td>DRC</td><td></td><td></td><td></td><td></td><td></td><td></td></tr><tr><td>15</td><td>14</td><td>13</td><td>12</td><td>11</td><td>10</td><td>9</td><td>8</td><td>7</td><td>6</td><td>5</td><td>4</td><td>3</td><td>2</td><td>1</td><td>0</td><td></td></tr><tr><td colspan="17">RESULT</td></tr><tr><td colspan="17">rwh</td></tr></table> |                        |                        |      | 31 | 30 | 29   | 28 | 27 | 26 | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | rh | rh | rh |  | rh | VF | FCR | CRS | EMUX |  |  | CHNR |  |  |  | DRC |  |  |  |  |  |  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  | RESULT |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | rwh |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 30                     | 29                     | 28   | 27 | 26 | 25   | 24 | 23 | 22 | 21  | 20 | 19 | 18 | 17 | 16 |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| rh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | rh                     | rh                     |      | rh |    | rh   |    | rh |    | rh  |    | rh |    | rh |    | rh |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| VF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | FCR                    | CRS                    | EMUX |    |    | CHNR |    |    |    | DRC |    |    |    |    |    |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 14                     | 13                     | 12   | 11 | 10 | 9    | 8  | 7  | 6  | 5   | 4  | 3  | 2  | 1  | 0  |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RESULT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |                        |      |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| rwh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                        |      |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |  |    |  |    |  |    |  |    |  |    |  |    |  |    |    |     |     |      |  |  |      |  |  |  |     |  |  |  |  |  |  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Field  | Bits   | Type | Description                                                                                                                                                                                                                                          |
|--------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESULT | [15:0] | rwh  | <b>Result of Most Recent Conversion</b><br>The position of the result bits within this bitfield depends on the configured operating mode.<br>Refer to <a href="#">Section 28.7.2</a> .                                                               |
| VF     | 31     | rh   | <b>Valid Flag</b><br>Indicates a new result in bitfield RESULT or bit FCR.<br>0 <sub>B</sub> No new result available<br>1 <sub>B</sub> Bitfield RESULT has been updated with new result value and has not yet been read, or bit FCR has been updated |

# ADC Example

## 3. 프로그래밍

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

```
70 /* Define PORT02/10 Registers for RGB LED */
71 #define PORT02_BASE      (0xF003A200)
72 #define PORT02_IOCR4     (*(volatile unsigned int*)(PORT02_BASE + 0x14))
73 #define PORT02_OMR       (*(volatile unsigned int*)(PORT02_BASE + 0x04))
74
75 #define PC7              27
76 #define PCL7             23
77 #define PS7              7
78
79 #define PORT10_BASE      (0xF003B000)
80 #define PORT10_IOCR4     (*(volatile unsigned int*)(PORT10_BASE + 0x14))
81 #define PORT10_IOCR0     (*(volatile unsigned int*)(PORT10_BASE + 0x10))
82 #define PORT10_OMR       (*(volatile unsigned int*)(PORT10_BASE + 0x04))
83
84 #define PC5              11
85 #define PC3              27
86 #define PCL5             21
87 #define PCL3             19
88 #define PS5              5
89 #define PS3              3
```

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

```
152 /* Initialize RGB LED */
153 void init_RGBLED(void)
154 {
155     /* Reset IOCR0 bits */
156     PORT02_IOCR4 &= ~((0x1F) << PC7);
157     PORT10_IOCR4 &= ~((0x1F) << PC5);
158     PORT10_IOCR0 &= ~((0x1F) << PC3);
159
160     /* Set PC bits in IOCR0 with push-pull(2b10000) */
161     PORT02_IOCR4 |= ((0x10) << PC7);
162     PORT10_IOCR4 |= ((0x10) << PC5);
163     PORT10_IOCR0 |= ((0x10) << PC3);
164 }
```

PORT IO 설정 함수



# ADC Example

## 3. 프로그래밍

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

- ① SCU\_WDTCPU0CON0 Register를 통해 Password/Modify Access를 수행하여 System ENDINIT을 해제한다.
- ② VADC\_CLC Register를 통해 VADC 모듈을 Enable 한다.
- ③ SCU\_WDTCPU0CON0 Register를 통해 Password/Modify Access를 수행하여 System ENDINIT을 설정한다.
- ④ VADC\_G4ARBPR Register를 통해 Group 4의 Request Source 0에 대한 Request Source Arbiter 설정을 한다.
- ⑤ VADC\_G4QMRO Register를 통해 Request Source 0에 대한 설정을 한다.
- ⑥ VADC\_G4ARBCFG Register를 통해 Analog Converter의 동작 모드를 Normal Operation으로 설정한다.
- ⑦ VADC\_G4ICLASS0 Register를 통해 Input Class 0을 설정한다.
- ⑧ VADC\_G4CHCTR7 Register를 통해 Analog Input Channel 7에 대한 설정을 한다.



# ADC Example

## 3. 프로그래밍

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

```
31 /* SCU Registers */
32 #define SCU_BASE          (0xF0036000)
33 #define SCU_WDT_CPU0CON0   (*(volatile unsigned int*)(SCU_BASE + 0x100))
34
35 #define LCK                1
36 #define ENDINIT            0
37
38 /* VADC Registers */
39 #define VADC_BASE          (0xF0020000)
40 #define VADC_CLC            (*(volatile unsigned int*)(VADC_BASE + 0x000))
41 #define VADC_GLOBCFG        (*(volatile unsigned int*)(VADC_BASE + 0x080))
42 #define VADC_G4ARBCFG       (*(volatile unsigned int*)(VADC_BASE + 0x1480))
43 #define VADC_G4ARBPR        (*(volatile unsigned int*)(VADC_BASE + 0x1484))
44 #define VADC_G4ICLASS0      (*(volatile unsigned int*)(VADC_BASE + 0x14A0))
45 #define VADC_G4QMR0          (*(volatile unsigned int*)(VADC_BASE + 0x1504))
46 #define VADC_G4QINR0         (*(volatile unsigned int*)(VADC_BASE + 0x1510))
47 #define VADC_G4CHCTR7       (*(volatile unsigned int*)(VADC_BASE + 0x161C))
48 #define VADC_G4RES0          (*(volatile unsigned int*)(VADC_BASE + 0x1700))
49
50 #define DISS               1
51 #define DISR               0
52 #define ANONC              0
53 #define ASEN0              24
54 #define CSM0               3
55 #define PRI00              0
56 #define CMS                8
57 #define FLUSH              10
58 #define TREV               9
59 #define ENGT               0
60 #define RF                 5
61 #define RESPOS             21
62 #define RESREG              16
63 #define ICLSEL              1
64 #define ICLSEL              1
65 #define VF                 31
66 #define RESULT              0
```



# ADC Example

## 3. 프로그래밍

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

```
166① void init_VADC(void)
167 {
168     /* VADC Enable */
169     /* Password Access to unlock WDTCPU0CON0 */
170     SCU_WDT_CPU0CON0 = ((SCU_WDT_CPU0CON0 ^ 0xFC) & ~(1 << LCK)) | (1 << ENDINIT);
171     ① while((SCU_WDT_CPU0CON0 & (1 << LCK)) != 0);
172
173     /* Modify Access to clear ENDINIT bit */
174     SCU_WDT_CPU0CON0 = ((SCU_WDT_CPU0CON0 ^ 0xFC) | (1 << LCK)) & ~ (1 << ENDINIT);
175     while((SCU_WDT_CPU0CON0 & (1 << LCK)) == 0);
176
177     VADC_CLC &= ~(1 << DISR); // Enable VADC Module
178     ②
179     /* Password Access to unlock WDTSCPU0CON0 */
180     SCU_WDT_CPU0CON0 = ((SCU_WDT_CPU0CON0 ^ 0xFC) & ~(1 << LCK)) | (1 << ENDINIT);
181     ③ while((SCU_WDT_CPU0CON0 & (1 << LCK)) != 0);
182
183     /* Modify Access to clear ENDINIT bit */
184     SCU_WDT_CPU0CON0 = ((SCU_WDT_CPU0CON0 ^ 0xFC) | (1 << LCK)) & ~ (1 << ENDINIT);
185     while((SCU_WDT_CPU0CON0 & (1 << LCK)) == 0);
186
187     while((VADC_CLC & (1 << DISS)) != 0); // Wait until module is enabled
188
189     ④ VADC_G4ARBPR |= ((0x3) << PRI00); // Highest Priority for Request Source 0
190     VADC_G4ARBPR &= ~(1 << CSM0); // Conversion Start Mode : Wait-for-start mode
191     VADC_G4ARBPR |= (1 << (ASEN0)); // Arbitration Source Input 0 Enable
```



# ADC Example

## 3. 프로그래밍

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

```
192 ⑤ VADC_G4QMR0 &= ~((0x3) << ENGT);           // Enable Conversion Requests  
193  VADC_G4QMR0 |= ((0x1) << ENGT);  
194  
195  VADC_G4QMR0 |= (1 << FLUSH);                  // Clear all Queue Entries  
196  
197 ⑥ VADC_G4ARBCFG |= ((0x3) << ANONC);          // Analog Converter : Normal Operation  
198  
199 ⑦ VADC_G4ICLASS0 &= ~((0x7) << CMS);          // Group-specific Class 0  
200  // Conversion Mode : Standard Conversion (12-bit)  
201  
202  /* VADC Group 4 Channel 7 Setting */  
203 ⑧ VADC_G4CHCTR7 |= (1 << RESPOS);             // Read Results Right-aligned  
204  VADC_G4CHCTR7 &= ~((0xF) << RESREG);          // Store Result in Group Result Register G4RES0  
205  VADC_G4CHCTR7 &= ~((0x3) << ICLSEL);          // Use Group-specific Class 0  
206  
207 }
```

VADC 설정 함수



# ADC Example

## 3. 프로그래밍

3) VADC의 Conversion Request를 생성하는 함수를 구현한다.

- ① VADC\_G0QINR0 Register를 통해 Request Source 0에서 생성할 Conversion Request의 Analog Input Channel(Channel 7)을 설정한다.
- ② VADC\_G0QINR0 Register를 통해 해당 Conversion Request가 Continuous Mode로 동작하도록 설정한다.
- ③ VADC\_G0QMRO Register를 통해 Conversion Request를 생성하는 트리거 이벤트를 소프트웨어적으로 발생시킨다.

```
209 void VADC_startConversion(void)
210 {
211     /* Fill and Start Queue */
212     VADC_G4QINR0 &= ~(0x1F);                                // Request Channel Number : 7
213     ① VADC_G4QINR0 |= (0x07);
214
215     ② VADC_G4QINR0 |= (1 << RF);                         // Automatic fill for continuous mode
216     ③ VADC_G4QMRO |= (1 << TREV);                      // Generate a Trigger Event
217 }
```



# ADC Example

## 3. 프로그래밍

4) VADC의 Result Register를 읽어오는 함수를 구현한다.

- ① VADC\_GORES0 Register의 VF bit를 통해 변환이 끝나 새로운 결과 값이 저장되기를 기다린다.
- ② VADC\_GORES0 Register를 Masking 하여 변환된 디지털 값만 읽어온다.
- ③ 해당 디지털 값을 반환한다.

```
219⊕ unsigned int VADC_readResult(void)
220 {
221     unsigned int result;
222
223     ① while((VADC_G4RES0 & (1 << VF)) == 0);           // Wait until New Result Available
224
225     ② result = (VADC_G4RES0 & ((0xFFFF) << RESULT)); // Read Result
226
227     ③ return result;
228 }
```



# ADC Example

## 3. 프로그래밍

5) 동작에 따라 'main' 함수를 구현한다. (필요한 레지스터 / 비트 필드 및 함수 프로토타입을 작성한다.)

```
31 /* SCU Registers */
32 #define SCU_BASE          (0xF0036000)
33 #define SCU_WDT_CPU0CON0   (*(volatile unsigned int*)(SCU_BASE + 0x100))
34
35 #define LCK                1
36 #define ENDINIT             0
37
38 /* VADC Registers */
39 #define VADC_BASE          (0xF0020000)
40 #define VADC_CLC            (*(volatile unsigned int*)(VADC_BASE + 0x000))
41 #define VADC_GLOBCFG        (*(volatile unsigned int*)(VADC_BASE + 0x080))
42 #define VADC_G4ARBCFG       (*(volatile unsigned int*)(VADC_BASE + 0x1480))
43 #define VADC_G4ARBPR        (*(volatile unsigned int*)(VADC_BASE + 0x1484))
44 #define VADC_G4ICLASS0      (*(volatile unsigned int*)(VADC_BASE + 0x14A0))
45 #define VADC_G4QMR0          (*(volatile unsigned int*)(VADC_BASE + 0x1504))
46 #define VADC_G4QINR0         (*(volatile unsigned int*)(VADC_BASE + 0x1510))
47 #define VADC_G4CHCTR7       (*(volatile unsigned int*)(VADC_BASE + 0x161C))
48 #define VADC_G4RES0          (*(volatile unsigned int*)(VADC_BASE + 0x1700))
49
50 #define DISS                1
51 #define DISR                0
52 #define ANONC               0
53 #define ASEN0               24
54 #define CSM0                3
55 #define PRI00               0
56 #define CMS                 8
57 #define FLUSH               10
58 #define TREV                9
59 #define ENGT                0
60 #define RF                  5
61 #define RESPOS              21
62 #define RESREG              16
63 #define ICLSEL              1
64 #define ICLSEL              1
65 #define VF                  31
66 #define RESULT              0
```

```
69 /* Define PORT02/10 Registers for RGB LED */
70 #define PORT02_BASE         (0xF003A200)
71 #define PORT02_IOCR4        (*(volatile unsigned int*)(PORT02_BASE + 0x14))
72 #define PORT02_OMR          (*(volatile unsigned int*)(PORT02_BASE + 0x04))
73
74 #define PC7                27
75 #define PCL7                23
76 #define PS7                7
77
78 #define PORT10_BASE         (0xF003B000)
79 #define PORT10_IOCR4        (*(volatile unsigned int*)(PORT10_BASE + 0x14))
80 #define PORT10_IOCR0        (*(volatile unsigned int*)(PORT10_BASE + 0x10))
81 #define PORT10_OMR          (*(volatile unsigned int*)(PORT10_BASE + 0x04))
82
83 #define PC5                11
84 #define PC3                27
85 #define PCL5                21
86 #define PCL3                19
87 #define PS5                5
88 #define PS3                3
89
90 void init_RGBLED(void);
91 void init_VADC(void);
92 void VADC_startConversion(void);
93 unsigned int VADC_readResult(void);
```



# ADC Example

## 3. 프로그래밍

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

```
97 int core0_main(void)
98 {
99     IfxCpu_enableInterrupts();
100
101    /* !!!WATCHDOG AND SAFETY WATCHDOG ARE DISABLED HERE!!
102     * Enable the watchdogs and service them periodically if it is required
103     */
104    IfxScuWdt_disableCpuWatchdog(IfxScuWdt_getCpuWatchdogPassword());
105    IfxScuWdt_disableSafetyWatchdog(IfxScuWdt_getSafetyWatchdogPassword());
106
107    /* Wait for CPU sync event */
108    IfxCpu_emitEvent(&g_cpuSyncEvent);
109    IfxCpu_waitEvent(&g_cpuSyncEvent, 1);
110
111    unsigned int adcResult;
112
113    /* Initialization */
114    init_RGBLED();           // Initialize PORT
115    init_VADC();             // Initialize VADC
```

```
118    while(1)
119    {
120        VADC_startConversion();
121        adcResult = VADC_readResult();
122
123        if(adcResult >= 3096)
124        {
125            PORT02_OMR |= (1<<PS7);          // Set LED RED
126            PORT10_OMR |= (1<<PCL5);        // Clear LED GREEN
127            PORT10_OMR |= (1<<PCL3);        // Clear LED BLUE
128        }
129        else if(adcResult >= 2048)
130        {
131            PORT02_OMR |= (1<<PCL7);        // Clear LED RED
132            PORT10_OMR |= (1<<PS5);        // Set LED GREEN
133            PORT10_OMR |= (1<<PCL3);        // Clear LED BLUE
134        }
135        else if(adcResult >= 1024)
136        {
137            PORT02_OMR |= (1<<PCL7);        // Clear LED RED
138            PORT10_OMR |= (1<<PCL5);        // Clear LED GREEN
139            PORT10_OMR |= (1<<PS3);        // Set LED BLUE
140        }
141        else
142        {
143            PORT02_OMR |= (1<<PCL7);        // Clear LED RED
144            PORT10_OMR |= (1<<PCL5);        // Clear LED GREEN
145            PORT10_OMR |= (1<<PCL3);        // Clear LED BLUE
146        }
147    }
148    return (1);
149 }
```



# ADC Example

## 4. 동작 확인

- ✓ Build 및 Debug 후 ('Resume' 버튼 클릭), Potentiometer를 돌려보며 RGB-LED가 켜지는 것을 확인한다.



# Q & A

**Thank you for your attention**



**School of Electronics Engineering, KNU**

ACE Lab (hn02301@gmail.com)