

# Microcontroller

Department of Electrical Engineering
Iran University of Science and Technology



### **Interrupt/Polling**





### **Interrupt**



Fig 1. Automatic stacking and unstacking for interrupt handler



### **Interrupt Mechanism**



Fig 2. Steps of stacking and unstacking for interrupt handler



### **Interrupt**





### External interrupt/event GPIO mapping







#### **NVIC**





### RCC\_APB2ENR :IOPCEN

IO port C clock enable

0: IO port C clock disabled

1: IO port C clock enabled

| 31         | 30           | 29         | 28         | 27         | 26         | 25         | 24         | 23         | 22         | 21          | 20          | 19         | 18         | 17       | 16         |
|------------|--------------|------------|------------|------------|------------|------------|------------|------------|------------|-------------|-------------|------------|------------|----------|------------|
|            |              |            |            | Res        | erved      |            |            |            |            | TIM11<br>EN | TIM10<br>EN | TIM9<br>EN |            | Reserved | I          |
|            |              |            |            |            |            |            |            |            |            | rw          | rw          | rw         |            |          |            |
| 15         | 14           | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5           | 4           | 3          | 2          | 1        | 0          |
| ADC3<br>EN | USART<br>1EN | TIM8<br>EN | SPI1<br>EN | TIM1<br>EN | ADC2<br>EN | ADC1<br>EN | IOPG<br>EN | IOPF<br>EN | IOPE<br>EN | IOPD<br>EN  | IOPC<br>EN  | IOPB<br>EN | IOPA<br>EN | Res.     | AFIO<br>EN |
| rw         | rw           | rw         | rw         | rw         | rw         | rw         | rw         | rw         | rw         | rw          | rw          | rw         | rw         |          | rw         |



## RCC\_APB2ENR :IOPCEN

| RCC->APB2ENR  = RCC_APB2ENR_IOPCEN; |  |
|-------------------------------------|--|
|                                     |  |
|                                     |  |
|                                     |  |
|                                     |  |
|                                     |  |
|                                     |  |
|                                     |  |



### GPIOx\_CRL :MODEy[1:0]

Port x mode bits (y=0..7)

00: Input mode (reset state)

01: Output mode, max speed 10 MHz.

10: Output mode, max speed 2 MHz.

11: Output mode, max speed 50 MHz.

| 31  | 30     | 29            | 28     | 27        | 26     | 25         | 24     | 23        | 22     | 21         | 20      | 19        | 18     | 17         | 16      |
|-----|--------|---------------|--------|-----------|--------|------------|--------|-----------|--------|------------|---------|-----------|--------|------------|---------|
| CNF | 7[1:0] | 0] MODE7[1:0] |        | CNF6[1:0] |        | MODE6[1:0] |        | CNF5[1:0] |        | MODE5[1:0] |         | CNF4[1:0] |        | MODE4[1:0] |         |
| rw  | rw     | rw            | rw     | rw        | rw     | rw         | rw     | rw        | rw     | rw         | rw      | rw        | rw     | rw         | гw      |
| 15  | 14     | 13            | 12     | 11        | 10     | 9          | 8      | 7         | 6      | 5          | 4       | 3         | 2      | 1          | 0       |
| CNF | 3[1:0] | MODE          | 3[1:0] | CNF       | 2[1:0] | MODE       | 2[1:0] | CNF       | 1[1:0] | MODE       | E1[1:0] | CNF       | 0[1:0] | MODE       | E0[1:0] |
| rw  | rw     | rw            | rw     | rw        | rw     | rw         | rw     | rw        | rw     | rw         | rw      | rw        | rw     | гw         | ΓW      |



### GPIOx\_CRL :MODEy[1:0]

RCC->APB2ENR |= RCC\_APB2ENR\_IOPCEN;

**GPIOC->CRL &= ~GPIO\_CRL\_MODE0;** 



### GPIOx\_CRL :CNFy[1:0]

#### **In input mode (MODE[1:0]=00)**

00: Analog mode

01: Floating input (reset state)

10: Input with pull-up / pull-down

11: Reserved

