### Kesmeler - Interrupts

- Kesmeler donanımla tetiklenen yazılım yordamlarıdır.
- Kesmeler mikrokontrolcünün verimli bir şekilde kullanılmasını sağlar.
- Kesmeler sayesinde mikrokontrolcü çoklu görev (multi tasking) şeklinde çalışabilir.
- Kesmeler sayesinde gömülü sistem gerçek zamanlı (real time) çalışabilir.
- Kesmeler harici veya dahili olabilir.

1/13

### NVIC: Nested Vectored Interrupt Controller

- Tüm kesmeler NVIC tarafından yönetilir.
- NVIC ve işlemci çekirdek arayüzü yakın bir şekilde eşleştirilmiştir. Bu durum kesmelerin verimli bir şekilde ele alınmasını sağlar.
- Referans kitabının Tablo 61'de vektörler gösterilmiştir.
- Aynı zamanda startup\_stm32f407xx.s dosyasında bu vektörler belirtilmiştir.

# NVIC: Nested Vectored Interrupt Controller

| Position | Priority | Type of priority | Acronym       | Description                                                                              | Address                      |  |  |
|----------|----------|------------------|---------------|------------------------------------------------------------------------------------------|------------------------------|--|--|
|          | -        | -                | -             | Reserved                                                                                 | 0x0000 0000                  |  |  |
|          | -3       | fixed            | Reset         | Reset                                                                                    | 0x0000 0004                  |  |  |
|          | -2       | fixed            | NMI           | Non maskable interrupt. The RCC Clock Security System (CSS) is linked to the NMI vector. | 0x0000 0008                  |  |  |
|          | -1       | fixed            | HardFault     | All class of fault                                                                       | 0x0000 000C                  |  |  |
|          | 0        | settable         | MemManage     | Memory management                                                                        | 0x0000 0010                  |  |  |
|          | 1        | settable         | BusFault      | Pre-fetch fault, memory access fault                                                     | 0x0000 0014                  |  |  |
|          | 2        | settable         | UsageFault    | Undefined instruction or illegal state                                                   | 0x0000 0018                  |  |  |
|          | -        | -                | -             | Reserved                                                                                 | 0x0000 001C - 0x0000<br>002B |  |  |
|          | 3        | settable SVCall  |               | System service call via SWI instruction                                                  | 0x0000 002C                  |  |  |
|          | 4        | settable         | Debug Monitor | Debug Monitor                                                                            | 0x0000 0030                  |  |  |
|          | -        | -                | -             | Reserved                                                                                 | 0x0000 0034                  |  |  |

# NVIC: Nested Vectored Interrupt Controller

| Vectors | DCD | initial_sp                   | ; Top of Stack          |
|---------|-----|------------------------------|-------------------------|
|         | DCD | Reset_Handler                | ; Reset Handler         |
|         | DCD | NMI_Handler                  | ; NMI Handler           |
|         | DCD | <pre>HardFault_Handler</pre> | ; Hard Fault Handler    |
|         | DCD | MemManage_Handler            | ; MPU Fault Handler     |
|         | DCD | BusFault_Handler             | ; Bus Fault Handler     |
|         | DCD | UsageFault_Handler           | ; Usage Fault Handler   |
|         | DCD | 0                            | ; Reserved              |
|         | DCD | 0                            | ; Reserved              |
|         | DCD | 0                            | ; Reserved              |
|         | DCD | 0                            | ; Reserved              |
|         | DCD | SVC_Handler                  | ; SVCall Handler        |
|         | DCD | DebugMon_Handler             | ; Debug Monitor Handler |
|         | DCD | 0                            | ; Reserved              |
|         | DCD | PendSV_Handler               | ; PendSV Handler        |
|         | DCD | SysTick_Handler              | ; SysTick Handler       |
|         |     |                              |                         |

### NVIC: Nested Vectored Interrupt Controller

- Vektör tablosu, adresleri tutmaktadır.
- Kesme olduğunda, ilgili kesme için yapılacak işlemler bir fonksiyonda tanımlıdır.
- Bu fonksiyona interrupt handler denilir.
- Vektörler ise interrrupt handlerın adreslerini tutarr
- Bazı kesmelerin önceliği sabittir ve değiştirilemez, Örnek: Reset
- startup\_stm32f407xx.s dosyasında interrupt için kullanılacak olan fonksiyonlar (interrupt handler) assembly dilinde yazılmıştır. Ancak bu fonksiyonların yanında yazılmış olan WEAK ifadeleri bu fonksiyonların tekrar yazılabileceği anlamına gelir.

5/13

## External Interrupt Event Controller



- NVIC yapısı ARM çekirdeği içerisinde bulunmaktadır.
- Bazı üniteler NVIC'e doğrudan bağlı iken GPIO'lar EXTI (External Interrupt Event Controller) yapısıyla NVIC'e bağlanmıştır.

## External Interrupt Event Controller

GPIO pinleri 16 harici kesme hatlarına aşağıdaki şekilde bağlanmıştır.



7/13

## External Interrupt Event Controller





/13

## External Interrupt Event Controller

#### Interrupt mask register (EXTI\_IMR)

Address offset: 0x00

Reset value: 0x0000 0000

