## **4357.(008) Embedded Firmware Essentials Spring 2015**

Toggle a GPIO Pin File: toggle\_gpio.c

Goal: write a code to toggle a GPIO pin as fast as possible.

Fast Read LPC178 schematics and data sheets
 http://developer.mbed.org/platforms/mbed-LPC1768/
 http://www.nxp.com/documents/user\_manual/UM10360.pdf (Chapter 9: GPIO)

- 2. Read ARM Cortex-M3 Datasheet
  - a. <a href="http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.ddi0337h/CHDDIGAC.html">http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.ddi0337h/CHDDIGAC.html</a>
  - b. <a href="https://ece.uwaterloo.ca/~ece222/ARM/ARM7-TDMI-manual-pt3.pdf">https://ece.uwaterloo.ca/~ece222/ARM/ARM7-TDMI-manual-pt3.pdf</a>
  - c. <a href="http://infocenter.arm.com/help/topic/com.arm.doc.ddi0337h/DDI0337H\_cortex\_m3\_r2p0\_trm.pdf">http://infocenter.arm.com/help/topic/com.arm.doc.ddi0337h/DDI0337H\_cortex\_m3\_r2p0\_trm.pdf</a>
- 3. write a C code to toggle a GPIO pin as fast as possible
- 4. study machine code output from objdump
- 5. write a page report to tell me the meaning of each bit of the machine code of the while loop body only.

(you may ignore all machine code before and after the while loop.)

| gcc commands:                                                           |
|-------------------------------------------------------------------------|
| \$ arm-none-eabi-gcc -mcpu=cortex-m3 -mthumb -c hw01.c -o hw01.o        |
| \$ arm-none-eabi-gcc -mcpu=cortex-m3 -mthumb -O3 -c hw01.c -o hw01_O3.o |
| \$ arm-none-eabi-gcc -mcpu=cortex-m3 -mthumb -Os -c hw01.c -o hw01_Os.o |
| \$ arm-none-eabi-objdump -d hw01.o                                      |

| Xia         | Andrew      | drew.xia@gmail.com         | mbed: PIN: 5 = DIP5 = P0.9 |  |
|-------------|-------------|----------------------------|----------------------------|--|
| Varma       | Kripa       | kripa.varma@gmail.com      | 6                          |  |
| Verma       | Sandeep     | thakursandeep044@gmail.com | 7                          |  |
| Taank       | Vilakshan   | vilakshantaank@gmail.com   | 8                          |  |
| Wu          | Takai Kevin | kevinwu1105@hotmail.com    | 9                          |  |
| younus      | muhammad    | myounus@aol.com            | 10                         |  |
| Joseph      | Anandraj    | anand737@yahoo.com         | 11                         |  |
| Thomas      | Auyeung     | thomas0403@yahoo.com       | 12                         |  |
| Govindaraju | Abhijit     | abhigovindaraju@gmail.com  | 13                         |  |

