# TI DSP, MCU, Xilinx Zynq FPGA 프로그래밍 전문가 과정

강사 - Innova Lee (이상훈) gcccompil3r@gmail.com 학생 - 김형주 mihaelkel@naver.com

### Cortex-R5F 부트로더 분석



부트로더는 "HL\_sys\_intvecs.asm" 파일 안에 작성되어 있다.

코드를 보면, b(branch)명령어를 통해 \_c\_int00로 점프를 하고 있다.

F3을 누르면 해당 함수의 정의부로 갈 수 있고, F2를 누르면 정의를 볼 수 있다. F3을 눌러 \_c\_int00가 뭔지 알아보자.

```
Getting Started
                  ☐ HL_sys_main.c
⑤ HL_sys_intvecs.asm
⑥ HL_sys_startup.c
  96 void _c_int00(void)
  97 {
  98
 99 /* USER CODE BEGIN (5) */
 100 /* USER CODE END */
 102
        /* Initialize Core Registers to avoid CCM Error */
 103
        _coreInitRegisters_();
 184
       /* Initialize Stack Pointers */
 105
        _coreInitStackPointer_();
 107
 108
        /* Reset handler: the following instructions read from the system exception status register
         * to identify the cause of the CPU reset.
 109
 110
        switch(getResetSource())
 112
            case POWERON RESET:
 113
 114
            case DEBUG RESET:
 115
            case EXT RESET:
함수 안에 함수가 또 있다.
```

하나씩 알아보자. 먼저 \_coreInitRegisters\_()가 어떻게 정의되어 있는지, F3을 눌러서 다시 들어간다.

```
Getting Started
             110 *
111 #define UNDEF STACK LENGTH 0x00000100U
112
113 /* System Core Interface Functions */
114
115 /** @fn void _coreInitRegisters_(void)
116 *
      @brief Initialize Core register
117 */
118 void coreInitRegisters (void);
119
120 /** @fn void coreInitStackPointer (void)
      @brief Initialize Core stack pointer
123 void _coreInitStackPointer_(void);
```

헤더파일, 즉 선언부밖에 보이지 않고, 정의는 안보인다.

정의는 다른 파일에 있다고 추측할 수 있는데, 함수 이름을 잘 기억해두고 include된 모든 파일들을 살펴보자

"HL\_sys\_core.asm" 라는 어셈블리 파일이 눈에 띈다. 해당 파일을 열어 coreInitRegisters를 검색하면 아래와 같이 정의를 볼 수 있다.

```
51_coreInitRegisters
  52
       ; After reset, the CPU is in the Supervisor mode (M = 10011)
          mov r0, lr
          mov r1, #0x0000
  55
           mov r2, #0x0000
  56
57
          mov r3, #0x0000
          mov r4, #0x0000
  59
          mov r5, #0x0000
          mov r6, #0x0000
  61
           mov r7, #0x0000
          mov r8, #0x0000
          mov r10, #0x0000
          mov r11, #0x0000
          mov r12, #0x0000
mov r13, #0x0000
           mrs r1, cpsr
           msr spsr cxsf, r1
  69
mov 명령어가 여러 개 보인다.
```

mov r0, lr:

lr에 복귀주소(return address)가 저장되어 있으므로,

복귀주소를 r0 레지스터에 저장하는 코드라는 것을 알 수 있다.

mov r(x), #0x0000(x 1:13):

각 범용 레지스터(general purpose registers)들을 0으로 초기화하는 코드이다.

mrs r1, cpsr:

cpsr 레지스터에 있는 정보를 r1으로 읽어온다.

msr spsr\_cxsf, r1:

rl에 저장되어 있는 정보를 spsr\_cxsf 레지스터에 저장한다.

\*psr(cpsr, spsr)

### 3.7 Program status registers The processor contains one CPSR and five SPSRs for exception handlers to use. The program status registers: hold information about the most recently performed ALU operation control the enabling and disabling of interrupts set the processor operating mode Figure 3-4 shows the bit arrangement in the status registers. 16 15 NZCVQ GE[3:0] \_ Greater than or equal to Thumb state bit Java state bit IT[1:0] IRQ disable Asynchrono disable bit

Carry/Bor
 Zero
 Negative/

Figure 3-4 Program status register

Data endianness bit

데이터시트를 찾아보면, cpsr은 Current Program Status Register를 의미한다.

프로그램의 상태를 저장하는 레지스터임을 알 수 있다. spsr은 각 모드마다 1개씩 존재한다. spsr이 각 모드마다 존재하므로, 모드가 바뀔시 이전에 저장되었던 context를 따로 불러올 필요가 없어진다.

x86의 경우 context switching시 현재 context의 정보를 별도의 stack에 보관하고, return시 stack에 있는 context를 다시 불러왔기 때문에 불필요한 연산, 즉, overhead가 발생했다. ARM에서는 mode별 context를 고유의 spsr에 저장하기 때문에, context switching을 overhead 없이 빠르게 처리할 수 있게 한다.

### General registers and program counter

| System and User | FIQ      | Supervisor | Abort    | IRQ      | Undefined |
|-----------------|----------|------------|----------|----------|-----------|
| R0              | R0       | R0         | R0       | R0       | R0        |
| R1              | R1       | R1         | R1       | R1       | R1        |
| R2              | R2       | R2         | R2       | R2       | R2        |
| R3              | R3       | R3         | R3       | R3       | R3        |
| R4              | R4       | R4         | R4       | R4       | R4        |
| R5              | R5       | R5         | R5       | R5       | R5        |
| R6              | R6       | R6         | R6       | R6       | R6        |
| R7              | R7       | R7         | R7       | R7       | R7        |
| R8              | R8_fiq   | R8         | R8       | R8       | R8        |
| R9              | R9_fiq   | R9         | R9       | R9       | R9        |
| R10             | R10_fiq  | R10        | R10      | R10      | R10       |
| R11             | R11_fiq  | R11        | R11      | R11      | R11       |
| R12             | R12_fiq  | R12        | R12      | R12      | R12       |
| R13             | R13_fiq  | R13_svc    | R13_abt  | R13_irq  | R13_und   |
| R14             | R14_fiq  | R14_svc    | R14_abt  | R14_irq  | R14_und   |
| R15             | R15 (PC) | R15 (PC)   | R15 (PC) | R15 (PC) | R15 (PC)  |

| CPSR | CPSR     | CPSR     | CPSR     | CPSR     | CPSR     |
|------|----------|----------|----------|----------|----------|
|      | SPSR_fiq | SPSR_svc | SPSR_abt | SPSR_irq | SPSR_und |

= banked register

데이터시트를 더 찾아보면, 각 mode별로 범용 레지스터 또한 banked register로 가지고 있는 것을 알 수 있다.



다음 코드를 보면 code change를 하고 각 모드별 context를 초기화 하는 것을 할 수 있다.

위의 레지스터 정보를 보면, r0는 banked register가 아니기 때문에 Supervisor mode에서 연산했던 r0의 정보를 그대로 가지고 있을 것이다. 즉, r0에는 return address가 저장되어 있을 것이다.

cps #17:

mode를 17(0b10001)로 바꾼다. mode bit는 cpsr에 있으므로, cpsr의 mode bit를 변경하는 명령어가 된다.

## Table 3-3 PSR ode bit values

| M[4:0] | Mode |
|--------|------|
| b10000 | User |
| ь10001 | FIQ  |
| b10010 | IRQ  |

# Table 3-3 PSR ode bit values (continued)

| M[4:0] | Mode       |
|--------|------------|
| b10011 | Supervisor |
| b10111 | Abort      |
| b11011 | Undefined  |
| b11111 | System     |

datasheet를 보면, 0b10001은 FIQ mode라는 것을 알 수 있다.

이 과정을 반복하여, System mode의 context까지 모두 초기화해준다.

```
102
                 p15,
                           #0x00,
                                       r2,
           mrc
                                                 c1, c0, #0x02
                                       #0xF00000
                 r2,
                           r2,
                           #0x00,
                                                 c1, c0, #0x02
                 p15,
105
           mov
                 r2,
                           #0x40000000
106
           fmxr fpexc,
                          r2
```

다음 코드를 보면, mrc 명령어가 보인다.

To access the CPACR, read or write CP15 with:

MRC p15, 0, <Rd>, c1, c0, 2; Read CPACR

mrc p15, #0x00, r2, c1, c0, #0x02 :

datasheet를 검색해보면, 이 코드는 CPACR값을 읽어서 r2에 저장한다는 것을 알 수 있다. orr r2, r2, #0xF00000 :

읽어온 CPACR값에 0x00F0 0000값을 or하므로, 23:20번 bit를 1로 set한다는 것을 알 수 있다.

mcr p15, #0x00, r2, c1, c0, #0x02 :

r2 레지스터에 저장된 값을 CPACR 레지스터에 저장한다.

즉, 3줄의 코드는 CPACR 레지스터의 23:20번 bit를 1로 set하는 코드라 할 수 있다.