| 31  | 30                   | 29 | 28      | 27        | 26 | 25         | 24 | 23        | 22 | 21         | 20 | 19        | 18 | 17         | 16      |
|-----|----------------------|----|---------|-----------|----|------------|----|-----------|----|------------|----|-----------|----|------------|---------|
| CNF | CNF7[1:0] MODE7[1:0] |    | E7[1:0] | CNF6[1:0] |    | MODE6[1:0] |    | CNF5[1:0] |    | MODE5[1:0] |    | CNF4[1:0] |    | MODE4[1:0] |         |
| rw  | rw                   | rw | rw      | rw        | rw | rw         | rw | rw        | rw | rw         | rw | rw        | rw | rw         | rw      |
| 15  | 14                   | 13 | 12      | 11        | 10 | 9          | 8  | 7         | 6  | 5          | 4  | 3         | 2  | 1          | 0       |
| CNF | CNF3[1:0] MODE3[1:0] |    | E3[1:0] | CNF2[1:0] |    | MODE2[1:0] |    | CNF1[1:0] |    | MODE1[1:0] |    | CNF0[1:0] |    | MODE       | E0[1:0] |
| rw  | rw                   | rw | rw      | rw        | rw | rw         | rw | rw        | rw | rw         | rw | rw        | rw | rw         | rw      |



### GPIOx\_CRL :CNFy[1:0]

```
RCC->APB2ENR |= RCC_APB2ENR_IOPCEN;
GPIOC->CRL |= GPIO_CRL_MODE0;
GPIOC->CRL &= ~GPIO_CRL_CNF0;
GPIOC->CRL |= ~GPIO_CRL_CNF0_1;
```



### Pull-down/Pull-up

Table 20. Port bit configuration table

| Configuration mode |                 | CNF1     | CNF0 | MODE1         | MODE0   | PxODR<br>register |
|--------------------|-----------------|----------|------|---------------|---------|-------------------|
| General purpose    | Push-pull       | 0        | 0    | 0             | 1       | 0 or 1            |
| output             | Open-drain      |          | 1    |               | 0       | 0 or 1            |
| Alternate Function | Push-pull       | 1        | 0    |               | 1       | Don't care        |
| output             | Open-drain      | <b>'</b> | 1    | see <i>la</i> | able 21 | Don't care        |
|                    | Analog          | 0        | 0    | - 00          |         | Don't care        |
| Input              | Input floating  |          | 1    |               |         | Don't care        |
| Input              | Input pull-down | 1        | 0    |               | U       | 0                 |
|                    | Input pull-up   | '        |      |               |         | 1                 |



#### **GPIOx\_ODR**

```
GPIOC->CRL &= ~GPIO_CRL_CNF0;
GPIOC->CRL |= ~GPIO_CRL_CNF0_1;
GPIOC->ODR |= GPIO_ODR_ODR0;
```



### **AFIO\_EXTICR1**





## RCC\_APB2ENR :AFION

| RCC->APB2ENR  = RCC_APB2ENR_AFIOEN; |  |
|-------------------------------------|--|
|                                     |  |
|                                     |  |
|                                     |  |
|                                     |  |
|                                     |  |
|                                     |  |
|                                     |  |



### AFIO\_EXTICR1

Bits 15:0 **EXTIX[3:0]:** EXTI x configuration (x= 0 to 3)

These bits are written by software to select the source input for EXTIx external interrupt.

Refer to Section 10.2.5: External interrupt/event line mapping

0000: PA[x] pin 0001: PB[x] pin 0010: PC[x] pin 0011: PD[x] pin 0100: PE[x] pin

0100: PE[x] pin 0101: PF[x] pin 0110: PG[x] pin

| 31 | 30   | 29     | 28 | 27 | 26   | 25     | 24   | 23    | 22   | 21     | 20 | 19 | 18   | 17     | 16 |
|----|------|--------|----|----|------|--------|------|-------|------|--------|----|----|------|--------|----|
|    |      |        |    |    |      |        | Rese | erved |      |        |    |    |      |        |    |
| 15 | 14   | 13     | 12 | 11 | 10   | 9      | 8    | 7     | 6    | 5      | 4  | 3  | 2    | 1      | 0  |
|    | EXTI | 3[3:0] |    |    | EXTI | 2[3:0] |      |       | EXTI | 1[3:0] |    |    | EXTI | 0[3:0] |    |
| rw | rw   | rw     | rw | rw | rw   | rw     | rw   | rw    | rw   | rw     | rw | rw | rw   | rw     | rw |



### **EXT Interrupt controller**

Figure 20. External interrupt/event controller block diagram AMBA APBbus PCLK2-Peripheral interface 19 **√19 ∤19 ∤19 ∤19** Software Rising **Falling** Interrupt Pending trigger trigger interrupt mask request selection selection event register register register register **FTSR** register 19 /19 19 To NVIC interrupt 19 controller Edge detect Pulse Input **1**9 **1**9 circuit generator Line **Event** mask register

