#### MAINLINE

- 1. Set up stacks for supervisor mode and IRQ mode
- 2. Initialize GPIO1 clock (Clock Module base: =0x44E0 0000)
  - a. Write #0x02 to CM PER GPIO1 CLKCTRL (offset: 0xAC)
- 3. Initialize UART2 clock
  - a. Write #0x02 to CM PER UART2 CLKCTRL (offset: #0x70)
- 4. Initialize Timer7 clock
  - a. Write #0x02 to CM\_PER\_TIMER7\_CLKCTRL (offset: #0x7C)
  - b. Select 32KHz by writing #0x02 to PRCMCLKSEL TIMER7 (offset: #0x504)
- 5. Set up GPIO1 31 for falling edge interrupt (GPIO1 base: =0x4804 C000)
  - a. RMW GPIO1 FALLINGDETECT register
    - i. Read GPIO1 FALLINGDETECT(offset: #0x14C)
    - ii. Modify (set bit 31) #0x8000 0000
    - iii. Write back
  - b. Enable button interrupt for bit 31 of GPIO1
    - i. Write #0x8000 0000 to GPIO1 IRQSTATUS SET 0 (offset: #0x34)
- 6. Initialize INTC for GPIO1\_31, UART2, and Timer7 (INTC base: =0x4820\_0000)
  - a. Reset INTC
    - i. Write #0x2 to INTC config reg (offset: #0x10)
  - b. Unmask INTC INT 98 (98 32 32 32 = bit 2) (GPIOINT1A)
    - i. Write #0x04 to INTC MIR CLEAR3 (offset: #0xE8)
  - c. Unmask INTC INT 74 (74 32 32 = bit 10) (UART2)
    - i. Write #0x400 to INTC MIR CLEAR2 (offset: #0xC8)
  - d. Unmask INTC INT 95 (95 32 32 = 31) (DMTimer7)
    - i. Write #0x80000000 to INTC MIR CLEAR2 (offset: #0xC8)
- 7. Map UART2
  - a. Read CONF SPI0 D0 (Address: =0x44E1 0954)
  - b. Modify (set bit 4 and 0) #0x11 for MODE1 (pin21 of P9)
  - c. Write back
- 8. Initialize UART2 Baud rate, etc. (UART2 base: =0x4802 4000)
  - a. Switch to mode A and set 8-bit data format
    - i. Write #0x83 to line control register UART\_LCR (offset: 0x0C)
  - b. Enable 9.6kbps Baud rate
    - i. Write #0x01 to divisor latch high DLH (offset: 0x04)
    - ii. Write #0x38 to divisor latch low DLL (offset: 0x00)
  - c. Enable 16x UART mode
    - i. Write #0x00 to MDR1 (offset: 0x20)
  - d. Switch back to operational mode
    - i. Write #0x03 to UART\_LCR (offset: #0x70)
  - e. Turn off FIFO
    - i. Write #0x00 to FIFO control register (offset: #0x8)
- 9. Initialize Timer7 (Timer7 Base: =0x4804 A000)
  - a. Reset Timer7
    - i. Write #0x1 to Timer7 config register (offset: #0x10)

- b. Enable overflow interrupt
  - i. Write #0x2 to IRQENABLE SET (offset: #0x2C)
- c. Load TLDR and TCRR with count value
  - i. Write ss to TLDR (offset: #0x40)
  - ii. Write ss to TCRR (offset: #0x3C)
- 10. Enable IRQ interrupt
  - a. Clear bit 7 in CPSR
- 11. Wait loop

#### INT DIRECTOR

- 1. Save registers
- 2. Check if interrupt from Timer7
  - a. Check bit 31 in INTC PENDING IRQ2 (Address: =0x4820 00D8)
  - b. If bit 31 = 0 go check UART2
  - c. If bit 31 = 1 check bit 1 of IRQSTATUS (Address: =0x4804 A028)
    - i. If bit 1 = 1, go to TIMER7 SVC
    - ii. If bit 1 = 0, go to RETURN SVC
- 3. Check if interrupt from UART2
  - a. Check bit 10 in INTC\_PENDING\_IRQ2 (Address: =0x4820\_00D8)
  - b. If bit 10 = 0, go check button
  - c. If bit 10 = 1, check bit 0 of IIR UART (Address: =0x4802 4008)
    - i. If bit 0 = 0, go to TALKER SVC
    - ii. If bit 0 = 1, go to RETURN SVC
- 4. Check if interrupt from button (INTC base: =0x4820 0000)
  - a. Check bit 2 in INTC PENDING IRQ3 (offset: #0xF8)
  - b. If bit 2 = 0, go to RETURN SVC
  - c. If bit 2 = 1, check bit 31 of GPIO1 IRQSTATUS 0 (Address: =0x4804 C02C)
    - i. If bit 31 = 1, go to BUTTON SVC
    - ii. If bit 31 = 0, go to RETURN SVC

#### **BUTTON SVC**

- 1. Turn off GPIO1 31 interrupt
  - a. Write 0x8000\_0000 to GPIO1\_IRQSTATUS\_0 (Address: =0x4804\_C02C)
- 2. Enable INTC for new interrupt aka turn off NEWIRQA bit
  - a. Write #0x1 to INTC CONTROL (Address: =0x4820 0048)
- 3. Enable UART2 interrupt signals
  - a. Write #0x02 to IER\_UART (Address: =0x4802\_4004)
- 4. Enable TIMER7 interrupt signals
  - a. Write #0x03 to TCLR (Address: =0x4804A038)
- 5. Restore registers and return to wait loop

# TIMER7\_SVC

- 1. Write shift command to THR (Address: =0x4802 4000)
  - a. Load byte, increment counter

- b. If counter = length of array, reset counter
  - i. Write 0 to R0
  - ii. Go to RETURN\_SVC
- 2. Go to RETURN SVC

# TALKER\_SVC

- 1. Write character to THR (Address: =0x4802 4000)
  - a. Load byte, increment counter
  - b. If counter = 0, disable UART2 interrupt signal
    - i. Write #0x0 to IER UART2 (Address: =0x4802 4004)
      - 1. Go to RETURN\_SVC
- 2. Go to RETURN\_SVC

# **RETURN\_SVC**

- 1. Enable new IRQ interrupt
  - a. Write #0x1 to INTC\_CONTROL (Address: =0x4820\_0048)
  - b. Restore registers and return to wait loop