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

강사 - Innova Lee(이상훈)
gcccompil3r@gmail.com
학생 - 최대성
c3d4s19@naver.com

\_\_\_\_\_

#### TMS570LC43x 레지스터 분석

gioREG->GCR0 = 1U;

## -> GIO핀 작동시킴

#### 25.5.1 GIO Global Control Register (GIOGCR0)

The GIOGCR0 register contains one bit that controls the module reset status. Writing a 0 to this bit puts the module in a reset state. After system reset, this bit must be set to 1 before configuring any other register of the GIO module. Figure 25-5 and Table 25-2 describe this register.

Figure 25-5. GIO Global Control Register (GIOGCR0) [offset = 00h]



LEGEND: R/W = Read/Write; R = Read only; WP = Write in privileged mode only; -n = value after reset

Table 25-2. GIO Global Control Register (GIOGCR0) Field Descriptions

| Bit  | Field    | Value | Description                            |
|------|----------|-------|----------------------------------------|
| 31-1 | Reserved | 0     | Reads return 0. Writes have no effect. |
| 0    | RESET    |       | GIO reset.                             |
|      |          | 0     | The GIO is in reset state.             |
|      |          | 1     | The GIO is operating normally.         |

NOTE: Note that putting the GIO module in reset state is not the same as putting it in a low-power state.

## gioREG->ENACLR = 0xFFU;

# -> 해당 인터럽트 사용 불가

#### 25.5.4.2 GIOENACLR Register

This register disables the interrupt. Figure 25-9 and Table 25-6 describe this register.

Figure 25-9. GIO Interrupt Enable Clear Register (GIOENACLR) [offset = 14h]



Table 25-6. GIO Interrupt Enable Clear Register (GIOENACLR) Field Descriptions

| Bit   | Field       | Value | Description                                   |
|-------|-------------|-------|-----------------------------------------------|
| 31-24 | GIOENACLR 3 |       | Interrupt disable for pins GIOD[7:0]          |
|       |             | 0     | Read: The interrupt is disabled.              |
|       |             |       | Write: Writing a 0 to this bit has no effect. |
|       |             | 1     | Read: The interrupt is enabled.               |
|       |             |       | Write: Disables the interrupt.                |
| 23-16 | GIOENACLR 2 |       | Interrupt disable for pins GIOC[7:0]          |
|       |             | 0     | Read: The interrupt is disabled.              |
|       |             |       | Write: Writing a 0 to this bit has no effect. |
|       |             | 1     | Read: The interrupt is enabled.               |
|       |             |       | Write: Disables the interrupt.                |
| 15-8  | GIOENACLR 1 |       | Interrupt disable for pins GIOB[7:0]          |
|       |             | 0     | Read: The interrupt is disabled.              |
|       |             |       | Write: Writing a 0 to this bit has no effect. |
|       |             | 1     | Read: The interrupt is enabled.               |
|       |             |       | Write: Disables the interrupt.                |
| 7-0   | GIOENACLR 0 |       | Interrupt disable for pins GIOA[7:0]          |
|       |             | 0     | Read: The interrupt is disabled.              |
|       |             |       | Write: Writing a 0 to this bit has no effect. |
|       |             | 1     | Read: The interrupt is enabled.               |
|       |             |       | Write: Disables the interrupt.                |

gioREG->LVLCLR = 0xFFU;

# -> 해당 인터럽트를 low-level로 만들고 low-level 인 터럽트들을 GIOOFF2 와 FIOEMU2에 기록한다

#### 25.5.5.2 GIOLVLCLR Register

The GIOLVLCLR register is used to configure an interrupt as a low-level interrupt going to the VIM. An interrupt can be configured as a low-level interrupt by writing a 1 into the corresponding bit of the GIOLVLCLR register. Writing a 0 has no effect. Figure 25-11 and Table 25-8 describe this register.

Figure 25-11, GIO Interrupt Priority Register (GIOLVLCLR) [offset = 1Ch]



LEGEND: R/W = Read/Write; -n = value after reset

#### Table 25-8, GIO Interrupt Priority Register (GIOLVLCLR) Field Descriptions