MS19816V1



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

Falling trigger event configuration bit of line x 0: Falling trigger **disabled** for input line

1: Falling trigger **enabled** for input line.

| 31   | 30   | 29   | 28   | 27   | 26   | 25    | 24  | 23  | 22  | 21  | 20  | 19   | 18   | 17   | 16   |  |
|------|------|------|------|------|------|-------|-----|-----|-----|-----|-----|------|------|------|------|--|
|      |      |      |      |      | Dan  | - m d |     |     |     |     |     | TR19 | TR18 | TR17 | TR16 |  |
|      |      |      |      |      | Res  | erved |     |     |     |     |     | 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   |  |



#### EXTI\_FTSR

**EXTI->FTSR** |= **EXTI\_FTSR\_TR0**;

OR

**EXTI->FTSR &= ~EXTI\_FTSR\_TR0**;



### **EXT Interrupt controller**

Figure 20. External interrupt/event controller block diagram AMBA APBbus PCLK2-Peripheral interface 19 **√19** 19 **∤19 ∤19** Software Rising Falling Interrupt Pending trigger trigger interrupt mask request selection selection event register register register register register **RTSR** 19 To NVIC interrupt 19 controller Edge detect Pulse Input **1**9 **1**9 circuit generator Line **Event** mask register

MS19816V1



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

Rising trigger event configuration bit of line x

0: Rising trigger **disabled** for input line

1: Rising trigger **enabled** for input line.

| 31   | 30   | 29   | 28   | 27   | 26   | 25    | 24  | 23  | 22  | 21  | 20  | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|-------|-----|-----|-----|-----|-----|------|------|------|------|
|      |      |      |      |      | Das  |       |     |     |     |     |     | TR19 | TR18 | TR17 | TR16 |
|      |      |      |      |      | Res  | erved |     |     |     |     |     | 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   |



#### EXTI\_RTSR

EXTI->RTSR &= ~EXTI\_RTSR\_TR0;

OR

**EXTI->RTSR** |= **EXTI\_RTSR\_TR0**;



### **EXT Interrupt controller**

Figure 20. External interrupt/event controller block diagram AMBA APBbus PCLK2-Peripheral interface 19 **∤19 ∤19 SWIER** Software Rising Falling Interrupt Pending trigger trigger interrupt mask request selection selection event register register register register register /19 19 19 To NVIC interrupt 19 controller Edge detect Pulse Input **1**9 **1**9 circuit generator Line **Event** mask register

MS19816V1



### **EXT Interrupt controller**

Figure 20. External interrupt/event controller block diagram AMBA APBbus PCLK2-Peripheral interface **∤19 ∤19 ∤19 ∤19 IMR** Software Rising Falling Interrupt Pending trigger trigger interrupt mask request selection selection event register register register register register /19 19 19 To NVIC interrupt 19 controller Edge detect Pulse Input **1**9 **1**9 circuit generator Line **Event** mask register

MS19816V1



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

Interrupt Mask on line x

0: Interrupt request from Line x is masked

1: Interrupt request from Line x is **not masked** 

| 31   | 30   | 29   | 28   | 27   | 26   | 25    | 24  | 23  | 22  | 21  | 20  | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|-------|-----|-----|-----|-----|-----|------|------|------|------|
|      |      |      |      |      | Pos  | erved |     |     |     |     |     | MR19 | MR18 | MR17 | MR16 |
|      |      |      |      |      | Kesi | erveu |     |     |     |     |     | 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   |



### EXTI\_IMR

```
EXTI->IMR |= EXTI_IMR_MR0;
```



### **EXT Interrupt controller**

Figure 20. External interrupt/event controller block diagram AMBA APBbus PCLK2-Peripheral interface **∤19 √19** 19 **∤19 ∤19** PR Software Rising Falling Interrupt Pending trigger trigger interrupt mask request selection selection event register register register register register /19 19 19 To NVIC interrupt 19 controller Edge detect Pulse Input **1**9 **1**9 circuit generator Line **Event** mask register

MS19816V1



### **EXT Interrupt controller**



MS19816V1



#### **Contact us**



tarasarpoolaki@gmail.com

amin.feizi751381@gmail.com



www.linkedin.com/in/Tara-Sarpoolaki

www.linkedin.com/in/aminfeizishahri