# ECE 271 Microcomputer Architecture and Applications Lab 9: Timer Input Capture in Assembly Instructor: Prof. Yifeng Zhu Spring 2016

#### Goals

- 1. Know how to modularize your codes by using assembly functions and placing assembly functions in separate source files.
- 2. Learn how to call a C function from assembly
- 3. Get familiar with API standards, especially passing arguments to C functions from assembly, passing arguments to assembly functions

## **Pre-Lab Assignment**

- 1. Read Chapter 10 Mixing C and Assembly of the Textbook
- 2. Read Chapter 15 Timers of the Textbook.

## **In-Lab Requirements**

- Re-do your previous lab in assembly.
- Your project should call the LCD C functions to display the measurement.
- Your project should include at least two assembly files
  - o main.s (read your measurement and display it on LCD)
  - o timer.s (all your timer-related function should be in this file)

# **ECE 271 Microcomputer Architecture and Applications**

## Lab 8 Timer Input Capture Pre-Lab Assignment

| <b>Student Name:</b> |  |
|----------------------|--|
| Student Name:        |  |

#### 1. Configure RCC\_AHBENR to enable the clock of GPIO Port B

| Register | 31       | 30     | 29       | 28 | 27    | 26       | 25     | 24     | 23 | 22 | 21 | 20  | 19   | 18 | 17 | 16 | 15      | 14 | 13       | 12    | 11 | 10  | 6    | 8   |          | 9               | 2 | 4        | 3        | 2        | 1        | 0        |
|----------|----------|--------|----------|----|-------|----------|--------|--------|----|----|----|-----|------|----|----|----|---------|----|----------|-------|----|-----|------|-----|----------|-----------------|---|----------|----------|----------|----------|----------|
| AHBENR   | Reserved | FSMCEN | Reserved | 3  | AESEN | Reserved | DMA2EN | DMA1EN |    |    | R  | ese | erve | ed |    |    | FLITFEN |    | Reserved | CRCEN |    | Res | serv | ⁄ed | GPIOPGEN | <b>NBHAOIAS</b> | O | GPIOPEEN | GPIOPDEN | GPIOPCEN | GPIOPBEN | GPIOPAEN |
| Mask     | ш.       |        |          | •  |       | _        |        |        |    |    |    |     |      |    |    |    |         |    |          |       |    |     |      |     |          |                 |   |          |          |          |          |          |
| Value    |          |        |          |    |       |          |        |        |    |    |    |     |      |    |    |    |         |    |          |       |    |     |      |     |          |                 |   |          |          |          |          |          |

Write your assembly code below to enable the GPIO B clock:

# 2. Configure RCC\_APB1ENR to enable the clock of Timer 2 and Timer 4

| Register | 31     | 30       | 29    | 28    | 27 | 26  | 25   | 24 | 23    | 22     | 21     | 20       | 19       | 18              | 17              | 16       | 15     | 14     | 13 | 12       | 11     | 10       | 6     | 8  | 7    | 9   | 2      | 4      | 3      | 2      | 1      | 0      |
|----------|--------|----------|-------|-------|----|-----|------|----|-------|--------|--------|----------|----------|-----------------|-----------------|----------|--------|--------|----|----------|--------|----------|-------|----|------|-----|--------|--------|--------|--------|--------|--------|
| APB1ENR  | COMPEN | Reserved | DACEN | PWREN | R  | ese | erve | ed | USBEN | I2C2EN | I2C1EN | USART5EN | USART4EN | <b>USART3EN</b> | <b>USART2EN</b> | Reserved | SPI3EN | SPI2EN |    | Reserved | WWDGEN | Reserved | LCDEN | Re | serv | ved | TIM7EN | TIMGEN | TIMSEN | TIM4EN | TIM3EN | TIM2EN |
| Mask     |        |          |       |       |    |     |      |    |       |        |        |          |          |                 |                 |          |        |        |    |          |        |          |       |    |      |     |        |        |        |        |        |        |
| Value    |        |          |       |       |    |     |      |    |       |        |        |          |          |                 |                 |          |        |        |    |          |        |          |       |    |      |     |        |        |        |        |        |        |

Write your assembly code below to enable the clock of Timer 2 and 4:

## 3. Configure PB 6 as Alternative Function Mode

GPIO Mode: Input (00, reset), Output (01), AlterFunc (10), Analog (11)

