

## **ARM HW4**

2019. 04. 05.

Embedded System LAB SKKU



### **Implementation Topic**

#### Interrupt

Using switch

C: LED ON

D: LED OFF

■ E : Push switch → LED ON

Release switch → LED OFF





## **Implementation Conditions**

- Use Hardware interrupt
- You must coding
  - Vector table
  - Switch Initialize
  - LED Initialize
  - Interrupt Configuration
  - Interrupt enable
  - Unmasking
  - Interrupt default handler
  - Handler code
  - Interrupt Clear



## **Program flowchart 1**

```
.global __stack
 stack:
                        ; Interrupt Vectors
                       .sect ".intvecs"
                       .align 4
                       .field IntDefaultHandler,32
                                                         ; g pfnVectors[0] @ 0
                       .field IntDefaultHandler,32
                                                      ; g_pfnVectors[1] @ 32
                       .field IntDefaultHandler,32
                                                       ; g_pfnVectors[2] @ 64
                                                        ; g_pfnVectors[3] @ 96
                       .field IntDefaultHandler,32
                                                      ; g_pfnVectors[4] @ 128
                       .field IntDefaultHandler,32
                       .field IntDefaultHandler,32
                                                         ; g pfnVectors[5] @ 160
                       .field IntGPIOm,32
                                              ; g_pfnVectors[127] @ 4064
197
199
200 SWITCH:
201
              mov r0, #GPIO BASE ;RCGC : Gener
              mov r1, #0xFE000
202
              add r1, r1, r0
203
204
              mov r0, #RCGCGPIO
              add r1, r1, r0
205
              ldr r0, [r1]
207
              orr r0, r0, #0x800
              str r0, [r1]
210
211
          Interrupt Configuration
```



# **Program flowchart 2**





## **Program flowchart 3**

```
; idle loop
loop
          b loop
IntDefaultHandler:
iloop
          b iloop
IntGPIOm:
          .asmfunc
          STMFD sp!, {a1-a4, lr}
; portm interrupt clear
             Interrupt
                Clear
          LED behavior
                 sp!, {a1-a4, lr}
         bx 1r
         .endasmfunc
```



#### **GPIO PORT M**

#### Vector Number (Interrupt Number)

Table 2-2. User Switches and User LED Signals

| GPIO Pin | Pin Function | Feature           |
|----------|--------------|-------------------|
| PM0      | GPIO         | SW1 (Up)          |
| PM1      | GPIO         | SW2 (Down)        |
| PM2      | GPIO         | SW3 (Left)        |
| PM3      | GPIO         | SW4 (Right)       |
| PM4      | GPIO         | SW5 (Select/Wake) |
| PG2      | GPIO         | User LED          |



Figure 2-6. Vector Table

| gure 2-6. Vector Table                                       |                         |                                                          |                                                                  |  |  |  |  |  |
|--------------------------------------------------------------|-------------------------|----------------------------------------------------------|------------------------------------------------------------------|--|--|--|--|--|
| xception number                                              | IRQ number              | Offset                                                   | Vector                                                           |  |  |  |  |  |
| 154                                                          | 138                     | 0x0268                                                   | IRQ 138                                                          |  |  |  |  |  |
| 18<br>17<br>16<br>15<br>14<br>13<br>12<br>11<br>10<br>9<br>8 | 2<br>1<br>0<br>-1<br>-2 | 0x004C<br>0x0048<br>0x0044<br>0x0040<br>0x003C<br>0x003S | IRQ2 IRQ1 IRQ0 Systick PendSV Reserved Reserved for Debug SVCall |  |  |  |  |  |
| 6                                                            | -10<br>-11              | 0x0018<br>0x0014                                         | Usage fault<br>Bus fault                                         |  |  |  |  |  |
| 4<br>3                                                       | -12<br>-13              | 0x0010                                                   | Memory management fault  Hard fault                              |  |  |  |  |  |

0x000C

0x0008

0x0004

0x0000

#### Datasheet – TM4C123GH6PGE.pdf

| Vector Number | Interrupt Number (Bit in Interrupt Registers) |             | Description |
|---------------|-----------------------------------------------|-------------|-------------|
| 75            | 59                                            | 0x0000.012C | UART3       |
| 76            | 60                                            | 0x0000.0130 | UART4       |
| 77            | 61                                            | 0x0000.0134 | UART5       |

| 127 | 111 | 0x0000.01FC | GPIO Port M |
|-----|-----|-------------|-------------|
| 128 | 112 | 0x0000.0200 | GPIO Port N |

NMI

Reset

Initial SP value



### **Interrupt Configuration**

Edge trigger, Level trigger



- Related Register
  - GPIOIS (GPIO Interrupt Sense)
  - GPIOIEV (GPIO Interrupt Event)



- EN3
  - Interrupt 96 ~ 127 Set Enable
- GPIOIM
  - GPIO Interrupt Mask
- GPIOICR
  - GPIO Interrupt Clear



#### EN3

- Interrupt 96-127 Set Enable
- This register can only be accessed from privileged mode



Access address: 0xE000.E10C

Base: 0xE000.E000, Offset: 0x10C

Value: 0x8000

On a read, indicates the interrupt is enabled.

On a write, enables the interrupt.



#### GPIOIM

GPIO Interrupt Mask



Access address: 0x4006.3410

Base: 0x4006.3000, Offset: 0x410

Value: 0xFF

The interrupt from the corresponding pin is masked.

The interrupt from the corresponding pin is sent to the interrupt controller.



#### GPIOICR

GPIO Interrupt Clear



Access address: 0x4006.341C

Base: 0x4006.3000, Offset: 0x41C

Value: 0xFF

The corresponding interrupt is unaffected.

1 The corresponding interrupt is cleared.



#### HW4 check

- Time and Place
  - April 12th(Fri) 19:00
  - Semi-conductor building 2 floor computer room
    - **400202, 400212**
- How to submit
  - asm.
  - I-Campus, until April 12th 18:59
    - format
      - > 2012310000\_HW4.asm