CPACR을 검색해보자.

| [23:22] | cp11 | Defines access permissions for the FPU.                                                                                                                 |
|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| [21:22] | cp10 | If the FPU is not included for this processor, these bits are RAZ/WI.  If the FPU is included, both cp10 and cp11 must be programmed to the same value: |
|         |      | b00 = Access denied. Attempts to access generates an Undefined Instruction exception. This is the reset value.                                          |
|         |      | b01 = Privileged mode access only                                                                                                                       |
|         |      | b10 = Reserved                                                                                                                                          |
|         |      | b11 = Privileged and User mode access.                                                                                                                  |

23:22 번 bit는 FPU에 대한 접근 허가를 정의한다고 써있다.

21:22 번 bit라고 써있는데, 오타인 듯 하다. 21:20으로 정정하자.

21:20 bit는 값에 따라 권한 설정을 한다는 것을 알 수 있다.

우리는 21:20 = 11 로 set했기 때문에, b11을 보자.

User mode와 Privileged mode 둘 다 접근을 허가한다고 써있다.

즉, 위의 3줄의 코드는 최종적으로 FPU를 정의하고 FPU에 대한 접근 권한을 설정하는 코드이다.

mov r2, #0x40000000

fmxr fpexc, r2:

위 2줄은 결국 fpexc에 0x40000000을 저장하는 코드가 된다.

즉, fpexc 레지스터의 30번 bit를 1로 set해준다.

| Bits   | Name | Function                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | -    | RAZ.                                                                                                                                                                                                                                                                                                                                                                                                              |
| [30]   | EN   | VFP enable bit. Setting EN enables VFP functionality. Reset clears EN.                                                                                                                                                                                                                                                                                                                                            |
| [29]   | DEX  | Set when an Undefined Instruction exception is taken because of a vector instruction that would have been executed if the processor supported vectors. This field is cleared when an Undefined Instruction exception is taken for any other reason. Resets to zero.  In single-precision only configurations, this bit is not set for any double-precision operations, whether they are vector operations or not. |
| [28:0] | 20   | RAZ.                                                                                                                                                                                                                                                                                                                                                                                                              |

30번 bit가 set되면, VFP를 사용할 수 있게 하고 다시 0으로 clear된다고 써있다.

In the FPU, you can view the register bank as

- Sixteen 64-bit doubleword registers, D0-D15
- Thirty-two 32-bit single-word registers, 50-S31. A combination of registers from these views.



Figure 11-1 FPU register bank

The mapping between the registers is as follows

- S<2n> maps to the least significant half of D<no
- 5<2n+1> maps to the most significant half of D<n>

For example, you can access the least significant half of the value in D6 by accessing 512, and the most significant half of the elements by accessing \$13.

FPU에 대한 설명을 읽어보면, D0~ D15까지 64bit의 레지스터 16개를 가지고 있음을 알 수 있다.

64bit이므로, 초기화를 하기 위해서는 32bit가 2개 필요하므로, 초기화는 아래와 같이 한다.

| 108 | fmdrr d0,  | r1, | r1 |
|-----|------------|-----|----|
| 109 | fmdrr d1,  | r1, | r1 |
| 110 | fmdrr d2,  | r1, | r1 |
| 111 | fmdrr d3,  | r1, | r1 |
| 112 | fmdrr d4,  | г1, | r1 |
| 113 | fmdrr d5,  | r1, | r1 |
| 114 | fmdrr d6,  | r1, | r1 |
| 115 | fmdrr d7,  | r1, | r1 |
| 116 | fmdrr d8,  | r1, | r1 |
| 117 | fmdrr d9,  | r1, | r1 |
| 118 | fmdrr d10, | r1, | r1 |
| 119 | fmdrr d11, | r1, | r1 |
| 120 | fmdrr d12, | г1, | r1 |
| 121 | fmdrr d13, | r1, | r1 |
| 122 | fmdrr d14, | r1, | r1 |
| 122 | fedor d15  | -01 | 01 |

이 뒤에 의미없어 보이는 코드들이 있는데, d0-d15를 초기화 하는 도중 b(branch)를 하게 되면 pipeline이 깨지게 되 므로 위 명령어들이 완료되는 동안 clock을 지연시키는 코드로 봐도 무방하다.

```
146_coreInitStackPointer_
147
           cps
ldr
149
                          figSp
                 #18
150
151
                 Sp.
                           irgSp
                 #19
                           svcSp
                 sp,
#23
          cps
1dr
                 sp,
#27
156
           cps
ldr
                sp,
#31
                          undefSp
           cps
ldr
159
                          userSp
161
162 userSp .word 0x08000000+0x00001000
           .word 0x08000000+0x00001000+0x00000100
163 svcSp
164 figSp
          165 irqSp
155 abort5p _word 0x08000000+0x00001000+0x00000100+0x00000100+0x00000100+0x000000100
167 undefSp .word 0x08000000+0x00001000+0x00000100+0x00000100+0x00000100+0x00000100+0x00000100+0x00000100
```

레지스터들을 초기화 한 후, Stack Pointer를 초기화하는 함수이다.

cps는 mode를 변경하는 명령어다.

sp 레지스터는 r14레지스터를 말하고,

r14레지스터는 Banked Register이므로 mode마다 각각 고유의 register를 가진다.



위와 같이 sp를 설정하는 함수가 된다. 실제 stack이 할당 되는 것은 아직 아니다. 예를 들면, user mode에서 stack을 사용시, 0x08001000을 기준으로 아래로 stack이 자라게 되고, abort mode에서 stack을 사용시, 0x08001400을 기준으로 아래로 stack이 자란다.

```
111 switch(getResetSource())
112 {
113     case POWERON_RESET:
114     case DEBUG_RESET:
115     case EXT_RESET:
return하고나면, getResetSource()를 호출하는 것을 볼 수 있다.
```

```
Getting Started
                   S HL_sys_core.asm
                                          C HL_sys_main.c S HL_sys_intvecs.asm
447 resetSource_t getResetSource(void)
448 {
 449
         register resetSource_t rst_source;
 450
         if ((SYS_EXCEPTION & (uint32)POWERON_RESET) != 0U)
 454
             rst source = POWERON RESET;
 455
             /* Clear all exception status Flag and proceed since it's power up */ \mbox{SYS\_EXCEPTION} = 0x0000FFFFU;
 457
 458
 459
         else if ((SYS_EXCEPTION & (uint32)EXT_RESET) != 0U)
              /* Reset caused due to External reset. */
 461
 462
              rst_source = EXT_RESET;
             SYS_EXCEPTION = (uint32)EXT_RESET;
 464
 465
         else if ((SYS_EXCEPTION & (uint32)DEBUG_RESET) !=0U)
 466
 467
              /* Reset caused due Debug reset request */
              rst source = DEBUG RESET
             SYS_EXCEPTION = (uint32)DEBUG_RESET;
 470
```

getResetSource()안에는 if문과 else if로 이루어진 switch ~ case: 문이 있고, rst\_source에 값을 넣어 리턴하는 형태이다.

```
124 #define SYS EXCEPTION (*(volatile uint32 *)0xFFFFFFE4U)
```

SYS\_EXCEPTION은 0xFFFFFFE4로 정의되어 있고, E4번 offset이 어떤 System Control Register인지 찾아보면,

E4h SYSESR System Exception Status Register Section 2.5.1.46

SYSESR 레지스터임을 알 수 있다.

Table 2-65. System Exception Status Register (SYSESR) Field Descriptions

| Bit   | Field                                    | Value | Description                                                                                                                                                                                                                   |
|-------|------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Reserved                                 | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                        |
| 15    | PORST                                    |       | Power-on reset. This bit is set when a power-on reset occurs, either internally asserted by the VMON or externally asserted by the nPORRST pin.                                                                               |
|       |                                          | 0     | No power-on reset has occurred since this bit was last cleared.                                                                                                                                                               |
|       |                                          | 1     | A reset was caused by a power-on reset. (This bit should be cleared after being read so that subsequent resets can be properly identified as not being power-on resets.)                                                      |
| 14    | OSCRST                                   |       | Reset caused by an oscillator failure or PLL cycle slip. This bit is set when a reset is caused by an oscillator failure or PLL slip. Write 1 will clear this bit. Write 0 has no effect.                                     |
|       |                                          |       | Note: The action taken when an oscillator failure or PLL slip is detected must configured in the PLLCTL1 register.                                                                                                            |
|       |                                          | 0     | No reset has occurred due to an oscillator failure or a PLL cycle slip.                                                                                                                                                       |
|       | A. A | 1     | A reset was caused by an oscillator failure or a PLL cycle slip.                                                                                                                                                              |
| 13    | WDRST                                    | 30    | Watchdog reset flag. This bit is set when the last reset was caused by the digital watchdog (DWD).<br>Write 1 will clear this bit. Write 0 has no effect.                                                                     |
|       |                                          | 0     | No reset has occurred because of the DWD.                                                                                                                                                                                     |
|       |                                          | 1     | A reset was caused by the DWD.                                                                                                                                                                                                |
| 12    | Reserved                                 | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                        |
| 11    | DBGRST                                   |       | Debug reset flag. This bit is set when the last reset was caused by the debugger reset request. Write 1 will clear this bit. Write 0 has no effect.                                                                           |
|       |                                          | 0     | No reset has occurred because of the debugger.                                                                                                                                                                                |
|       |                                          | - 1   | A reset was caused by the debugger.                                                                                                                                                                                           |
| 10-8  | Reserved                                 | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                        |
| 7     | ICSTRST                                  |       | Interconnect reset flag. This bit is set when the last CPU reset was caused by the entering and exiting of interconnect self-test check. While the interconnect is under self-test check, the CPU is also held in reset until |
|       |                                          | 0     | No CPUx reset has occurred because of an interconnect self-test check.                                                                                                                                                        |
|       |                                          | 1     | A reset has occurred to the CPUx because of the interconnect self-test check.                                                                                                                                                 |
| 6     | Reserved                                 | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                        |