| Register       | 31           | 29           | 27<br>26     | 25<br>24     | 23           | 22 | 21<br>20     | 19          | 17          | 15          | 13          | 11          | 6 8         | 7           | 5           | 2           | 1          |
|----------------|--------------|--------------|--------------|--------------|--------------|----|--------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------------|
| GPIOB<br>MODER | MODER15[1:0] | MODER14[1:0] | MODER13[1:0] | MODER12[1:0] | MODER11[1:0] |    | MODER10[1:0] | MODER9[1:0] | MODER8[1:0] | MODER7[1:0] | MODER6[1:0] | MODER5[1:0] | MODER4[1:0] | MODER3[1:0] | MODER2[1:0] | MODER1[1:0] | MODER0[:0] |
| Mask           |              |              |              |              |              |    |              |             |             |             |             |             |             |             |             |             |            |
| Value          |              |              |              |              |              |    |              |             |             |             |             |             |             |             |             |             |            |

GPIOB Mode Register MASK Value = 0x\_\_\_\_\_\_\_ (in HEX)
GPIOB Mode Register Value = 0x\_\_\_\_\_\_\_ (in HEX)

## 4. Configure and Select the Alternative Function for PB 6



GPIOx\_AFRL[31:00] defines the alternate function for pins 0 to 7, and GPIO\_AFHL for pins 8 to 15.

