

# Microcontroller

Department of Electrical Engineering
Iran University of Science and Technology



#### **GPIO MAP**





### **GPIO MODE**





#### **PUSH PULL / OPEN DRAIN**





## **LED**





### 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         | ΓW         | rw         | rw         | rw         | rw         | rw         | ΓW         | rw          | rw          | rw         | rw         |          | rw         |



# RCC\_APB2ENR :IOPCEN

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



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

Port x mode bits (y=8...15)

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      |
|------|---------|------|---------|------|--------|------|---------|------|--------|------|---------|------|--------|------|---------|
| CNF1 | 15[1:0] | MODE | 15[1:0] | CNF1 | 4[1:0] | MODE | 14[1:0] | CNF1 | 3[1:0] | MODE | 13[1:0] | CNF1 | 2[1:0] | MODE | 12[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       |
| CNF1 | 11[1:0] | MODE | 11[1:0] | CNF1 | 0[1:0] | MODE | 10[1:0] | CNF  | 9[1:0] | MODE | 9[1:0]  | CNF  | B[1:0] | MODE | E8[1:0] |
| rw   | rw      | rw   | rw      | rw   | rw     | rw   | rw      | rw   | rw     | rw   | rw      | rw   | rw     | rw   | rw      |



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

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

**GPIOC->CRH** |= **GPIO\_CRH\_MODE9**;



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

Port x configuration bits (y= 8 .. 15) In output mode (MODE[1:0] > 00):

00: General purpose output push-pull

01: General purpose output Open-drain

10: Alternate function output Push-pull

11: Alternate function output Open-drain

| 31   | 30      | 29   | 28      | 27   | 26     | 25   | 24      | 23   | 22     | 21   | 20      | 19   | 18     | 17   | 16      |
|------|---------|------|---------|------|--------|------|---------|------|--------|------|---------|------|--------|------|---------|
| CNF1 | 15[1:0] | MODE | 15[1:0] | CNF1 | 4[1:0] | MODE | 14[1:0] | CNF1 | 3[1:0] | MODE | 13[1:0] | CNF1 | 2[1:0] | MODE | 12[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       |
| CNF1 | 11[1:0] | MODE | 11[1:0] | CNF1 | 0[1:0] | MODE | 10[1:0] | CNF  | 9[1:0] | MODE | 9[1:0]  | CNF  | 8[1:0] | MODE | E8[1:0] |
| rw   | rw      | rw   | rw      | rw   | rw     | rw   | rw      | rw   | rw     | rw   | rw      | rw   | rw     | rw   | rw      |



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

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

**GPIOC->CRH** |= **GPIO\_CRH\_MODE9**;

**GPIOC->CRH** &= ~GPIO\_CRH\_CNF9;



# **GPIO**x\_**ODR**

| 31    | 30    | 29    | 28    | 27    | 26    | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|       |       |       |       |       |       |      | Rese | rved |      |      |      |      |      |      |      |
| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ODR15 | ODR14 | ODR13 | ODR12 | ODR11 | ODR10 | ODR9 | ODR8 | ODR7 | ODR6 | ODR5 | ODR4 | ODR3 | ODR2 | ODR1 | ODR0 |
| rw    | rw    | rw    | rw    | rw    | rw    | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   |



### GPIOx\_ODR

**GPIOC->ODR** |= **GPIO\_ODR\_ODR13**;

**GPIOC->ODR** &= ~ **GPIO\_ODR\_ODR13**;



# **GPIOx\_BSRR**

Bits 15:0 Set bit y

0: No action on the corresponding ODRx bit

1: Set the corresponding ODRx bit

Bits 31:16 **Reset** bit y

0: No action on the corresponding ODRx bit

1: Reset the corresponding ODRx bit

| 31   | 30   | 29   | 28   | 27   | 26   | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| BR15 | BR14 | BR13 | BR12 | BR11 | BR10 | BR9 | BR8 | BR7 | BR6 | BR5 | BR4 | BR3 | BR2 | BR1 | BR0 |
| w    | w    | w    | w    | w    | w    | W   | W   | W   | w   | W   | w   | W   | w   | W   | w   |
| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| BS15 | BS14 | BS13 | BS12 | BS11 | BS10 | BS9 | BS8 | BS7 | BS6 | BS5 | BS4 | BS3 | BS2 | BS1 | BS0 |
| w    | w    | w    | w    | w    | w    | W   | W   | W   | W   | W   | W   | W   | w   | W   | w   |



### GPIOx\_BSRR

**GPIOC->BSRR** = **GPIO\_BSRR\_BS13**;

**GPIOC->BSRR** = **GPIO\_BSRR\_BR13**;



#### **SYSTICK**

The processor has a 24-bit system timer, SysTick, that counts down from the reload value to zero, reloads (wraps to) the value in the LOAD register on the next clock edge, then counts down on subsequent clocks.



#### **SYSTICK**





### STK\_LOAD

RELOAD[23:0]: RELOAD value The LOAD register specifies the start value to load into the VAL register when the counter is enabled and when it reaches 0.

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



### STK\_LOAD

```
uint32_t ticks = SystemCoreClock / 1000;
SysTick->LOAD = ticks - 1;
```



### STK\_VAL

CURRENT[23:0]: Current counter value
The VAL register contains the current value of the SysTick counter.

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



### STK\_LOAD

```
uint32_t ticks = SystemCoreClock / 1000;
SysTick->LOAD = ticks - 1;
```

$$SysTick->VAL=0;$$



COUNTFLAG: Returns 1 if timer counted to 0 since last time this was read

| 31 | 30 | 29 | 28 | 27 | 26 | 25      | 24      | 23 | 22 | 21 | 20 | 19 | 18            | 17          | 16            |
|----|----|----|----|----|----|---------|---------|----|----|----|----|----|---------------|-------------|---------------|
|    |    |    |    |    |    |         | Reserve | ed |    |    |    |    |               |             | COUNT<br>FLAG |
|    |    |    |    |    |    |         |         |    |    |    |    |    |               |             | rw            |
| 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8       | 7  | 6  | 5  | 4  | 3  | 2             | 1           | 0             |
|    |    |    |    |    |    | Reserve | ed      |    |    |    |    |    | CLKSO<br>URCE | TICK<br>INT | EN<br>ABLE    |
|    |    |    |    |    |    |         |         |    |    |    |    |    | rw            | rw          | rw            |



CLKSOURCE: Clock source selection

Selects the clock source.

0: AHB/8

1: Processor clock (AHB)

| 31 | 30 | 29 | 28 | 27 | 26 | 25      | 24      | 23 | 22 | 21 | 20 | 19 | 18            | 17          | 16            |
|----|----|----|----|----|----|---------|---------|----|----|----|----|----|---------------|-------------|---------------|
|    |    |    |    |    |    |         | Reserve | ed |    |    |    |    |               |             | COUNT<br>FLAG |
|    |    |    |    |    |    |         |         |    |    |    |    |    |               |             | rw            |
| 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8       | 7  | 6  | 5  | 4  | 3  | 2             | 1           | 0             |
|    |    |    |    |    |    | Reserve | ed      |    |    |    |    |    | CLKSO<br>URCE | TICK<br>INT | EN<br>ABLE    |
|    |    |    |    |    |    |         |         |    |    |    |    |    | rw            | rw          | rw            |



TICKINT: SysTick exception request enable

- 0: Counting down to zero does not assert the SysTick exception request
- 1: Counting down to zero to asserts the SysTick exception request.

| 31 | 30 | 29 | 28 | 27 | 26 | 25      | 24      | 23 | 22 | 21 | 20 | 19 | 18            | 17          | 16            |
|----|----|----|----|----|----|---------|---------|----|----|----|----|----|---------------|-------------|---------------|
|    |    |    |    |    |    |         | Reserve | d  |    |    |    |    |               |             | COUNT<br>FLAG |
|    |    |    |    |    |    |         |         |    |    |    |    |    |               |             | rw            |
| 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8       | 7  | 6  | 5  | 4  | 3  | 2             | 1           | 0             |
|    |    |    |    |    |    | Reserve | ed      |    |    |    |    |    | CLKSO<br>URCE | TICK<br>INT | EN<br>ABLE    |
|    |    |    |    |    |    |         |         |    |    |    |    |    | rw            | rw          | rw            |



**ENABLE:** Counter enable

| 31 | 30 | 29 | 28 | 27 | 26 | 25      | 24      | 23 | 22 | 21 | 20 | 19 | 18            | 17          | 16            |
|----|----|----|----|----|----|---------|---------|----|----|----|----|----|---------------|-------------|---------------|
|    |    |    |    |    |    |         | Reserve | d  |    |    |    |    |               |             | COUNT<br>FLAG |
|    |    |    |    |    |    |         |         |    |    |    |    |    |               |             | rw            |
| 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8       | 7  | 6  | 5  | 4  | 3  | 2             | 1           | 0             |
|    |    |    |    |    |    | Reserve | ed      |    |    |    |    |    | CLKSO<br>URCE | TICK<br>INT | EN<br>ABLE    |
|    |    |    |    |    |    |         |         |    |    |    |    |    | rw            | rw          | rw            |



### STK\_LOAD



### **Delay function**

```
volatile uint32_t msTicks = 0;
void SysTick_Handler(void) {
  if (msTicks > 0) {
    msTicks--;
void delay_ms(uint32_t ms) {
  msTicks = ms;
  while (msTicks > 0) { }
```



#### **Contact us**



tarasarpoolaki@gmail.com

amin.feizi751381@gmail.com



www.linkedin.com/in/Tara-Sarpoolaki

www.linkedin.com/in/aminfeizishahri