SYSESR register의 description은 위와 같다. 필드 이름을 보니, Power,Ocillator,Watchdog,Debug 등이 reset이 될 때, 해당 비트가 set되는 register임을 알 수 있다.

분석하고 있는 것은 부트코드 이므로, PORST(15번 bit)가 1로 set되어있을 것이다. 코드로 돌아와서

```
POWERON_RESET = 0x8000U, /**< Alias for Power On Reset */
```

0x80000이므로, POWERON\_RESET은 15번bit를 의미하는 것을 알 수 있다.

if문들 중, 위의 code가 실행될 것이고,

rst\_source = 0x80000, SYS\_ECEPTION=0x0000FFFF;

가 저장되고, rst\_source가 return될 것이다.

getResetSource()의 return값이 POWERON\_RESET이므로, 제일 위쪽 코드부터 실행될 것이다.

제일 처음 보이는 함수는 \_memInit\_();이므로 해당 함수를 분석해보자

```
Getting Started

SHLsys_main.c

HLsys_main.c

HLsys_intvecs.asm

HLsys_main.c

HLsys_intvecs.asm

HLsys_intv
```

위 3줄은 MINITGCR 레지스터의 값을 r12로 가져오고,

1,3번 비트를 1로 set한 후 다시 MINITGCR 레지스터에 값을 넣는 것을 알 수 있다.

MINITGCR이 뭔지 검색해보자.

```
91 uint32 WINITGCR; /* 0x805C */
```

offset은 5c이고,

Table 2-40. Memory Hardware Initialization Global Control Register (MINITGCR) Field Descriptions

| Bit  | Field     | Value  | Description                                                                                                                                                                                         |
|------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | Reserved  | 0      | Reads return 0. Writes have no effect.                                                                                                                                                              |
| 3-0  | MINITGENA |        | Memory hardware initialization global enable key.                                                                                                                                                   |
|      |           | Ah     | Global memory hardware initialization is enabled.                                                                                                                                                   |
|      |           | Others | Global memory hardware initialization is disabled.                                                                                                                                                  |
|      |           |        | Note: It is recommended that a value of 5h be used to disable memory hardware initialization. This value will give maximum protection from an event that would inadvertently enable the controller. |

위 코드에서 MINITGCR에 0xA를 set해주었으므로, 메모리 하드웨어 초기화가 Enable 될 것이다.

```
601 Idr r11, MSIENA ;Load MSIENA register address
602 mov r4, #0x1 ;Bit position 0 of MSIENA corresponds to SRAM
603 str r4, [r11] ;Enable auto hardware initalisation for SRAM
```

다음 코드도 보니, MSIENA 레지스터의 0번 bit를 1로 set해준다는 것을 알 수 있다.

MSIENA를 찾아보자.

```
92 uint32 MSINENA; /* 0x0060 */
```

MSINENA의 오타인 듯 하다. MSIENA는 코드 내에서 정의를 찾을 수가 없다. 왜 정상동작하는지는 모르겠다.

Table 2-41. MBIST Controller/Memory Initialization Enable Register (MSINENA) Field Descriptions

| Bit       | Field  | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 MSIE | MSIENA |       | PBIST controller and memory initialization enable register. In memory self-test mode, all the corresponding bits of the memories to be tested should be set before enabling the global memory self-test controller key (MSTGENA) in the MSTGCR register (offset 58h). The reason for this is that MSTGENA, in addition to being the global enable for all individual PBIST controllers, is the source for the reset generation to all the PBIST controller state machines. Disabling the MSTGENA or MINITGENA key (by writing from an Ah to any other value) will reset all the MSIENA[31-0] bits to their default values. |
|           |        | 0     | In memory self-test mode (MSTGENA = Ah): PBIST controller [31-0] is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           |        |       | In memory Initialization mode (MINITGENA = Ah); Memory module [31-0] auto hardware initialization is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           |        | 1     | In memory self-test mode (MSTGENA = Ah): PBIST controller [31-0] is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           |        |       | In memory Initialization mode (MINITGENA = Ah): Memory module [31-0] auto hardware initialization is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           |        |       | Note: Software should ensure that both the memory self-test global enable key (MSTGENA) and the memory hardware initialization global key (MINITGENA) are not enabled at the same time.                                                                                                                                                                                                                                                                                                                                                                                                                                    |

0번 bit가 1로 Set되었고, 이 전에 MINITGENA 레지스터에 A값을 Set해줬으므로, Memory module[0] 의 auto hardware initialization이 enable된다. 주의사항도 한 번 읽어보면, 위의 두 옵션(self-test, initialization)이 동시에 일어나지 않도록 프로그램하라고 써있다.

604 mloop 605 ldr r5, MSTCGSTAT 606 ldr r4, [r5] 607 tst r4, #0x100 608 beg mloop

1 instruction만큼 덜 최적화된 코드이긴 하지만, MSTCGSTAT 레지스터 값을 읽어와서, 8번째 bit가 1이 될 때까지, Loop를 도는 형태로 되어있다. MSTCGSTAT의 8번째 bit가 뭔지 알아보자

Table 2-42. MSTC Global Status Register (MSTCGSTAT) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                           |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 31-9 | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                |
| 8    | MINIDONE | Î     | Memory hardware initialization complete status.                                                                       |
|      |          |       | Note: Disabiling the MINITGENA key (By writing from a Ah to any other value) will clear the MINIDONE status bit to 0. |
|      |          |       | Note: Individual memory initialization status is shown in the MINISTAT register.                                      |
|      |          | 0     | Read: Memory hardware initialization is not complete for all memory.                                                  |
|      |          |       | Write: A write of 0 has no effect.                                                                                    |
|      |          | 1     | Read: Hardware initialization of all memory is completed.                                                             |
|      |          |       | Write: The bit is cleared to 0.                                                                                       |
| 7-1  | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                |
| 0    | MSTDONE  | 1     | Memory self-test run complete status.                                                                                 |
|      |          |       | Note: Disabling the MSTGENA key (by writing from a Ah to any other value) will clear the MSTDONE status bit to 0.     |
|      |          | 0     | Read: Memory self-test is not completed.                                                                              |
|      |          | : 10  | Write: A write of 0 has no effect.                                                                                    |
|      |          | 1     | Read: Memory self-test is completed.                                                                                  |
|      |          |       | Write: The bit is cleared to 0.                                                                                       |

8번의 read값이 1이라는 것은, 하드웨어의 모든 메모리 초기화가 완료되었다는 뜻이다.

즉, 위의 loop문은 하드웨어가 초기화될 때까지 대기하는 코드가 된다.

610 mov r4, #5 611 str r4, [r12] ;Disable global memory hardware initialization 612 bx lr

다음 코드는 r12, 즉 MINITGCR 레지스터에 5값(0b0101)을 set 하고 복귀주소로 return하는 코드이다.

Table 2-40. Memory Hardware Initialization Global Control Register (MINITGCR) Field Descriptions

| Bit  | Field     | Value  | Description                                                                                                                                                                                         |
|------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4 | Reserved  | 0      | Reads return 0. Writes have no effect.                                                                                                                                                              |
| 3-0  | MINITGENA |        | Memory hardware initialization global enable key.                                                                                                                                                   |
|      |           | Ah     | Global memory hardware initialization is enabled.                                                                                                                                                   |
|      | 1 1       | Others | Global memory hardware initialization is disabled.                                                                                                                                                  |
|      |           |        | Note: It is recommended that a value of 5h be used to disable memory hardware initialization. This value will give maximum protection from an event that would inadvertently enable the controller. |

0b0101은 0xA가 아니므로, 하드웨어 초기화를 disable해주는 코드가 된다. 한 번 초기화를 했으니, 다시 초기화할 필요가 없기 때문에 초기화 옵션을 꺼준다.

다음 함수는 \_coreEnableEventBusExport\_(); 다.