| Register        | 31 | 30   | 29  | 28  | 27 | 26  | 25   | 24 | 23 | 22  | 21   | 20  | 19 | 18   | 17   | 16 | 15 | 14  | 13   | 12  | 11 | 10   | 6    | 8  | 7  | 9   | 2   | 4   | 3  | 7   | - (   | 0  |
|-----------------|----|------|-----|-----|----|-----|------|----|----|-----|------|-----|----|------|------|----|----|-----|------|-----|----|------|------|----|----|-----|-----|-----|----|-----|-------|----|
| GPIOB<br>AFR[0] | AF | 'RL' | 7[3 | :0] | AF | RL6 | 5[3: | 0] | AF | 'RL | 5[3: | :0] | AF | 'RL₄ | 4[3: | 0] | Α  | FRL | 3[3، | :0] | AF | 'RL2 | 2[3: | 0] | AF | 7RL | 1[3 | :0] | AF | RL( | )[3:( | )] |
| MASK            |    |      |     |     |    |     |      |    |    |     |      |     |    |      |      |    |    |     |      |     |    |      |      |    |    |     |     |     |    |     |       |    |
| VALUE           |    |      |     |     |    |     |      |    |    |     |      |     |    |      |      |    |    |     |      |     |    |      |      |    |    |     |     |     |    |     |       | _  |

GPIOB Alternative Function Register [0] MASK = 0x\_\_\_\_\_\_\_ (in HEX)

GPIOB Alternative Function Register [0] = 0x\_\_\_\_\_\_ (in HEX)

5. Complete the following table to configure the Input Capture for Channel 1 of Timer 4

| 3. Con                              | Г  | T              |    | T  |    | Т  | Т  | T    | Т    | Т   | T  | Т  | Т    | Г   | Т   | Т  |       |          |          |            | I        |                 |       |            |          |          | 1                 |       |                |                |           |            |
|-------------------------------------|----|----------------|----|----|----|----|----|------|------|-----|----|----|------|-----|-----|----|-------|----------|----------|------------|----------|-----------------|-------|------------|----------|----------|-------------------|-------|----------------|----------------|-----------|------------|
| Register                            | 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24   | 23   | 22  | 21 | 20 | 19   | 18  | 17  | 16 | 15    | 14       | 13       | 12         | 7        | 10              | 6     | ∞          | 7        | 9        | 2                 | 4     | က              | 7              | _         | 0          |
| TIMx_CR1                            |    |                |    |    |    |    |    |      |      |     | R  | es | erve | ed  |     |    |       |          |          |            |          |                 |       | KD<br>:0]  | ARPE     | CI<br>[1 | MS<br>:0]         | DIR   | OPM            | URS            | NDIS      | CEN        |
| Value                               |    |                |    |    |    |    |    |      |      |     |    |    |      |     |     |    |       |          |          |            |          |                 |       |            |          |          |                   |       |                |                |           |            |
| TIMx_CR2                            |    |                |    |    |    |    |    |      |      |     |    |    | Res  | er  | vec | i  |       |          |          |            |          |                 |       |            | TI1S     |          | MMS<br>[2:0]      |       | CCDS           | Re             | ser       | ved        |
| Value                               |    |                |    |    |    |    |    |      |      |     |    |    |      |     |     |    |       |          |          |            |          |                 |       |            |          |          |                   |       |                |                |           |            |
| TIMx_SMCR                           |    |                |    |    |    |    | R  | lese | rv   | ed  |    |    |      |     |     |    | ETP   | ECE      | S [      | TP<br>1:0] |          | ETF             | [3:0  | )]         | MSM      | Т        | S[2:              | 0]    | Reserved       | SN             | 1S[2      | 2:0]       |
| Value                               |    |                |    |    |    |    |    |      |      |     |    |    |      |     |     |    |       |          |          |            |          |                 |       |            |          |          |                   |       |                |                |           |            |
| TIMx_DIER                           |    | Reserved       |    |    |    |    |    |      |      |     |    |    |      |     |     |    |       | TDE      | COMDE    | CC4DE      | CC3DE    | CC2DE           | CC1DE | NDE        | Reserved | 믣        | Reserved          | CC4IE | CC3IE          | CC2IE          | CC1IE     | OIE        |
| Value                               |    |                |    |    |    |    |    |      |      |     |    |    |      |     |     |    |       | <u> </u> |          | <u>.</u>   |          |                 |       |            |          |          |                   |       |                |                |           |            |
| TIMx_SR                             |    | Reserved CC30F |    |    |    |    |    |      |      |     |    |    |      |     |     |    | CC10F |          | Keserved | Ŧ          | Reserved | CC4IF           | CC3IF | CC2IF      | CC11F    | UIF      |                   |       |                |                |           |            |
| Value                               |    |                |    |    |    |    |    |      |      |     |    |    |      |     |     |    |       |          |          |            |          |                 |       |            | <u>۲</u> |          | 2                 |       |                |                |           |            |
| TIMx_EGR                            |    |                |    |    |    |    |    |      |      |     |    |    | R    | .es | erv | ed |       |          |          |            |          |                 |       |            |          | TG       | Reserved          | CC4G  | CC3G           | CC2G           | CC1G      | ne         |
| Value                               |    |                |    |    |    |    |    |      |      |     |    |    |      |     |     |    |       |          |          |            | I        |                 |       |            | 1        |          | 2                 |       |                |                |           |            |
| TIMx_CCMR1<br>Input Capture<br>mode |    |                |    |    |    |    | R  | lese | rv   | ed  |    |    |      |     |     |    | ľ     | C2F      | [3:0     | 0]         | P        | C2<br>SC<br>:0] | S[    | C2<br>1:0] | I        | C1F      | <del>-</del> [3:0 | )]    | IC<br>PS<br>[1 | SC             | C(<br>S [ | C1<br>1:0] |
| Value                               |    |                |    |    |    |    |    |      |      |     |    |    |      |     |     |    |       |          |          |            |          |                 |       |            |          |          |                   |       |                |                |           |            |
| TIMx_CCMR2<br>Input Capture<br>mode |    |                |    |    |    |    | R  | lese | rv   | ed  |    |    |      |     |     |    | Į,    | C4F      | [3:      | 0]         | P        | C4<br>SC<br>:0] |       | C4<br>1:0] | I        | C3F      | -[3:0             | )]    |                | 3<br>SC<br>:0] |           | C3<br>1:0] |
| Value                               |    |                |    |    |    |    | 1\ |      | ,1 V | cu  |    |    |      |     |     |    |       |          |          |            |          |                 |       |            |          |          |                   |       |                |                |           |            |
| TIMx_CCER                           |    |                |    |    |    |    | R  | ese  | erv  | ⁄e( | d  |    |      |     |     |    | CC4NP |          | CC4P     | CC4E       | CC3NP    |                 | CC3P  | CC3E       | CC2NP    |          | CC2P              | CC2E  | CC1NP          |                | CC1P      | CC1E       |

| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    | 0 |     | erv | 0   | 0 | 0  | erv  | 0   | 0    | 0     | erv   | 0   | 0 | 0  | erv  | 0   | 0        |
|-----------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----|---|-------------|-----|-----|-----|-----|-----|-----|------|----|---|-----|-----|-----|---|----|------|-----|------|-------|-------|-----|---|----|------|-----|----------|
| TIMx_CNT  | С                                                                 | N٦                                                                                                                                                                                                                                             | [32  | 2:1 | 6]  |   | M5<br>ther  |     |     |     | er∖ | /ed | O   | n th | ne |   |     |     |     | I |    |      | C   | NT   | 15:0  |       |     | 1 |    |      | I   |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIMx_PSC  |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   | Dog         |     |     | 1   |     |     |     |      |    |   |     |     |     |   |    |      | F   | PSC[ | 15:0  | )]    |     |   |    |      |     |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   | Res         | erv | vea | L   |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIMx_ARR  | Α                                                                 | RF                                                                                                                                                                                                                                             | R[32 | 2:1 | 6]  |   | M5<br>ther  |     |     |     | er۱ | /ed | 0   | n th | ne |   |     |     |     |   |    |      | A   | RR   | [15:0 | 0]    |     |   |    |      |     |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIMx_CCR1 | C                                                                 | CR                                                                                                                                                                                                                                             | 1[3  | 2:  | 16] |   | IM5<br>ther |     |     |     | er  | vec | d c | n t  | he |   |     |     |     |   |    |      | С   | CR1  | [15:  | 0]    |     |   |    |      |     |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIMx_CCR2 | C                                                                 | CR                                                                                                                                                                                                                                             | 4[3  | 2:  | 16] |   |             |     |     |     | er  | vec | d c | n t  | he |   |     |     |     |   |    |      | С   | CR2  | [15:  | 0]    |     |   |    |      |     |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIMx_CCR3 | CCR4[32:16] (TIM5 only, reserved on the other timers)  CCR3[15:0] |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIMx_CCR4 | C                                                                 | CCR4[32:16] (TIM5 only, reserved on the other timers)         CCR2[15:0]           CCR4[32:16] (TIM5 only, reserved on the other timers)         CCR3[15:0]           CCR4[32:16] (TIM5 only, reserved on the other timers)         CCR4[15:0] |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIMx_DCR  |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             | R   | les | erv | e(  | d   |     |      |    |   |     |     |     |   | DI | 3L[4 | :0] |      |       | Reser | ved |   | DE | 8A[4 | :0] |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     | -   |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIMx_DMAR |                                                                   |                                                                                                                                                                                                                                                |      |     |     | 1 | Res         | er  | vec | ł   |     |     |     |      |    |   |     |     |     |   |    |      | DI  | MAE  | 3[15  | :0]   |     |   |    |      |     |          |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   | ites        | C1  | vcc |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIM2_OR   |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    | F | Res | ser | ved | l |    |      |     |      |       |       |     |   |    |      |     | ITR1_RMP |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |
| TIM3_OR   |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    | F | Res | ser | ved | l |    |      |     |      |       |       |     |   |    |      |     | ITR2_RMP |
| Value     |                                                                   |                                                                                                                                                                                                                                                |      |     |     |   |             |     |     |     |     |     |     |      |    |   |     |     |     |   |    |      |     |      |       |       |     |   |    |      |     |          |

## **ECE 271 Microcomputer Architecture and Applications**

## Lab 8 Timer Input Capture In-Lab Demo

#### Part 1: Measure the period of 1 Hz square signal

- Basic requirement: In the debug environment, show the period you have measured. Record the accuracy for the post-lab assignment.
- Something cool: for example, show time measurements on LCD.

#### Part 2: Interface with Ultrasonic distance sensor

- Basic requirement: In the debug environment, show the distance you have measured. . Record the accuracy for the post-lab assignment.
- Something cool: for example, show distance measurements on LCD.

#### **ECE 271 Microcomputer Architecture and Applications**

## Lab 8 Timer Input Capture Post-Lab Assignment

#### Write your answers to Readme.md and submit it to Gitlab server:

- 1. Does the timer counter count up or down in your lab? If counting up, how did you handle the counter overflow? (If counting down, how did you handle the counter underflow?)
- 2. What is the accuracy when measuring the period of 1Hz square wave?
- 3. What is the accuracy of the distance you have measured?
- 4. What is the most challenge issue you had in this lab?
- 5. Do you have any suggestions or comments of this lab?
- 6. Do you have any comments of the textbook?