| Bit   | Field       | Value | Description                                                                                                          |
|-------|-------------|-------|----------------------------------------------------------------------------------------------------------------------|
| 31-24 | GIOLVLCLR 3 |       | GIO low-priority interrupt for pins GIOD[7:0]                                                                        |
|       |             | 0     | Read: The interrupt is a low-level interrupt.                                                                        |
|       |             |       | Write: Writing a 0 to this bit has no effect.                                                                        |
|       |             | 1     | Read: The interrupt is set as a high-level interrupt. The high-level interrupts are recorded to GIOOFF1 and GIOEMU1. |
|       |             |       | Write: Sets the interrupt as a low-level interrupt. The low-level interrupts are recorded to GIOOFF2 and GIOEMU2.    |
| 23-16 | GIOLVLCLR 2 |       | GIO low-priority interrupt for pins GIOC[7:0]                                                                        |
|       |             | 0     | Read: The interrupt is a low-level interrupt.                                                                        |
|       |             |       | Write: Writing a 0 to this bit has no effect.                                                                        |
|       |             | 1     | Read: The interrupt is set as a high-level interrupt. The high-level interrupts are recorded to GIOOFF1 and GIOEMU1. |
|       |             |       | Write: Sets the interrupt as a low-level interrupt. The low-level interrupts are recorded to GIOOFF2 and GIOEMU2.    |
| 15-8  | GIOLVLCLR 1 |       | GIO low-priority interrupt for pins GIOB[7:0]                                                                        |
|       |             | 0     | Read: The interrupt is a low-level interrupt.                                                                        |
|       |             |       | Write: Writing a 0 to this bit has no effect.                                                                        |
|       |             | 1     | Read: The interrupt is set as a high-level interrupt. The high-level interrupts are recorded to GIOOFF1 and GIOEMU1. |
|       |             |       | Write: Sets the interrupt as a low-level interrupt. The low-level interrupts are recorded to GIOOFF2 and GIOEMU2.    |
| 7-0   | GIOLVLCLR 0 |       | GIO low-priority interrupt for pins GIOA[7:0]                                                                        |
|       |             | 0     | Read: The interrupt is a low-level interrupt.                                                                        |
|       |             |       | Write: Writing a 0 to this bit has no effect.                                                                        |
|       |             | 1     | Read: The interrupt is set as a high-level interrupt. The high-level interrupts are recorded to GIOOFF1 and GIOEMU1. |
|       |             |       | Write: Sets the interrupt as a low-level interrupt. The low-level interrupts are recorded to GIOOFF2 and GIOEMU2.    |

#### gioPORTA->DIR

# -> GIO PORTA의 핀들을 입력으로 쓸지 출력으로 쓸지 결정해줌

#### 25.5.11 GIO Data Direction Registers (GIODIR[A-B])

The GIODIR register controls whether the pins of a given port are configured as inputs or outputs. Figure 25-17 and Table 25-14 describe this register.

Figure 25-17. GIO Data Direction Registers (GIODIR[A-B]) [offset = 34h, 54h]



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

Table 25-14. GIO Data Direction Registers (GIODIR[A-B]) Field Descriptions

| Bit  | Field     | Value | Description                                                                                             |
|------|-----------|-------|---------------------------------------------------------------------------------------------------------|
| 31-8 | Reserved  | 0     | Reads return 0. Writes have no effect.                                                                  |
| 7-0  | GIODIR[n] |       | GIO data direction of port n, pins [7:0]                                                                |
|      |           | 0     | The GIO pin is an input. Note: If the pin direction is set as an input, the output buffer is tristated. |
|      |           | 1     | The GIO pin is an output.                                                                               |

## gioPORTA->DOUT

# -> GIO PORTA의 핀들의 출력을 HIGH(1) 또는 LOW(0) 으로 설정

#### 25.5.13 GIO Data Output Registers (GIODOUT[A-B])

Values in the GIODOUT register specify the output state (high | 1 or low = 0) of the pins of the port when they are configured as outputs. Figure 25-19 and Table 25-16 describe this register.