명령어 4개짜리 함수인데, c9, c12, 0에 해당하는 CoProcessor의 4번 bit에 1을 set해주는 코드가 된다. c9, c12, 0을 검색해보자

The PMCR Register is always accessible in Privileged mode. To access the register, read or write CP15 with:

MRC p15, 0, <Rd>, c9, c12, 0 ; Read PMCR Register MCR p15, 0, <Rd>, c9, c12, 0 ; Write PMCR Register

PMCR 레지스터의 4번 bit가 뭔지 찾아보자.

Table 21-36. Page Mode Control Register (PMCR) Field Descriptions

| Bit   | Field        | Value | Description                                                                                                                                                                    |
|-------|--------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-26 | CS5_PG_DEL   | 1-3Fh | Page access delay for NOR Flash connected on CS5. CS5 is not available on this device.                                                                                         |
| 25    | CS5_PG_SIZE  |       | Page Size for NOR Flash connected on CS5. CS5 is not available on this device.                                                                                                 |
| 24    | CS5_PG_MD_EN |       | Page Mode enable for NOR Flash connected on CS5. CS5 is not available on this device.                                                                                          |
| 23-18 | CS4_PG_DEL   | 1-3Fh | Page access delay for NOR Flash connected on CS4. Number of EMIF_CLK cycles required for the page read data to be valid, minus one cycle. This value must not be cleared to 0. |
| 17    | CS4_PG_SIZE  |       | Page Size for NOR Flash connected on CS4.                                                                                                                                      |
|       |              | 0     | Page size is 4 words                                                                                                                                                           |
|       |              | 1     | Page size is 8 words                                                                                                                                                           |
| 16    | CS4_PG_MD_EN | 1     | Page Mode enable for NOR Flash connected on CS4.                                                                                                                               |
|       | not the see  | 0     | Page mode disabled for this chip select                                                                                                                                        |
|       |              | 1     | Page mode enabled for this chip select                                                                                                                                         |
| 15-10 | CS3_PG_DEL   | 1-3Fh | Page access delay for NOR Flash connected on CS3. Number of EMIF_CLK cycles required for the page read data to be valid, minus one cycle. This value must not be cleared to 0. |
| 9     | CS3_PG_SIZE  |       | Page Size for NOR Flash connected on CS3.                                                                                                                                      |
|       |              | 0     | Page size is 4 words                                                                                                                                                           |
|       |              | 1     | Page size is 8 words                                                                                                                                                           |
| 8     | CS3_PG_MD_EN |       | Page Mode enable for NOR Flash connected on CS3.                                                                                                                               |
|       | 342 345 34   | 0     | Page mode disabled for this chip select                                                                                                                                        |
|       |              | . 1   | Page mode enabled for this chip select                                                                                                                                         |
| 7-2   | CS2_PG_DEL   | 1-3Fh | Page access delay for NOR Flash connected on CS2. Number of EMIF_CLK cycles required for the page read data to be valid, minus one cycle. This value must not be cleared to 0. |
| 1     | CS2_PG_SIZE  |       | Page Size for NOR Flash connected on CS2.                                                                                                                                      |
|       |              | 0     | Page size is 4 words                                                                                                                                                           |
|       |              | 1     | Page size is 8 words                                                                                                                                                           |
| 0     | CS2_PG_MD_EN | *     | Page Mode enable for NOR Flash connected on CS2.                                                                                                                               |
|       |              | 0     | Page mode disabled for this chip select                                                                                                                                        |
|       |              | 1     | Page mode enabled for this chip select                                                                                                                                         |

7:2 bit는 Page에 접근하는 데 필요한 delay를 설정해주는 bit인 것 같다. 0이 되면 안된다고 써있다.

```
Getting Started SHL_sys_core.asm HL_sys_main.c SHL

146 if ((esmREG->SR1[2]) != 0U)

147 {
    esmGroup3Notification(esmREG,esmREG->SR1[2]);

149 }
```

다음 코드인데, esmReg->SR1[2]가 뭔지 알아보자.

```
78 uint32 SR1[3U]; /* 0x0018, 0x001C, 0x0020 */
```

SR1[2] 이므로, offset은 0x0020이 된다.

Table 16-11. ESM Status Register 3 (ESMSR3) Field Descriptions

| Bit  | Field    | Value | Description                                                        |  |
|------|----------|-------|--------------------------------------------------------------------|--|
| 31-0 | ESF3     |       | Error Status Flag. Provides status information on a pending error. |  |
|      | donovene |       | Read in User and Privileged mode. Write in Privileged mode only.   |  |
|      |          | 0     | Read: No error occurred.                                           |  |
|      |          |       | Write: Leaves the bit unchanged.                                   |  |
|      |          | 31    | Read: Error occurred.                                              |  |
|      |          |       | Write: Clears the bit.                                             |  |

위 코드에서 ESMSR3 레지스터가 0이 아닐 경우, if문 안에 있는 함수를 호출한다. ESMSR3 레지스터는 에러가 발생할 경우만 1이므로, read값은 0이 될 것이다. 따라서 if문은 건너뛰고 다음 코드를 살펴보자.

```
systemInit();

339 void systemInit(void)
340 {
341 /* USER CODE BEGIN (15) */
342 /* USER CODE END */
343

44  /* Configure PLL control registers and enable PLLs.
345  * The PLL takes (127 + 1024 * NR) oscillator cycles to acquire lock.
346  * This initialization sequence performs all the tasks that are not
347  * required to be done at full application speed while the PLL locks.
348  */
349  setupPLL();
```

CSDISSET 레지스터에 0x00000042값을 set해준다. 즉, 1번,6번 bit를 1로 set한다.

Table 2-30. Clock Source Disable Set Register (CSDISSET) Field Descriptions

| Bit  | Field            | Value | Description                                                                                                                                                                                                                              |
|------|------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | Reserved         | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                   |
| 7-3  | SETCLKSR[7-3]OFF |       | Set clock source[7-3] to the disabled state.                                                                                                                                                                                             |
|      |                  | 0     | Read: Clock source[7-3] is enabled.                                                                                                                                                                                                      |
|      |                  |       | Write: Clock source[7-3] is unchanged.                                                                                                                                                                                                   |
|      |                  | 1     | Read: Clock source[7-3] is disabled.                                                                                                                                                                                                     |
|      |                  | 1.0   | Write: Clock source[7-3] is set to the disabled state.                                                                                                                                                                                   |
|      |                  |       | Note: After a new clock source disable bit is set via the CSDISSET register, the new status of the bit will be reflected in the CSDIS register (offset 30h), the CSDISSET register (offset 34h), and the CSDISCLR register (offset 38h). |
| 2    | Reserved         | 1     | Reads return 1. Writes have no effect.                                                                                                                                                                                                   |
| 1-0  | SETCLKSR[1-0]OFF |       | Set clock source[1-0] to the disabled state.                                                                                                                                                                                             |
|      | 17 .551          | 0     | Read: Clock source[1-0] is enabled.                                                                                                                                                                                                      |
|      |                  |       | Write: Clock source[1-0] is unchanged.                                                                                                                                                                                                   |
|      |                  | 1     | Read: Clock source[1-0] is disabled.                                                                                                                                                                                                     |
|      |                  |       | Write: Clock source[1-0] is set to the disabled state.                                                                                                                                                                                   |
|      |                  |       | Note: After a new clock source disable bit is set via the CSDISSET register, the new status of the bit will be reflected in the CSDIS register (offset 30h), the CSDISSET register (offset 34h), and the CSDISCLR register (offset 38h). |

clock source[1], clock source[6]을 disabled state로 설정한다.

Table 2-28. Clock Source Disable Register (CSDIS) Field Descriptions

| Bit  | Field                       | Value | Description                                                  |  |
|------|-----------------------------|-------|--------------------------------------------------------------|--|
| 31-8 | Reserved                    | 0     | Reads return 0. Writes have no effect.                       |  |
| 7-3  | CLKSR[7-3]OFF               |       | Clock source[7-3] off.                                       |  |
|      | Name of the second          | 0     | Clock source[7-3] is enabled.                                |  |
|      |                             | 1     | Clock source[7-3] is disabled.                               |  |
|      |                             |       | Note: On wakeup, only clock sources 0, 4, and 5 are enabled. |  |
| 2    | Reserved                    | 1     | eads return 1. Writes have no effect.                        |  |
| 1-0  | CLKSR[1-0]OFF               |       | Clock source[1-0] off.                                       |  |
|      | NOT THE OWNER OF THE OWNER. | 0     | Clock source[1-0] is enabled.                                |  |
|      |                             | 1     | Clock source[1-0] is disabled.                               |  |
|      |                             |       | Note: On wakeup, only clock sources 0, 4, and 5 are enabled. |  |

while문은 clock source[1],clock source[6]이 정상적으로 disable state로 설정될 때까지 기다리는 코드다.