| Patchava  | Chaitanya                               | cpatchava@gmail.com        | 14 |  |
|-----------|-----------------------------------------|----------------------------|----|--|
| Fujiwara  | a Tsuyoshi tsuyoshifujiwara11@gmail.com |                            | 15 |  |
| Jayaraman | Anand                                   | anandnayan@gmail.com       | 16 |  |
| Sankara   | Bharath                                 | wajsankara@yahoo.com       | 17 |  |
| Hung      | Perry                                   | pyhung@gmail.com           | 18 |  |
| Luo       | Qihua                                   | qihua578@gmail.com         | 19 |  |
| Rucker    | Terri                                   | trrdesigns@comcast.net     | 20 |  |
| Dwayne    | Dilbeck                                 | ddilbeck@yahoo.com         | 21 |  |
|           | paul                                    | pcheung347@gmail.com       | 22 |  |
|           | Eliana                                  | emeridaf@ucsc.edu          | 23 |  |
| Krishna   | Ajay                                    | ajaykrishna@gmail.com      | 24 |  |
| Lee       | Jason                                   | jasonclee0@gmail.com       | 25 |  |
| ackula    | swetha                                  | udayasree23@gmail.com      | 26 |  |
| Olling    | Cliff                                   | cliff@bromantech.com       | 27 |  |
| Jerry     | Mueckl                                  | jerry.mueckl@gmail.com     | 28 |  |
| Park      | Jae Yang                                | jaeyangp@gmail.com 29=P0.5 |    |  |
| Frank     |                                         | frank.chao@sbcglobal.net   | 30 |  |

 $\underline{http://developer.mbed.org/handbook/mbed-NXP-LPC1768-Getting-Started}$ 



http://developer.mbed.org/media/uploads/chris/mbed-005.1.pdf



## 9.2.1 Digital I/O ports

- Accelerated GPIO functions:
  - GPIO registers are located on a peripheral AHB bus for fast I/O timing.
  - Mask registers allow treating sets of port bits as a group, leaving other bits unchanged.
  - All GPIO registers are byte, half-word, and word addressable.
  - Entire port value can be written in one instruction.
  - GPIO registers are accessible by the GPDMA.
- Bit-level set and clear registers allow a single instruction set or clear of any number of bits in one port.
- All GPIO registers support Cortex-M3 bit-banding.
- GPIO registers are accessible by the GPDMA controller to allow DMA of data to or from GPIOs, synchronized to any DMA request.
- · Direction control of individual port bits.
- All I/Os default to input with pullup after reset.

Table 102. GPIO register map (local bus accessible registers - enhanced GPIO features)

| Generic<br>Name | Description                                                                                                                                                                                                                                                                                                                                                                                     | Access | Reset<br>value <sup>[1]</sup> | PORTn Register<br>Name & Address                                                                                               |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| FIODIR          | Fast GPIO Port Direction control register. This register individually controls the direction of each port pin.                                                                                                                                                                                                                                                                                  | R/W    | 0                             | FIOODIR - 0x2009 C000<br>FIO1DIR - 0x2009 C020<br>FIO2DIR - 0x2009 C040<br>FIO3DIR - 0x2009 C060<br>FIO4DIR - 0x2009 C080      |
| FIOMASK         | Fast Mask register for port. Writes, sets, clears, and reads to port (done via writes to FIOPIN, FIOSET, and FIOCLR, and reads of FIOPIN) alter or return only the bits enabled by zeros in this register.                                                                                                                                                                                      | R/W    | 0                             | FIO0MASK - 0x2009 C010<br>FIO1MASK - 0x2009 C030<br>FIO2MASK - 0x2009 C050<br>FIO3MASK - 0x2009 C070<br>FIO4MASK - 0x2009 C090 |
| FIOPIN          | Fast Port Pin value register using FIOMASK. The current state of digital port pins can be read from this register, regardless of pin direction or alternate function selection (as long as pins are not configured as an input to ADC). The value read is masked by ANDing with inverted FIOMASK. Writing to this register places corresponding values in all bits enabled by zeros in FIOMASK. | R/W    | 0                             | FIO0PIN - 0x2009 C014<br>FIO1PIN - 0x2009 C034<br>FIO2PIN - 0x2009 C054<br>FIO3PIN - 0x2009 C074<br>FIO4PIN - 0x2009 C094      |
|                 | <b>Important:</b> if an FIOPIN register is read, its bit(s) masked with 1 in the FIOMASK register will be read as 0 regardless of the physical pin state.                                                                                                                                                                                                                                       |        |                               |                                                                                                                                |
| FIOSET          | Fast Port Output Set register using FIOMASK. This register controls the state of output pins. Writing 1s produces highs at the corresponding port pins. Writing 0s has no effect. Reading this register returns the current contents of the port output register. Only bits enabled by 0 in FIOMASK can be altered.                                                                             | R/W    | 0                             | FIO0SET - 0x2009 C018<br>FIO1SET - 0x2009 C038<br>FIO2SET - 0x2009 C058<br>FIO3SET - 0x2009 C078<br>FIO4SET - 0x2009 C098      |
| FIOCLR          | Fast Port Output Clear register using FIOMASK. This register controls the state of output pins. Writing 1s produces lows at the corresponding port pins. Writing 0s has no effect. Only bits enabled by 0 in FIOMASK can be altered.                                                                                                                                                            | WO     | 0                             | FIOOCLR - 0x2009 C01C<br>FIO1CLR - 0x2009 C03C<br>FIO2CLR - 0x2009 C05C<br>FIO3CLR - 0x2009 C07C<br>FIO4CLR - 0x2009 C09C      |

<sup>[1]</sup> Reset value reflects the data stored in used bits only. It does not include reserved bits content.

Table 106. Fast GPIO port output Set register (FIO0SET to FIO4SET - addresses 0x2009 C018 to 0x2009 C098) bit description

| Bit                     | Symbol             | Value     | Description                                                                                                | Reset<br>value |
|-------------------------|--------------------|-----------|------------------------------------------------------------------------------------------------------------|----------------|
| 31:0 FIO0SET<br>FIO1SET |                    |           | Fast GPIO output value Set bits. Bit 0 in FIOxSET controls pin Px.0, bit 31 in FIOxSET controls pin Px.31. | 0x0            |
|                         | FIO2SET<br>FIO3SET | 0         | Controlled pin output is unchanged.                                                                        | _              |
|                         |                    | FIO4SET 1 | Controlled pin output is set to HIGH.                                                                      |                |

Aside from the 32-bit long and word only accessible FIOxSET register, every fast GPIO port can also be controlled via several byte and half-word accessible registers listed in Table 107, too. Next to providing the same functions as the FIOxSET register, these additional registers allow easier and faster access to the physical port pins.

Table 107. Fast GPIO port output Set byte and half-word accessible register description

| Generic<br>Register<br>name | Description                                                                                                                               | Register<br>length (bits)<br>& access | Reset<br>value | PORTn Register<br>Address & Name                                                                                               |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------|
| FIOxSET0                    | Fast GPIO Port x output Set register 0. Bit 0 in FIOxSET0 register corresponds to pin Px.0 bit 7 to pin Px.7.                             | 8 (byte)<br>R/W                       | 0x00           | FIO0SET0 - 0x2009 C018<br>FIO1SET0 - 0x2009 C038<br>FIO2SET0 - 0x2009 C058<br>FIO3SET0 - 0x2009 C078<br>FIO4SET0 - 0x2009 C098 |
| FIOXSET1                    | Fast GPIO Port x output Set register 1. Bit 0 in FIOxSET1 register corresponds to pin Px.8 bit 7 to pin Px.15.                            | 8 (byte)<br>R/W                       | 0x00           | FIO0SET1 - 0x2009 C019<br>FIO1SET1 - 0x2009 C039<br>FIO2SET1 - 0x2009 C059<br>FIO3SET1 - 0x2009 C079<br>FIO4SET1 - 0x2009 C099 |
| FIOXSET2                    | Fast GPIO Port x output Set register 2. Bit 0 in FIOxSET2 register corresponds to pin Px.16 bit 7 to pin Px.23.                           | 8 (byte)<br>R/W                       | 0x00           | FIO0SET2 - 0x2009 C01A<br>FIO1SET2 - 0x2009 C03A<br>FIO2SET2 - 0x2009 C05A<br>FIO3SET2 - 0x2009 C07A<br>FIO4SET2 - 0x2009 C09A |
| FIOXSET3                    | Fast GPIO Port x output Set register 3. Bit 0 in FIOxSET3 register corresponds to pin Px.24 bit 7 to pin Px.31.                           | 8 (byte)<br>R/W                       | 0x00           | FIO0SET3 - 0x2009 C01B<br>FIO1SET3 - 0x2009 C03B<br>FIO2SET3 - 0x2009 C05B<br>FIO3SET3 - 0x2009 C07B<br>FIO4SET3 - 0x2009 C09B |
| FIOXSETL                    | Fast GPIO Port x output Set<br>Lower half-word register. Bit 0<br>in FIOxSETL register<br>corresponds to pin Px.0 bit<br>15 to pin Px.15. | 16 (half-word)<br>R/W                 | 0x0000         | FIO0SETL - 0x2009 C018<br>FIO1SETL - 0x2009 C038<br>FIO2SETL - 0x2009 C058<br>FIO3SETL - 0x2009 C078<br>FIO4SETL - 0x2009 C098 |
| FIOXSETU                    | Fast GPIO Port x output Set<br>Upper half-word register. Bit 0<br>in FIOxSETU register<br>corresponds to Px.16 bit<br>15 to Px.31.        | 16 (half-word)<br>R/W                 | 0x0000         | FIO0SETU - 0x2009 C01A<br>FIO1SETU - 0x2009 C03A<br>FIO2SETU - 0x2009 C05A<br>FIO3SETU - 0x2009 C07A<br>FIO4SETU - 0x2009 C09A |