NOTE: Values in the GIODSET register set the data output control register bits to 1 regardless of the current value in the GIODOUT bits.

Figure 25-19. GIO Data Output Registers (GIODOUT[A-B]) [offset = 3Ch, 5Ch]

| 31 |          |        |              | 16 |
|----|----------|--------|--------------|----|
|    | Re       | served |              |    |
| •  |          | R-0    |              |    |
| 15 | 8        | 7      |              | 0  |
|    | Reserved |        | GIODOUT[7:0] |    |
|    | R-0      |        | R/W-0        |    |

): R/W = Read/Write; R = Read only; -n = value after reset

Table 25-16, GIO Data Output Registers (GIODOUT[A-B]) Field Descriptions

| Bit  | Field      | Value | Description                                                                          |
|------|------------|-------|--------------------------------------------------------------------------------------|
| 31-8 | Reserved   | 0     | Reads return 0. Writes have no effect.                                               |
| 7-0  | GIODOUT[n] |       | GIO data output of port n, pins[7:0].                                                |
|      |            | 0     | The pin is driven to logic low (0).                                                  |
|      |            | 1     | The pin is driven to logic high (1).                                                 |
|      |            |       | Note: Output is in high impedance state if the GIOPDRx bit = 1 and GIODOUTx bit = 1. |
|      |            |       | Note: GIO pin is placed in output mode by setting the GIODIRx bit to 1.              |

#### gioPORTA->DSET

# -> 해당 GIO PORTA 핀들의 출력만 HIGH로 설정

#### 25.5.14 GIO Data Set Registers (GIODSET[A-B])

Values in this register set the data output control register bits to 1 regardless of the current value in the GIODOUT bits. The contents of this register reflect the contents of GIODOUT. Figure 25-20 and Table 25-17 describe this register.

Figure 25-20. GIO Data Set Registers (GIODSET[A-B]) [offset = 40h, 60h]

| 31       |          | 16    |
|----------|----------|-------|
|          | Reserved |       |
| •        | R-0      | ,     |
| 15       | 8 7      | 0     |
| Reserved | GIODSET  | [7:0] |
| P-0      | P.W.O    |       |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

Table 25-17. GIO Data Set Registers (GIODSET[A-B]) Field Descriptions

| Bit  | Field      | Value | Description                                                                          |
|------|------------|-------|--------------------------------------------------------------------------------------|
| 31-8 | Reserved   | 0     | Reads return 0. Writes have no effect.                                               |
| 7-0  | GIODSET[n] |       | GIO data set for port n, pins[7:0]. This bit drives the output of GIO pin high.      |
|      |            | 0     | Write: Writing a 0 has no effect.                                                    |
|      |            | 1     | Write: The corresponding GIO pin is driven to logic high (1).                        |
|      |            |       | Note: The current logic state of the GIODOUT bit will also be displayed by this bit. |
|      |            |       | Note: GIO pin is placed in output mode by setting the GIODIRx bit to 1.              |

#### gioPORTA->DCLR

#### -> 해당 GIO PORTA 핀들의 출력만 LOW로 설정

#### 25.5.15 GIO Data Clear Registers (GIODCLR[A-B])

Values in this register clear the data output register (GIO Data Output Register [A-H]) bit to 0 regardless of its current value. The contents of this register reflect the contents of GIODOUT. Figure 25-21 and Table 25-18 describe this register.

Figure 25-21. GIO Data Clear Registers (GIODCLR[A-B]) [offset = 44h, 64h]



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

Table 25-18. GIO Data Clear Registers (GIODCLR[A-B]) Field Descriptions

| Bit  | Field      | Value | Description                                                                          |
|------|------------|-------|--------------------------------------------------------------------------------------|
| 31-8 | Reserved   | 0     | Reads return 0. Writes have no effect.                                               |
| 7-0  | GIODCLR[n] |       | GIO data clear for port n, pins[7:0]. This bit drives the output of GIO pin low.     |
|      |            | 0     | Write: Writing a 0 has no effect.                                                    |
|      |            | 1     | Write: The corresponding GIO pin is driven to logic low (0).                         |
|      |            |       | Note: The current logic state of the GIODOUT bit will also be displayed by this bit. |
|      |            |       | Note: GIO pin is placed in output mode by setting the GIODIRx bit to 1               |

