

UTAustinX: UT.6.01x Embedded Systems - Shape the World

KarenWest (/dashboard)

Courseware (/courses/UTAustinX/UT.6.01x/1T2014/courseware)

Course Info (/courses/UTAustinX/UT.6.01x/1T2014/info)

Discussion (/courses/UTAustinX/UT.6.01x/1T2014/discussion/forum)

Progress (/courses/UTAustinX/UT.6.01x/1T2014/progress)

Questions (/courses/UTAustinX/UT.6.01x/1T2014/a3da417940af4ec49a9c02b3eae3460b/)

Syllabus (/courses/UTAustinX/UT.6.01x/1T2014/a827a8b3cc204927b6efaa49580170d1/)

On most embedded microcontrollers, the I/O ports are memory mapped. This means the software can access an input/output port simply by reading from or writing to the appropriate address. It is important to realize that even though I/O operations "look" like reads and writes to memory variables, the I/O ports often DO NOT act like memory. For example, some bits are read-only, some are write-only, some can only be cleared, others can only be set, and some bits cannot be modified. To make our software more readable we include symbolic definitions for the I/O ports. We set the direction register (e.g., GPIO\_PORTF\_DIR\_R) to specify which pins are input and which are output. Individual port pins can be general purpose I/O (GPIO) or have an alternate function. We will set bits in the alternate function register (e.g., GPIO\_PORTF\_AFSEL\_R) when we wish to activate the alternate functions listed in Table 6.1. For each I/O pin we wish to use whether GPIO or alternate function we must enable the digital circuits by setting the bit in the enable register (e.g., GPIO\_PORTF\_DEN\_R). Typically, we write to the direction and alternate function registers once during the initialization phase. We use the data register (e.g., GPIO\_PORTF\_DATA\_R) to perform input/output on the port. Conversely, we read and write the data register multiple times to perform input and output respectively during the running phase. Table 6.2 shows some of the parallel port registers for the LM4F120/TM4C123. The only differences among the Stellaris and Tiva families are the number of ports and available pins in each port.

| Address     | 7    | 6    | 5     | 4     | 3     | 2     | 1     | 0     | Name               |
|-------------|------|------|-------|-------|-------|-------|-------|-------|--------------------|
| \$400F.E108 |      |      | GPIOF | GPIOE | GPIOD | GPIOC | GPIOB | GPIOA | SYSCTL_RCGC2_R     |
| \$4000.43FC | DATA | DATA | DATA  | DATA  | DATA  | DATA  | DATA  | DATA  | GPIO_PORTA_DATA_R  |
| \$4000.4400 | DIR  | DIR  | DIR   | DIR   | DIR   | DIR   | DIR   | DIR   | GPIO_PORTA_DIR_R   |
| \$4000.4420 | SEL  | SEL  | SEL   | SEL   | SEL   | SEL   | SEL   | SEL   | GPIO_PORTA_AFSEL_R |
| \$4000.4510 | PUE  | PUE  | PUE   | PUE   | PUE   | PUE   | PUE   | PUE   | GPIO_PORTA_PUR_R   |
| \$4000.451C | DEN  | DEN  | DEN   | DEN   | DEN   | DEN   | DEN   | DEN   | GPIO_PORTA_DEN_R   |
| \$4000.4524 | 1    | 1    | 1     | 1     | 1     | 1     | 1     | 1     | GPIO_PORTA_CR_R    |
| \$4000.4528 | 0    | 0    | 0     | 0     | 0     | 0     | 0     | 0     | GPIO_PORTA_AMSEL_R |
| \$4000.53FC | DATA | DATA | DATA  | DATA  | DATA  | DATA  | DATA  | DATA  | GPIO_PORTB_DATA_R  |
| \$4000.5400 | DIR  | DIR  | DIR   | DIR   | DIR   | DIR   | DIR   | DIR   | GPIO_PORTB_DIR_R   |
| \$4000.5420 | SEL  | SEL  | SEL   | SEL   | SEL   | SEL   | SEL   | SEL   | GPIO_PORTB_AFSEL_R |

1 of 4 02/17/2014 10:17 AM

| =       |  |
|---------|--|
| <u></u> |  |
| w       |  |
| _       |  |
| _       |  |
|         |  |