```
87 /* Clear Global Status Register */
88 systemREG1->GBLSTAT = 0x301U;
```

GBLSTAT 레지스터에 0x301를 set한다. 0,8,9번 bit를 1로 set한다.

Table 2-67. Global Status Register (GLBSTAT) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                              |
|-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10 | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                                                                                   |
| 9     | FBSLIP   | 0     | PLL over cycle slip detection. (cleared by nPORRST, maintains its previous value for all other resets).  Read: No PLL over cycle slip has been detected.  Write: The bit is unchanged.   |
|       |          | 1     | Read: A PLL over cycle slip has been detected.  Write: The bit is cleared to 0.                                                                                                          |
| 8     | RFSLIP   | 0     | PLL under cycle slip detection. (cleared by nPORRST, maintains its previous value for all other resets<br>Read: No PLL under cycle slip has been detected.  Write: The bit is unchanged. |
|       |          | 1     | Read: A PLL under cycle slip has been detected.  Write: The bit is cleared to 0.                                                                                                         |
| 7-1   | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                                                                                   |
| 0     | OSCFAIL  | 0     | Oscillator fall flag bit. (cleared by nPORRST, maintains its previous value for all other resets).  Read: No oscillator failure has been detected.  Write: The bit is unchanged.         |
|       |          | 1     | Read: An oscillator failure has been detected.  Write: The bit is cleared to 0.                                                                                                          |

0,8,9번을 1로 write하면, 0으로 바뀌면서 아무 일도 일어나지 않는다.

0,8,9번이 set되어 있다는 것은, 각각의 bit에 해당하는 에러가 발생했다는 뜻이므로, 에러 플래그를 초기화하는 코드가 된다.

```
101 systemREG1->PLLCTL1 = (uint32)0x00000000U

102 | (uint32)0x20000000U

103 | (uint32)((uint32)0x1FU << 24U)

104 | (uint32)0x00000000U

105 | (uint32)((uint32)(8U - 1U)<< 16U)

106 | (uint32)(0x9500U);
```

PLLCTL1 = 0x2000 0000 | 0x1F00 0000 | 0x0007 0000 | 0x0000 9500 = 0x3F07 9500

29,28 27,26,25,24 18,17,16 15,12 10,8번 bit 1로 set

|       |           |        | Note: BPOS (Bits 30-29) must also be enabled for ROS to be enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30-29 | BPOS      |        | Bypass of PLL Slip.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |           | 2h     | Bypass on PLL Slip is disabled. If a PLL Slip is detected no action is taken.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |           | Others | Bypass on PLL Slip is enabled. If a PLL Slip is detected the device will automatically bypass the PLL and use the oscillator to provide the device clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |           |        | Note: If ROS (Bit 31) is set to 1, the device will be reset if a PLL Slip and the PLL will be bypassed after the reset occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 28-24 | PLLDIV    |        | PLL Output Clock Divider                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |           |        | $R = PLLDIV + 1$ $f_{PLL CLF} = f_{post_ODCLK} / R$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |           | 0      | f <sub>PLL CLK</sub> = f <sub>post-OOCLK</sub> / 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |           | 1h     | f PLL CLK = f post-COCLK / 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |           |        | De de management de la disconsideration de la |
|       |           | 1Fh    | f <sub>PLL CLK</sub> = f <sub>post-ODCLK</sub> / 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23    | ROF       |        | Reset on Oscillator Fail.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |           | 0      | Do not reset system when oscillator is out of range.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |           | 1      | The ROF bit enables the OSC_FAIL condition to generate a system reset. If the ROF bit in the PLLCTL1 register is set when the oscillator fails, then a system reset occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 22    | Reserved  | 0      | Value has no effect on PLL operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 21-16 | REFCLKDIV |        | Reference Clock Divider                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |           |        | NR = REFCLKDIV + 1<br>f NT CLR = f OBCIN / NR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |           | 0      | f NT CLX = f OSCIN / 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |           | 1h     | f <sub>NT CLM</sub> = f <sub>OSCIN</sub> / 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |           | 3      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |           | 3Fh    | f <sub>INT CLK</sub> = f <sub>OSCIN</sub> / 64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15-0  | PLLMUL    |        | PLL Multiplication Factor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |           |        | NF = (PLLMUL / 256) + 1, valid multiplication factors are from 1 to 256.<br>$f_{\text{VOO CLK}} = f_{\text{INT-CLK}} \times \text{NF}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |           | Oh     | f voo cik= f int cik x 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |           | 100h   | f voo clk = f int clk x 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       |           | 35     | Township of the contract                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |           | 5B00h  | f voo clk = f int clk x 92                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |           | 5C00h  | f <sub>VCO CLK</sub> = f <sub>INT CLK</sub> x 93                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       |           | 4      | *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |           | FF00h  | f <sub>vco cik</sub> = f <sub>int cik</sub> x 256                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

29번 bit : 2가 아니므로, PLL Slip에서 바이패스를 허용한다.

28:24번 bit : 1F이므로  $_{LLCLK} = f_{\ ostODCLK}/32$ 

18:16번 bit : 7이므로  $f_{\mathit{CLK}} = f_{\mathit{OSCIN}}/8$ 

15:0번 bit : 0x9500==149이므로  $f_{VCOCLK} = f_{CLK}/150$ 

```
114 systemREG1->PLLCTL2 = (uint32)((uint32)255U << 22U)
115 | (uint32)((uint32)7U << 12U)
116 | (uint32)((uint32)(1U - 1U) << 9U)
117 | (uint32)61U;
```

PLLCTL2 = 0x3FC0 0000 | 0x0000 7000 | 0x0000 00(0011)(1101)

29,28 27,26,24,23 22,21 14,13,12 5,4,3,2,0 1로 set, 9번 bit clear.

| Bit   | Field           | Value      | Description                                                                                                                                                                                                                                                  |
|-------|-----------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | FMENA           |            | Frequency Modulation Enable.                                                                                                                                                                                                                                 |
|       | S-247-84.000-73 | 0          | Disable frequency modulation.                                                                                                                                                                                                                                |
|       |                 | 1          | Enable frequency modulation.                                                                                                                                                                                                                                 |
| 30-22 | SPREADINGRATE   |            | NS = SPREADINGRATE + 1                                                                                                                                                                                                                                       |
|       |                 | 50.1       | $f_{\text{mod}} = f_{\text{s}} = f_{\text{NT CLK}}/(2 \times \text{NS})$                                                                                                                                                                                     |
|       |                 | 0          | $f_{mod} = f_s = f_{INT CLK} / (2 \times 1)$                                                                                                                                                                                                                 |
|       |                 | 1h         | $f_{mod} = f_s = f_{INT CLK} / (2 \times 2)$                                                                                                                                                                                                                 |
|       |                 | - 1        | 1                                                                                                                                                                                                                                                            |
|       |                 | 1FFh       | $f_{mod} = f_s = f_{INT CLK} / (2 \times 512)$                                                                                                                                                                                                               |
| 21    | Reserved        | 0          | Value has no effect on PLL operation.                                                                                                                                                                                                                        |
| 20-12 | MULMOD          |            | Multiplier Correction when Frequency Modulation is enabled.                                                                                                                                                                                                  |
|       |                 |            | When FMENA = 0, MUL_when_MOD = 0; when FMENA = 1, MUL_when_MOD = (MULMOD / 256)                                                                                                                                                                              |
|       |                 | 0          | No adder to NF.                                                                                                                                                                                                                                              |
|       |                 | 8h         | MUL_when_MOD = 8/256                                                                                                                                                                                                                                         |
|       |                 | 9h         | MUL_when_MOD = 9/256                                                                                                                                                                                                                                         |
|       |                 | - 8        | 5                                                                                                                                                                                                                                                            |
|       |                 | 1FFh       | MUL_when_MOD = 511/256                                                                                                                                                                                                                                       |
| 11-9  | ODPLL           | 1,000.4    | Internal PLL Output Divider                                                                                                                                                                                                                                  |
|       |                 |            | OD = ODPLL + 1                                                                                                                                                                                                                                               |
|       |                 |            | f post-DDCLK= f VCO CLK/OD                                                                                                                                                                                                                                   |
|       |                 |            | Note: PLL output clock is gated off, if ODPLL is changed while the PLL is active.                                                                                                                                                                            |
|       |                 | 0          | f post-ODCLK = f VCO CLK / 1                                                                                                                                                                                                                                 |
|       |                 | 1h         | f post-DDGLK= f VCD CLK / 2                                                                                                                                                                                                                                  |
|       |                 | 123        | 1                                                                                                                                                                                                                                                            |
|       |                 | 7h         | f post-DDCLK <sup>®</sup> f VCD CLK / 8                                                                                                                                                                                                                      |
| 8-0   | SPR_AMOUNT      |            | Spreading Amount                                                                                                                                                                                                                                             |
|       |                 |            | NV = (SPR_AMOUNT + 1)/2048                                                                                                                                                                                                                                   |
|       |                 |            | NV ranges from 1/2048 to 512/2048                                                                                                                                                                                                                            |
|       |                 |            | Note that the PLL output clock is disabled for 1 modulation period, if the SPR_AMOUNT field is changed while the frequency modulation is enabled. If frequency modulation is disabled and SPR_AMOUNT is changed, there is no effect on the PLL output clock. |
|       |                 | 0          | NV = 1/2048                                                                                                                                                                                                                                                  |
|       |                 | 1h         | NV = 2/2048                                                                                                                                                                                                                                                  |
|       |                 |            | CPC CONNECTOR                                                                                                                                                                                                                                                |
|       |                 | 1FFh       | NV = 512/2048                                                                                                                                                                                                                                                |
|       | . 0 (( 5) = 3   | 600 (1959) |                                                                                                                                                                                                                                                              |

30-22 : 0xff 이므로  $mod = f = f_{LK}/512$ 

20-12 : 7이므로 no function

11-9 : 0이므로  $f_{postODCLK} = f_{VCOCLK}/1$ 

8-0:61이므로 NV = 62/2048

```
127
128
               systemREG2->PLLCTL3 = (uint32)((uint32)(1U - 1U) << 29U)
127 systemked2->PLCC163 = (uint32)((uint32)(x160 - 10) << 240)
128  | (uint32)((uint32)(x170 << 240)
129  | (uint32)((uint32)(x170 - 10) << 160)
130  | (uint32)(x170 - 10) << 160)
129번 bit clear, 28,27,26,25,24번 bit set, 0x0007 0000 set, 0x0000 9500 set
```

| Bit   | Field      | Value | Description                                                                                   |
|-------|------------|-------|-----------------------------------------------------------------------------------------------|
| 31-29 | ODPLL2     |       | Internal PLL Output Divider                                                                   |
|       |            |       | OD2 = ODPLL2 + 1, ranges from 1 to 8.                                                         |
|       |            |       | f <sub>post_COCLH2</sub> = f <sub>output_CLH2</sub> / GD2                                     |
|       |            |       | Note: PLL output clock is gated off if ODPLL2 is changed while the PLL#2 is active.           |
|       |            | 0     | $f_{post_COCCLK2} = f_{output_CLK2/1}$                                                        |
|       |            | 1h    | f <sub>post_ODCLK2</sub> = f <sub>output_CLK2 / 2</sub>                                       |
|       |            | 3     | 1                                                                                             |
|       |            | 7h    | f <sub>post</sub> cocks = f <sub>output</sub> cks / 8                                         |
| 28-24 | PLLDIV2    |       | PLL2 Output Clock Divider                                                                     |
|       |            |       | R2 = PLLDIV2 + 1, ranges from 1 to 32.                                                        |
|       |            |       | $f_{PLL2 CLK} = f_{post_ODCLK2} / R2$                                                         |
|       |            | 0     | f <sub>PLL2 CLK</sub> = f <sub>post_ODCLK2</sub> / 1                                          |
|       |            | 1h    | $f_{\text{PLL2 CLK}} = f_{\text{post ODCLK2}} / 2$                                            |
|       |            | (4    | PS-3200CO 100 TANKS 00 Y                                                                      |
|       |            | 1Fh   | f <sub>PLL2 CLK</sub> = f <sub>post_ODCLK2</sub> / 32                                         |
| 23-22 | Reserved   | 0     | Value has no effect on PLL operation,                                                         |
| 21-16 | REFCLKDIV2 | - 1   | Reference Clock Divider                                                                       |
|       |            |       | NR2 = REFCLKDIV2 + 1, ranges from 1 to 64.<br>f <sub>INTCLKZ</sub> = f <sub>OSCIN</sub> / NR2 |
|       |            |       | Note: This value should not be changed while the PLL2 is active.                              |
|       |            | 0     | f <sub>INTOLK2</sub> = f <sub>OSCIN</sub> / 1                                                 |
|       |            | 1h    | $f_{\text{INTCLK2}} = f_{\text{OSCIN}} / 2$                                                   |
|       |            | 3500  | Section of Automotives                                                                        |
|       |            | 3Fh   | $f_{\text{INTCLK2}} = f_{\text{DSCIN}} / 64$                                                  |
| 15-0  | PLLMUL2    | 1     | PLL2 Multiplication Factor                                                                    |
|       |            |       | NF2 = (PLLMUL2 / 256) + 1, valid multiplication factors are from 1 to 256.                    |
|       |            |       | $f_{VCOCLK2} = f_{INTCLK2} \times NF2$                                                        |
|       |            |       | User and privileged mode (read):                                                              |
|       |            |       | Privileged mode (write):                                                                      |
|       |            | 100h  | f <sub>VCOCLK2</sub> = f <sub>INTCLK2</sub> x 1                                               |
|       |            | - 3   | Transmiss Indicators                                                                          |
|       |            | 5B00h | f <sub>MCOCLK2</sub> = f <sub>INTCLK2</sub> x 92                                              |
|       |            | 5C00h | f <sub>VCCCLR2</sub> × 93                                                                     |
|       |            | 11    |                                                                                               |
|       |            | FF00h | f <sub>MCOCLE2</sub> = f <sub>INTCLE2</sub> x 256                                             |

31-29:  $_{ost}$   $_{DCLK2} = f_{OUTPUTCLK2}/1$ 

 $28\text{-}24\ :\ f_{PLL2CLK} = f_{POSTODCLK2}/32$ 

21-16 :  $f_{CLK2} = f_{OSCIN}/8$ 

15-0:  $f_{VCOCLK2} = f_{CLK2} * 150$ 

로 PLL1, PLL2, PLL3의 clock 등을 설정해준다.

systemREG1->CSDIS = 0x00000000U 0x00000008U 0x00000080U 0x00000000U 0x00000000U 0x00000000U 0x00000004U;

CSDIS = 0x0000008C 이므로 2,3,7번 bit를 1로 set해준다.

### Table 2-28. Clock Source Disable Register (CSDIS) Field Descriptions

| Bit  | Field         | Value | Description                                                  |  |
|------|---------------|-------|--------------------------------------------------------------|--|
| 31-8 | Reserved      | 0     | Reads return 0. Writes have no effect.                       |  |
| 7-3  | CLKSR[7-3]OFF |       | Clock source[7-3] off.                                       |  |
|      |               | 0     | Clock source[7-3] is enabled.                                |  |
|      |               | 1     | Clock source[7-3] is disabled.                               |  |
|      |               |       | Note: On wakeup, only clock sources 0, 4, and 5 are enabled. |  |
| 2    | Reserved      | 1     | Reads return 1. Writes have no effect.                       |  |
| 1-0  | CLKSR[1-0]OFF |       | Clock source[1-0] off.                                       |  |
|      |               | 0     | Clock source[1-0] is enabled.                                |  |
|      |               | 1     | Clock source[1-0] is disabled.                               |  |
|      |               |       | Note: On wakeup, only clock sources 0, 4, and 5 are enabled. |  |

Clock Source 3번과 7번을 disabled 해준다.

Table 2-29. Clock Sources Table

| Clock Source # | Clock Source Name                               |
|----------------|-------------------------------------------------|
| Clock Source 0 | Oscillator                                      |
| Clock Source1  | PLL1                                            |
| Clock Source 2 | Not Implemented                                 |
| Clock Source 3 | EXTCLKIN                                        |
| Clock Source 4 | Low Frequency LPO (Low Power Oscillator) clock  |
| Clock Source 5 | High frequency LPO (Low Power Oscillator) clock |
| Clock Source 6 | PLL2                                            |
| Clock Source 7 | EXTCLKIN2                                       |

EXTCLKIN과 EXTCLKIN2가 disabled 되는 것인데, 뭔지 검색이 안되긴 해도 외부 clock 입력을 막는 것이라는 것으로 추측할 수는 있다

```
Getting Started
               8355
         * Enable clocks to peripherals and release peripheral reset */
 356
        periphInit();
그 다음 줄에 periphInit()함수가 있으니 들어가보자
Getting Started
                 S HL_sys_core.asm
        /** - Disable Peripherals before peripheral p
 218
 219
        systemREG1->CLKCNTL &= 0xFFFFFEFFU;
 220
 221
        /** - Release peripherals from reset and enab
        /** - Power-up all peripherals *,
 222
        pcrREG1->PSPWRDWNCLR0 = 0xFFFFFFFFU;
 223
        pcrREG1->PSPWRDWNCLR1 = 0xFFFFFFFFU;
 224
 225
        pcrREG1->PSPWRDWNCLR2 = 0xFFFFFFFFU;
 226
        pcrREG1->PSPWRDWNCLR3 = 0xFFFFFFFFU;
 227
 228
        pcrREG2->PSPWRDWNCLR0 = 0xFFFFFFFFU;
        pcrREG2->PSPWRDWNCLR1 = 0xFFFFFFFFU;
 229
 230
        pcrREG2->PSPWRDWNCLR2 = 0xFFFFFFFFU;
 231
        pcrREG2->PSPWRDWNCLR3 = 0xFFFFFFFFU;
 232
 233
        pcrREG3->PSPWRDWNCLR0 = 0xFFFFFFFFU;
 234
        pcrREG3->PSPWRDWNCLR1 = 0xFFFFFFFFU;
        pcrREG3->PSPWRDWNCLR2 = 0xFFFFFFFFU;
 235
 236
        pcrREG3->PSPWRDWNCLR3 = 0xFFFFFFFFU;
 237
 238
        /** - Enable Peripherals */
 239
        systemREG1->CLKCNTL |= 0x00000100U;
```

뭔가 많아보이지만, 이름이 똑같고 0.1.2.3으로 다른 애들이 있으니 금방 할 수 있을 것 같다. CLKCNTL &= 0xFFFFFEFF; 이므로, CLKCNTL의 8번 비트를 0으로 clear해주는 코드이다. CLKCNTL의 정의부로 들어가서 offset을 본 후, 8번 비트가 어떤 역할을 하는지 알아보자. 이름을 보니, clcok을 control하는 녀석인 듯 하다.

```
120 uint32 CLKCNTL; /* 0x00D0 */
```

Table 2-61. Clock Control Register (CLKCNTL) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                         |  |  |
|-------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31-28 | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                              |  |  |
| 27-24 | VCLK2R   |       | VBUS clock2 ratio.                                                                                                                                                                                                                                  |  |  |
|       |          |       | Note: The VCLK2 frequency must always be greater than or equal to the VCLK frequency.<br>The VCLK2 frequency must be an integer multiple of the VCLK frequency. In addition, the<br>VCLK and VCLK2 clock ratios must not be changed simultaneously. |  |  |
|       |          | 0     | The VCLK2 speed is HCLK divided by 1.                                                                                                                                                                                                               |  |  |
|       |          | 51    | 2                                                                                                                                                                                                                                                   |  |  |
|       |          | Fh    | The VCLK2 speed is HCLK divided by 16.                                                                                                                                                                                                              |  |  |
| 23-20 | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                              |  |  |
| 19-16 | VCLKR    |       | VBUS clock ratio.                                                                                                                                                                                                                                   |  |  |
|       |          |       | Note: The VCLK2 frequency must always be greater than or equal to the VCLK frequency.<br>The VCLK2 frequency must be an integer multiple of the VCLK frequency. In addition, the<br>VCLK and VCLK2 clock ratios must not be changed simultaneously. |  |  |
|       |          | 0     | The VCLK speed is HCLK divided by 1.                                                                                                                                                                                                                |  |  |
|       |          |       | 1                                                                                                                                                                                                                                                   |  |  |
|       |          | Fh    | The VCLK speed is HCLK divided by 16.                                                                                                                                                                                                               |  |  |
| 15-9  | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                              |  |  |
| 8     | PENA     |       | Peripheral enable bit. The application must set this bit before accessing any peripheral.                                                                                                                                                           |  |  |
|       |          | 0     | The global peripheral/peripheral memory frames are in reset.                                                                                                                                                                                        |  |  |
|       |          | 1     | All peripheral/peripheral memory frames are out of reset.                                                                                                                                                                                           |  |  |
| 7-0   | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                              |  |  |

8번 bit가 0으로 clear되면, 모든 peripheral과 peripheral memory frames의 reset을 가능하게 한다. 즉, 이 뒤로 peripheral을 reset하기 위한 코드가 있을 것이다 라고 추측은 할 수 있다. 다음 코드는 PSPWRDWNCLR0=0xFFFFFFFF;인데, 일단 검색이 안된다. PCR 레지스터 목록을 찾은 뒤, offset을 통해 찾아보자.

```
96 uint32 PSPWRDWNCLR0; /* 0x00A0 */
```

Table 2-106. Peripheral Power-Down Clear Register 0 (PSPWRDWNCLR0) Field Descriptions

| Bit  | Field            | Value | Description                                                                              |
|------|------------------|-------|------------------------------------------------------------------------------------------|
| 31-0 | PS[7-0]QUAD[3-0] |       | Peripheral select quadrant clock power-down clear.                                       |
|      | PWRDWNCLR        | 0     | Read: The clock to the peripheral select quadrant is active.                             |
|      |                  |       | Write: The bit is unchanged.                                                             |
|      |                  | .1    | Read: The clock to the peripheral select quadrant is inactive.                           |
|      |                  |       | Write: The corresponding bit in PSPWRDWNSET0 and PSPWRDWNCLR0 registers is cleared to 0. |

이름이 다른 것도 아닌데, 검색이 안된 이유는 모르겠다. 검색이 되지 않아도 다른 방법을 통해 찾아보도록 하자. 이 레지스터를 1로 set하면, PSPWRDNSET 레지스터와 이 레지스터의 해당되는 bit가 0으로 clear된다. PSPWRDNSET을 찾아보자. 나머지 PCR2, PCR3도 같은 코드들이다.

Table 2-102. Peripheral Power-Down Set Register 0 (PSPWRDWNSET0) Field Descriptions

| Bit  | t Field Value                 |      | Description                                                                          |  |  |  |  |  |
|------|-------------------------------|------|--------------------------------------------------------------------------------------|--|--|--|--|--|
| 31-0 | PS[7-0]QUAD[3-0]<br>PWRDWNSET | 1000 | Peripheral select quadrant clock power-down set.                                     |  |  |  |  |  |
|      | FWINDWINGET                   | 0    | Read: The clock to the peripheral select quadrant is active.                         |  |  |  |  |  |
|      |                               |      | Write: The bit is unchanged.                                                         |  |  |  |  |  |
|      |                               | 1    | Read: The clock to the peripheral select quadrant is inactive.                       |  |  |  |  |  |
|      |                               |      | Write: The corresponding bit in PSPWRDWNSET0 and PSPWRDWNCLR0 registers is set to 1. |  |  |  |  |  |

마지막 코드는 CLKCNTL |= 0x00000100;이니 clear했던 8번 bit를 1로 set해준다.

Table 2-61. Clock Control Register (CLKCNTL) Field Descriptions

| Bit   | Field                                   | Value | Description                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|-------|-----------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 31-28 | Reserved                                | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                              |  |  |  |  |  |  |
| 27-24 | VCLK2R                                  |       | VBUS clock2 ratio.                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|       | 540000000000000000000000000000000000000 |       | Note: The VCLK2 frequency must always be greater than or equal to the VCLK frequency.<br>The VCLK2 frequency must be an integer multiple of the VCLK frequency. In addition, the<br>VCLK and VCLK2 clock ratios must not be changed simultaneously. |  |  |  |  |  |  |
|       |                                         | 0     | The VCLK2 speed is HCLK divided by 1.                                                                                                                                                                                                               |  |  |  |  |  |  |
|       |                                         | 25    | 2                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|       |                                         | Fh    | The VCLK2 speed is HCLK divided by 16.                                                                                                                                                                                                              |  |  |  |  |  |  |
| 23-20 | Reserved                                | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                              |  |  |  |  |  |  |
| 19-16 | VCLKR                                   |       | VBUS clock ratio.                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|       | 10050000000                             |       | Note: The VCLK2 frequency must always be greater than or equal to the VCLK frequency.<br>The VCLK2 frequency must be an integer multiple of the VCLK frequency. In addition, the<br>VCLK and VCLK2 clock ratios must not be changed simultaneously. |  |  |  |  |  |  |
|       |                                         | 0     | The VCLK speed is HCLK divided by 1.                                                                                                                                                                                                                |  |  |  |  |  |  |
|       |                                         | 8     | 1                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|       |                                         | Fh    | The VCLK speed is HCLK divided by 16.                                                                                                                                                                                                               |  |  |  |  |  |  |
| 15-9  | Reserved                                | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                              |  |  |  |  |  |  |
| 8     | PENA                                    | -     | Peripheral enable bit. The application must set this bit before accessing any peripheral.                                                                                                                                                           |  |  |  |  |  |  |
|       |                                         | 0     | The global peripheral/peripheral memory frames are in reset.                                                                                                                                                                                        |  |  |  |  |  |  |
|       |                                         | 1     | All peripheral/peripheral memory frames are out of reset.                                                                                                                                                                                           |  |  |  |  |  |  |
| 7-0   | Reserved                                | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                                                              |  |  |  |  |  |  |

peripheral이 reset되는 것을 방지한다고 써있다. 즉, 일련의 코드들은

peripgeral의 reset을 허용하게 한 뒤, pcr1부터 pcr3까지 peripheral들을 reset한 뒤, reset을 막는 코드가 된다. 362 muxInit();

다음 코드인 muxInit()으로 가보자

230 pinMuxReg->KICKER0 = 0x83E70B13U;

pinMuxReg->KICKER1 = 0x95A4F1E0U;

KICKER가 보인다. KICKER로 데이터 시트 또는 레퍼런스 매뉴얼을 검색해보자.

Table 6-15. Kicker Register 0 Field Descriptions

| Bit  | Field | Description                                                                                                                                       |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | KICK0 | Kicker 0 Register. The value 83E7 0B13h must be written to KICK0 as part of the process to unlock the CPU write access to the PINMMRnn registers. |

Table 6-16. Kicker Register 1 Field Descriptions

| Bit  | Field | Description                                                                                                                                              |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | KICK1 | Kicker 1 Register. The value 95A4 F1E0h must be written to the KICK1 as part of the process to unlock the<br>CPU write access to the PINMMRnn registers. |

읽어보니, KICKO와 KICK1 둘 다 특정 값을 넣어야 CPU가 PINMMRnn 레지스터들에 쓰기 권한을 얻을 수 있는 것 같다. 다음 코드를 보자.

pinMuxReg->PINMUX[0] = PINMUX\_BALL\_N19\_ADIEVT | PINMUX\_BALL\_04\_EMIF\_ADDR\_00 | PINMUX\_BALL\_05\_EMIF\_ADDR\_01 | PINMUX\_BALL\_C4\_EMIF\_ADDR\_06;

pinMuxReg->PINMUX[1] = PINMUX\_BALL\_C5\_EMIF\_ADDR\_07 | PINMUX\_BALL\_C6\_EMIF\_ADDR\_08 | PINMUX\_BALL\_C7\_EMIF\_ADDR\_09 | PINMUX\_BALL\_C8\_EMIF\_ADDR\_10;

pinMuxReg->PINMUX[2] = PINMUX\_BALL\_C9\_EMIF\_ADDR\_11 | PINMUX\_BALL\_C10\_EMIF\_ADDR\_12 | PINMUX\_BALL\_C11\_EMIF\_ADDR\_13 | PINMUX\_BALL\_C12\_EMIF\_ADDR\_14;

pinMuxReg->PINMUX[3] = PINMUX\_BALL\_C13\_EMIF\_ADDR\_15 | PINMUX\_BALL\_D14\_EMIF\_ADDR\_16 | PINMUX\_BALL\_C14\_EMIF\_ADDR\_17 | PINMUX\_BALL\_D15\_EMIF\_ADDR\_18;

pinMuxReg->PINMUX[4] = PINMUX\_BALL\_C15\_EMIF\_ADDR\_19 | PINMUX\_BALL\_C16\_EMIF\_ADDR\_20 | PINMUX\_BALL\_C17\_EMIF\_ADDR\_21;

PINMUX 배열들에 어떤 값들을 넣어주고 있다.

86 uint32 PINMUX[180]; /\*\*< 0x110 - 1A4 : Output Pin Multiplexing Control Registers (38 registers); 0x250 - 0x29C PINMUX는 180개짜리 배열로 선언되어 있다.

mux로 검색해보니, 결과가 나오지 않는다. 이럴 땐 abbreviated name이 아닌 full name으로도 검색해보자 (multiplex)

Control of Multiplexed Inputs www.ti.com

Table 6-1. Multiplexing for Outputs on 337ZWT Package

| 337ZWT<br>BALL | Default Function                         | Selection<br>Bit    | Alternate Function 1 | Selection<br>Bit | Alternate Function 2           | Selection<br>Bit             | Alternate Function 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Selection<br>Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Alternate Function 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Selection<br>Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Alternate Function 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Selection<br>Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------------------------------------|---------------------|----------------------|------------------|--------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N19            | AD1EVT                                   | 0[0]                |                      | *                | MII_RX_ER                      | 0[2]                         | RMII_RX_ER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0(3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | nTZ1_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0[5]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| D4             | EMIF_ADDR[00]                            | [8]0                |                      |                  | N2HET2[01]                     | 0[10]                        | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| D5             | EMIF_ADDR[01]                            | 0[16]               |                      | X                | N2HET2[03]                     | 0[18]                        | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| C4             | EMIF_ADDR[06]                            | 0[24]               | RTP_DATA[13]         | 0(25]            | N2HET2[11]                     | 0[26]                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| C5             | EMIF_ADDR[07]                            | 1[0]                | RTP_DATA[12]         | 1[1]             | N2HET2[13]                     | 1[2]                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| C8             | EMIF_ADDR[06]                            | 1[8]                | RTP_DATA[11]         | 1(9)             | N2HET2[15]                     | 1[10]                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ſ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| C7             | EMIF_ADDR(09)                            | 1[16]               | RTP_DATA[10]         | 1[17]            | 2.0                            |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| C8             | EMIF_ADDR[10]                            | 1[24]               | RTP_DATA[09]         | 1[25]            | Ÿ                              |                              | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| C9             | EMIF_ADDR(11)                            | 2[0]                | RTP_DATA[08]         | 2[1]             | ×                              | 3                            | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| C10            | EMIF_ADDR[12]                            | 2[8]                | RTP_DATA[06]         | 2[9]             | 1                              | 8                            | 8 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| C11            | EMIF_ADDR[13]                            | 2[16]               | RTP_DATA[05]         | 2[17]            | ,                              | s                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| C12            | EMIF_ADDR[14]                            | 2[24]               | RTP_DATA[04]         | 2[25]            |                                |                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                | BALL N19 D4 D5 C4 C5 C8 C7 C8 C9 C10 C11 | BALL   N19   AD1EVT | BALL   Bit   N19     | BALL             | BALL   Bit   Bit   Bit     N19 | BALL   Bit   Bit   Bit   Bit | BALL   Bit   Bit | BALL   Bit   Bit | BALL   Bit   Bit | BALL   Bit   Bit | BALL   Bit   Bit | BALL   Bit   Bit |

이런 테이블이 나온다. 코드가 너무 많으므로, 첫 줄만 자세히 분석해보자.

236 pinMuxReg->PINMUX[0] = PINMUX\_BALL\_N19\_AD1EVT | PINMUX\_BALL\_D4\_EMIF\_ADDR\_00 | PINMUX\_BALL\_D5\_EMIF\_ADDR\_01 | PINMUX\_BALL\_C4\_EMIF\_ADDR\_06;

테이블을 보니, 110에 해당하는 레지스터 1개가 N19, D4, D5, C4 4개의 pin의 output을 결정해주는 것 같다. 코드에 or 연산이 3개가 있는데, 각 4개의 define은 1개당 1개의 pin의 output을 정해준다고 추측할 수 있다.

첫 번째 define을 보니, PINMUX\_BALL\_N19\_AD1EVT라고 써있다. N19를 AD1EVT로 사용할 수 있게 해주는 놈이다. N19를 AD1EVT로 사용하려면, Selection bit를 0[0]으로 설정해줘야 된다고 써있다. 이게 정확히 무슨 뜻인지는 define을 보면서 추측해보자.

### 55 #define PINMUX\_BALL\_N19\_SHIFT

0x1 << 0 이 되므로, 0번 bit를 1로 set한다는 뜻이 된다.

- 즉, 괄호 [] 안에 있는 숫자 번째의 bit를 1로 set하면, 해당 output으로 설정할 수 있다는 뜻이다.
- 두 번째 define은 PINMUX\_BALL\_D4\_EMIF\_ADDR\_00 이므로, D4를 EMIF\_ADDR[00]으로 설정하겠다는 의미가 된 다. 테이블을 보니, Selection Bit가 0[8]이므로, 8번째 bit를 1로 set한다는 의미가 된다.
- 즉, #define PINMUX\_BALL\_D4\_EMIF\_ADDR\_00 0x0000 0100로 정의되어 있을 것이다. 확인해보자.

452 #define PINMUX\_BALL\_D4\_EMIF\_ADDR\_00

((uint32)((uint32)0x1U << PINMUX\_BALL\_D4\_SHIFT))

56 #define PINMUX BALL D4 SHIFT 8U

1<<8 이므로 0x0000 0100이 맞다.

같은 방식으로 PINMUX\_BALL\_D5\_EMIF\_ADDR\_01 과 PINMUX\_BALL\_C4\_EMIF\_ADDR\_06 각각 0x0001 0000. 0x0100 0000로 define 되어 있을 것이다.

455 #define PINMUX BALL D5 EMIF ADDR 01

((uint32)((uint32)0x1U << PINMUX BALL D5 SHIFT))

57 #define PINMUX BALL D5 SHIFT 16U

458 #define PINMUX BALL C4 EMIF ADDR 06

((uint32)((uint32)0x1U << PINMUX BALL C4 SHIFT))

58 #define PINMUX BALL C4 SHIFT

확인되었다.

그럼 테이블에서 Selection bit의 0[24]에서 24의 의미는 알았지만, 0의 의미는 정확히 알 수 없다.

하지만, 생긴 형태를 보니 0번째 레지스터를 의미하는 것 같다. 즉 0번째 레지스터의 24번 bit를 set하면, C4 핀의 출 력을 EMIF\_ADDR[06]으로서 사용하게 한다 라는 뜻이다.