#### gioPORTA->PDR

-> 핀들을 open drain으로 사용할지 push/pull로 사용 할지 결정함

#### 25.5.16 GIO Open Drain Registers (GIOPDR[A-B])

Values in this register enable or disable the open drain capability of the data pins. Figure 25-22 and Table 25-19 describe this register.

Figure 25-22. GIO Open Drain Registers (GIOPDR[A-B]) [offset = 48h, 68h]



Table 25-19. GIO Open Drain Registers (GIOPDR[A-B]) Field Descriptions

| Bit  | Field     | Value | Description                                                                                                                                                                                                       |
|------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | Reserved  | 0     | Reads return 0. Writes have no effect.                                                                                                                                                                            |
| 7-0  | GIOPDR[n] |       | GIO open drain for port n, pins[7:0]                                                                                                                                                                              |
|      |           | 0     | The GIO pin is configured in push/pull (normal GIO) mode. The output voltage is V $_{\rm OL}$ or lower if GIODOUT bit = 0 and V $_{\rm OH}$ or higher if GIODOUT bit = 1.                                         |
|      |           | 1     | The GIO pin is configured in open drain mode. The GIODOUTx bit controls the state of the GIO output buffer: GIODOUTx = 0, the GIO output buffer is driven low; GIODOUTx = 1, the GIO output buffer is thristated. |

#### Push/Pull, Open drain 비교설명 관련 링크

#### http://irmus.tistory.com/76

#### gioPORTA->PULDIS

-> pull up / pull down 을 사용할지 설정

#### 25.5.17 GIO Pull Disable Registers (GIOPULDIS[A-B])

Values in this register enable or disable the pull control capability of the pins. Figure 25-23 and Table 25-20 describe this register.

Figure 25-23. GIO Pull Disable Registers (GIOPULDIS[A-B]) [offset = 4Ch, 6Ch]



Table 25-20. GIO Pull Disable Registers (GIOPULDISIA-BI) Field Descriptions

| В  | it | Field        | Value | Description                                                                                                                   |
|----|----|--------------|-------|-------------------------------------------------------------------------------------------------------------------------------|
| 31 | -8 | Reserved     | 0     | Reads return 0. Writes have no effect.                                                                                        |
| 7- | 0  | GIOPULDIS[n] |       | GIO pull disable for port n, pins[7:0]. Writes to this bit will only take effect when the GIO pin configured as an input pin. |
|    |    |              | 0     | The pull functionality is enabled.                                                                                            |
|    |    |              | 1     | The pull functionality is disabled.                                                                                           |
|    |    |              |       | Note: The GIO pin is placed in input mode by clearing the GIODIRx bit to 0.                                                   |

#### gioPORTA->PSL

-> pull up / pull down을 사용한다면 둘중 무엇을 사용 할지 설정

# 25.5.18 GIO Pull Select Registers (GIOPSL[A-B])

Values in this register select the pull up or pull down functionality of the pins. Figure 25-24 and Table 25-21 describe this register.

Figure 25-24. GIO Pull Select Registers (GIOPSL[A-B]) [offset = 50h, 70h]



Table 25-21. GIO Pull Select Registers (GIOPSL[A-B]) Field Descriptions

| Bit  | Field     | Value | Description                                                                                           |
|------|-----------|-------|-------------------------------------------------------------------------------------------------------|
| 31-8 | Reserved  | 0     | Reads return 0. Writes have no effect.                                                                |
| 7-0  | GIOPSL[n] |       | GIO pull select for port n, pins[7:0]                                                                 |
|      |           | 0     | The pull down functionality is select, when pull up/pull down logic is enabled.                       |
|      |           | 1     | The pull up functionality is select, when pull up/pull down logic is enabled.                         |
|      |           |       | Note: The pull up/pull down functionality is enabled by clearing corresponding bit in GIOPULDIS to 0. |