| G | PIO Regis   | sters   6. | 3 I/O PI | rogramn | ning and | 1 t      |          | nttp  | s://cour | ses.eax.org/course |
|---|-------------|------------|----------|---------|----------|----------|----------|-------|----------|--------------------|
|   | \$4000.5510 | PUE        | PUE      | PUE     | PUE      | PUE      | PUE      | PUE   | PUE      | GPIO_PORTB_PUR_R   |
|   | \$4000.551C | DEN        | DEN      | DEN     | DEN      | DEN      | DEN      | DEN   | DEN      | GPIO_PORTB_DEN_R   |
|   | \$4000.5524 | 1          | 1        | 1       | 1        | 1        | 1        | 1     | 1        | GPIO_PORTB_CR_R    |
|   | \$4000.5528 | 0          | 0        | AMSEL   | AMSEL    | 0        | 0        | 0     | 0        | GPIO_PORTB_AMSEL_R |
|   | \$4000.63FC | DATA       | DATA     | DATA    | DATA     | JTAG     | JTAG     | JTAG  | JTAG     | GPIO_PORTC_DATA_R  |
|   | \$4000.6400 | DIR        | DIR      | DIR     | DIR      | JTAG     | JTAG     | JTAG  | JTAG     | GPIO_PORTC_DIR_R   |
|   | \$4000.6420 | SEL        | SEL      | SEL     | SEL      | JTAG     | JTAG     | JTAG  | JTAG     | GPIO_PORTC_AFSEL_R |
|   | \$4000.6510 | PUE        | PUE      | PUE     | PUE      | JTAG     | JTAG     | JTAG  | JTAG     | GPIO_PORTC_PUR_R   |
|   | \$4000.651C | DEN        | DEN      | DEN     | DEN      | JTAG     | JTAG     | JTAG  | JTAG     | GPIO_PORTC_DEN_R   |
|   | \$4000.6524 | 1          | 1        | 1       | 1        | JTAG     | JTAG     | JTAG  | JTAG     | GPIO_PORTC_CR_R    |
|   | \$4000.6528 | AMSEL      | AMSEL    | AMSEL   | AMSEL    | JTAG     | JTAG     | JTAG  | JTAG     | GPIO_PORTC_AMSEL_R |
|   | \$4000.73FC | DATA       | DATA     | DATA    | DATA     | DATA     | DATA     | DATA  | DATA     | GPIO_PORTD_DATA_R  |
|   | \$4000.7400 | DIR        | DIR      | DIR     | DIR      | DIR      | DIR      | DIR   | DIR      | GPIO_PORTD_DIR_R   |
|   | \$4000.7420 | SEL        | SEL      | SEL     | SEL      | SEL      | SEL      | SEL   | SEL      | GPIO_PORTD_AFSEL_R |
|   | \$4000.7510 | PUE        | PUE      | PUE     | PUE      | PUE      | PUE      | PUE   | PUE      | GPIO_PORTD_PUR_R   |
|   | \$4000.751C | DEN        | DEN      | DEN     | DEN      | DEN      | DEN      | DEN   | DEN      | GPIO_PORTD_DEN_R   |
|   | \$4000.7524 | CR         | 1        | 1       | 1        | 1        | 1        | 1     | 1        | GPIO_PORTD_CR_R    |
|   | \$4000.7528 | 0          | 0        | AMSEL   | AMSEL    | AMSEL    | AMSEL    | AMSEL | AMSEL    | GPIO_PORTD_AMSEL_R |
|   | \$4002.43FC |            |          | DATA    | DATA     | DATA     | DATA     | DATA  | DATA     | GPIO_PORTE_DATA_R  |
|   | \$4002.4400 |            |          | DIR     | DIR      | DIR      | DIR      | DIR   | DIR      | GPIO_PORTE_DIR_R   |
|   | \$4002.4420 |            |          | SEL     | SEL      | SEL      | SEL      | SEL   | SEL      | GPIO_PORTE_AFSEL_R |
|   | \$4002.4510 |            |          | PUE     | PUE      | PUE      | PUE      | PUE   | PUE      | GPIO_PORTE_PUR_R   |
|   | \$4002.451C |            |          | DEN     | DEN      | DEN      | DEN      | DEN   | DEN      | GPIO_PORTE_DEN_R   |
|   | \$4002.4524 |            |          | 1       | 1        | 1        | 1        | 1     | 1        | GPIO_PORTE_CR_R    |
|   | \$4002.4528 |            |          | AMSEL   | AMSEL    | AMSEL    | AMSEL    | AMSEL | AMSEL    | GPIO_PORTE_AMSEL_R |
|   | \$4002.53FC |            |          |         | DATA     | DATA     | DATA     | DATA  | DATA     | GPIO_PORTF_DATA_R  |
|   | \$4002.5400 |            |          |         | DIR      | DIR      | DIR      | DIR   | DIR      | GPIO_PORTF_DIR_R   |
|   |             | <b></b>    | <b>!</b> |         | <b></b>  | <b>L</b> | <b>L</b> | ·     |          |                    |

2 of 4 02/17/2014 10:17 AM