| 31   | 30        | 29   | 28   | 27   | 26   | 25  | 24  | 23  | 22  | 21  | 20   | 19   | 18   | 17   | 16   |
|------|-----------|------|------|------|------|-----|-----|-----|-----|-----|------|------|------|------|------|
|      | Percented |      |      |      |      |     |     |     |     |     | MR20 | MR19 | MR18 | MR17 | MR16 |
|      | Reserved  |      |      |      |      |     |     |     |     | rw  | rw   | rw   | rw   | rw   | rw   |
| 15   | 14        | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4    | 3    | 2    | 1    | 0    |
| MR15 | MR14      | MR13 | MR12 | MR11 | MR10 | MR9 | MR8 | MR7 | MR6 | MR5 | MR4  | MR3  | MR2  | MR1  | MR0  |
| rw   | rw        | rw   | rw   | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw   | rw   | rw   | rw   | rw   |

Bits 31:23 Reserved, must be kept at reset value.

Bits 22:0 MRx: Interrupt mask on line x

0: Interrupt request from line x is masked1: Interrupt request from line x is not masked

9/13

# External Interrupt Event Controller

#### Rising trigger selection register (EXTI\_RTSR)

Address offset: 0x08

Reset value: 0x0000 0000

| 31   | 30       | 29   | 28   | 27      | 26   | 25  | 24  | 23  | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|------|----------|------|------|---------|------|-----|-----|-----|------|------|------|------|------|------|------|
|      |          |      |      | Pacania | 4    |     |     |     | TR22 | TR21 | TR20 | TR19 | TR18 | TR17 | TR16 |
|      | Reserved |      |      |         |      |     |     |     |      | rw   | rw   | rw   | rw   | rw   | rw   |
| 15   | 14       | 13   | 12   | 11      | 10   | 9   | 8   | 7   | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| TR15 | TR14     | TR13 | TR12 | TR11    | TR10 | TR9 | TR8 | TR7 | TR6  | TR5  | TR4  | TR3  | TR2  | TR1  | TR0  |
| rw   | rw       | rw   | rw   | rw      | rw   | rw  | rw  | rw  | rw   | rw   | rw   | rw   | rw   | rw   | rw   |

Bits 31:23 Reserved, must be kept at reset value.

Bits 22:0 TRx: Rising trigger event configuration bit of line x

0: Rising trigger disabled (for Event and Interrupt) for input line

1: Rising trigger enabled (for Event and Interrupt) for input line

### External Interrupt Event Controller

#### Falling trigger selection register (EXTI\_FTSR)

Address offset: 0x0C Reset value: 0x0000 0000

| 31   | 30        | 29   | 28   | 27   | 26   | 25  | 24  | 23  | 22  | 21  | 20   | 19   | 18   | 17   | 16   |
|------|-----------|------|------|------|------|-----|-----|-----|-----|-----|------|------|------|------|------|
|      | Percented |      |      |      |      |     |     |     |     |     | TR20 | TR19 | TR18 | TR17 | TR16 |
|      | Reserved  |      |      |      |      |     |     |     | rw  | rw  | rw   | rw   | rw   | rw   | rw   |
| 15   | 14        | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4    | 3    | 2    | 1    | 0    |
| TR15 | TR14      | TR13 | TR12 | TR11 | TR10 | TR9 | TR8 | TR7 | TR6 | TR5 | TR4  | TR3  | TR2  | TR1  | TR0  |
| rw   | rw        | rw   | rw   | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw   | rw   | rw   | rw   | rw   |

Bits 31:23 Reserved, must be kept at reset value.

Bits 22:0 TRx: Falling trigger event configuration bit of line x

0: Falling trigger disabled (for Event and Interrupt) for input line1: Falling trigger enabled (for Event and Interrupt) for input line.

11/13

# External Interrupt Event Controller

#### Pending register (EXTI\_PR)

Address offset: 0x14 Reset value: undefined

| 31    | 30       | 29    | 28    | 27      | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|----------|-------|-------|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|       |          |       |       | Pacania | 4     |       |       |       | PR22  | PR21  | PR20  | PR19  | PR18  | PR17  | PR16  |
|       | Reserved |       |       |         |       |       |       |       |       | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 |
| 15    | 14       | 13    | 12    | 11      | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| PR15  | PR14     | PR13  | PR12  | PR11    | PR10  | PR9   | PR8   | PR7   | PR6   | PR5   | PR4   | PR3   | PR2   | PR1   | PR0   |
| rc_w1 | rc_w1    | rc_w1 | rc_w1 | rc_w1   | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 | rc_w1 |

Bits 31:23 Reserved, must be kept at reset value.

Bits 22:0 PRx: Pending bit

0: No trigger request occurred

1: selected trigger request occurred

This bit is set when the selected edge event arrives on the external interrupt line.

This bit is cleared by programming it to '1'.

read/clear (rc\_w1) Software can read as well as clear this bit by writing 1. Writing '0' has no effect on the bit value.

# EXTI Vektörleri

| Position | Priority | Type of priority | Acronym | Description          | Address     |
|----------|----------|------------------|---------|----------------------|-------------|
| 6        | 13       | settable         | EXTI0   | EXTI Line0 interrupt | 0x0000 0058 |
| 7        | 14       | settable         | EXTI1   | EXTI Line1 interrupt | 0x0000 005C |
| 8        | 15       | settable         | EXTI2   | EXTI Line2 interrupt | 0x0000 0060 |
| 9        | 16       | settable         | EXTI3   | EXTI Line3 interrupt | 0x0000 0064 |
| 10       | 17       | settable         | EXTI4   | EXTI Line4 interrupt | 0x0000 0068 |

0x4001 3C00 - 0x4001 3FFF | EXTI | APB2 |

13/13