| ᅀ        |
|----------|
| <u>o</u> |

| G      | PIO Registers   6.3 I/O Programming and t https://courses.edx.org/cou |                                                                                   |            |              |                  |                   |      |      |      | es/UTAustinX/UT    |  |  |
|--------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------|------------|--------------|------------------|-------------------|------|------|------|--------------------|--|--|
|        | \$4002.5420                                                           |                                                                                   |            |              | SEL              | SEL               | SEL  | SEL  | SEL  | GPIO_PORTF_AFSEL_R |  |  |
|        | \$4002.5510                                                           |                                                                                   |            |              | PUE              | PUE               | PUE  | PUE  | PUE  | GPIO_PORTF_PUR_R   |  |  |
|        | \$4002.551C                                                           |                                                                                   |            |              | DEN              | DEN               | DEN  | DEN  | DEN  | GPIO_PORTF_DEN_R   |  |  |
|        | \$4002.5524                                                           |                                                                                   |            |              | 1                | 1                 | 1    | 1    | CR   | GPIO_PORTF_CR_R    |  |  |
|        | \$4002.5528                                                           |                                                                                   |            |              | 0                | 0                 | 0    | 0    | 0    | GPIO_PORTF_AMSEL_R |  |  |
|        |                                                                       |                                                                                   |            |              |                  |                   |      |      |      |                    |  |  |
|        |                                                                       | 31-28                                                                             | 27-24      | 23-20        | 19-16            | 15-12             | 11-8 | 7-4  | 3-0  |                    |  |  |
|        | \$4000.452C                                                           | PMC7                                                                              | PMC6       | PMC5         | PMC4             | PMC3              | PMC2 | PMC1 | PMC0 | GPIO_PORTA_PCTL_R  |  |  |
|        | \$4000.552C                                                           | PMC7                                                                              | PMC6       | PMC5         | PMC4             | PMC3              | PMC2 | PMC1 | PMC0 | GPIO_PORTB_PCTL_R  |  |  |
|        | \$4000.652C                                                           | PMC7                                                                              | PMC6       | PMC5         | PMC4             | 0x1               | 0x1  | 0x1  | 0x1  | GPIO_PORTC_PCTL_R  |  |  |
|        | \$4000.752C                                                           | PMC7                                                                              | PMC6       | PMC5         | PMC4             | PMC3              | PMC2 | PMC1 | РМС0 | GPIO_PORTD_PCTL_R  |  |  |
|        | \$4002.452C                                                           |                                                                                   |            | PMC5         | PMC4             | РМС3              | PMC2 | PMC1 | РМС0 | GPIO_PORTE_PCTL_R  |  |  |
|        | \$4002.552C                                                           |                                                                                   |            |              | PMC4             | PMC3              | PMC2 | PMC1 | PMC0 | GPIO_PORTF_PCTL_R  |  |  |
| ב<br>ב | \$4000.6520                                                           |                                                                                   | LOCK (writ | e 0x4C4F434E | 3 to unlock, oth | GPIO_PORTC_LOCK_R |      |      |      |                    |  |  |
|        | \$4000.7520                                                           | LOCK (write 0x4C4F434B to unlock, other locks) (reads 1 if locked, 0 if unlocked) |            |              |                  |                   |      |      |      | GPIO_PORTD_LOCK_R  |  |  |
|        | \$4002.5520                                                           |                                                                                   | LOCK (writ | e 0x4C4F434E | 3 to unlock, oth | GPIO_PORTF_LOCK_R |      |      |      |                    |  |  |

Table 6.2 Some TM4C123 parallel ports. Each register is 32 bits wide. For PMCx bits, see Table 6.1. JTAG means do not use these pins and do not change any of these bits.



About (https://www.edx.org/about-us) Jobs (https://www.edx.org/jobs) Press (https://www.edx.org/press) FAQ (https://www.edx.org/student-faq) Contact (https://www.edx.org/contact)



EdX is a non-profit created by founding partners Harvard and MIT whose mission is to bring the best of higher education to students of all ages anywhere in the world, wherever there is Internet access. EdX's free online MOOCs are interactive and subjects include computer science, public health, and artificial intelligence.



(http://www.meetup.com/edX-Global-Community/)



(http://www.facebook.com/EdxOnline)



(https://twitter1cpm/edXOnline)

https://courses.edx.org/courses/UTAustinX/UT... (https://plus.google.com /108235383044095082735/posts)



(http://youtube.com/user/edxonline) © 2014 edX, some rights reserved.

Terms of Service and Honor Code - Privacy Policy (https://www.edx.org/edx-privacy-policy)

4 of 4 02/17/2014 10:17 AM