Difference between revisions of "LPC1768: Switch and LED"
| (35 intermediate revisions by 5 users not shown) | |||
| Line 1: | Line 1: | ||
| [[category: LPC1768 Tutorials]] | [[category: LPC1768 Tutorials]] | ||
| − | + | This is second tutorial on LPC1768 where we are going to read the switches and turn ON/OFF the LEDs accordingly. | |
| − | + | LPC1768 has its GPIOs divided into five ports PORT0 - PORT4, although many of them are not physically 32bit wide. Refer the data sheet for more info. | |
| − | This is  | + | <br><br> | 
| =Register Configuration= | =Register Configuration= | ||
| − | + | The Below registers will be used for Configuring and using the GPIOs registers for sending and receiving the Digital signals. | |
| − | |||
| − | |||
| − | |||
| <b>PINSEL:</b> GPIO Pins Select Register<br> | <b>PINSEL:</b> GPIO Pins Select Register<br> | ||
| − | Every GPIO pin has a minimum of one function and max of four functions. The required function can be selected by configuring the PINSEL register. As there can be up to 4 functions associated with a GPIO pin, two bits for each pin are available to select the function. This  | + | Almost all the LPC1768 pins are multiplexed to support more than 1 function. Every GPIO pin has a minimum of one function and max of four functions. The required function can be selected by configuring the PINSEL register. As there can be up to 4 functions associated with a GPIO pin, two bits for each pin are available to select the function. This implies that we need two PINSEL registers to configure a PORT pins. | 
| − | By this the first 16(P0.0-P0.16) pin functions of PORT0  | + | By this the first 16(P0.0-P0.16) pin functions of PORT0 can be selected by 32 bits of PINSELO register. The remaining 16 bits(P0.16-P0.32) are configured using 32bits of PINSEL1 register.    | 
| As mentioned earlier every pin has max of four functions. Below table shows how to select the function for a particular pin using two bits of the PINSEL register. | As mentioned earlier every pin has max of four functions. Below table shows how to select the function for a particular pin using two bits of the PINSEL register. | ||
| − | {| class=" | + | {| class="table table-striped table-hover table-condensed table-bordered" | 
| − | + | |-class="info" | |
| + | |Value||   Function || Enumeration | ||
| |- | |- | ||
| − | |00|| Primary (default) function, typically GPIO port | + | |00|| Primary (default) function, typically GPIO port || PINSEL_FUNC_0 | 
| |- | |- | ||
| − | |01|| First alternate function | + | |01|| First alternate function || PINSEL_FUNC_1 | 
| |- | |- | ||
| − | |10|| Second alternate function | + | |10|| Second alternate function || PINSEL_FUNC_2 | 
| |- | |- | ||
| − | |11|| Third alternate function | + | |11|| Third alternate function || PINSEL_FUNC_3 | 
| |} | |} | ||
| Line 32: | Line 30: | ||
| <b>FIODIR:</b>Fast GPIO Direction Control Register.<br>This register individually controls the direction of each port pin. | <b>FIODIR:</b>Fast GPIO Direction Control Register.<br>This register individually controls the direction of each port pin. | ||
| − | {| class=" | + | {| class="table table-striped table-hover table-condensed table-bordered" | 
| − | + | |-class="info" | |
| + | |Values|| Direction | ||
| |- | |- | ||
| |0|| Input | |0|| Input | ||
| Line 43: | Line 42: | ||
| <b>FIOSET:</b>Fast Port Output Set Register.<br>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 not the physical port value. | <b>FIOSET:</b>Fast Port Output Set Register.<br>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 not the physical port value. | ||
| − | {| class=" | + | {| class="table table-striped table-hover table-condensed table-bordered" | 
| − | + | |-class="info" | |
| + | |Values||   FIOSET   | ||
| |- | |- | ||
| − | |0 | + | |0|| No Effect | 
| |- | |- | ||
| − | |1|| Sets High  | + | |1|| Sets High on Pin | 
| |} | |} | ||
| Line 54: | Line 54: | ||
| <b>FIOCLR:</b>Fast Port Output Clear Register.<br>This register controls the state of output pins. Writing 1s produces lows at the corresponding port pins. Writing 0s has no effect.   | <b>FIOCLR:</b>Fast Port Output Clear Register.<br>This register controls the state of output pins. Writing 1s produces lows at the corresponding port pins. Writing 0s has no effect.   | ||
| − | {| class=" | + | {| class="table table-striped table-hover table-condensed table-bordered" | 
| − | + | |-class="info" | |
| + | |Values||    FIOCLR   | ||
| |- | |- | ||
| |0|| No Effect   | |0|| No Effect   | ||
| Line 62: | Line 63: | ||
| |} | |} | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| Line 78: | Line 69: | ||
| <b>Output:</b> Writing to this register places corresponding values in all bits of the particular PORT pins.<br> | <b>Output:</b> Writing to this register places corresponding values in all bits of the particular PORT pins.<br> | ||
| <b>Input:</b>  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).<br> | <b>Input:</b>  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).<br> | ||
| − | <b>Note:</b> | + | <b>Note:</b>It is recommended to configure the PORT direction and pin function before using it. | 
| − | + | <br><br><br><br> | |
| − | + | ||
| − | = | + | =Hardware Connections= | 
| − | In this program we are going to do both INPUT and OUTPUT operation. | + | [[File:Switch and LED bb.jpg|680px]] | 
| + | =Examples= | ||
| + | ===Example 1=== | ||
| + | In this program, we are going to do both INPUT and OUTPUT operation. | ||
| The port pin to which switch is connected is configured as Input and the pin to which LED is connected is configured as OUTPUT.   | The port pin to which switch is connected is configured as Input and the pin to which LED is connected is configured as OUTPUT.   | ||
| Here the switch status is read and accordingly the LED will be turned ON/OFF. | Here the switch status is read and accordingly the LED will be turned ON/OFF. | ||
| − | < | + | <html>   | 
| − | + | <script src="https://gist.github.com/Amritach/6f15f4134cfbebf1d352.js"></script> | |
| + | </html> | ||
| − | + | ===Example 2=== | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| This is the alternate method using the stdutils macros.   | This is the alternate method using the stdutils macros.   | ||
| − | < | + | <html> | 
| − | + | <script src="https://gist.github.com/Amritach/6c5d46d70b005114f0b6.js"></script> | |
| − | + | </html> | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | / | + | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | </ | + | |
| − | + | ||
| − | + | ||
| − | = | + | ===Example 3=== | 
| In this program multiple(3) switches are read and multiple LEDs are turned ON/OFF depending on the respective switch status. | In this program multiple(3) switches are read and multiple LEDs are turned ON/OFF depending on the respective switch status. | ||
| As shown in the schematic the LEDs are connected from P2.0 to P2.3. | As shown in the schematic the LEDs are connected from P2.0 to P2.3. | ||
| And the switches are connected to P2.10 to P2.12, accordingly the 3bit mask will be 0x07. | And the switches are connected to P2.10 to P2.12, accordingly the 3bit mask will be 0x07. | ||
| − | < | + | <html> | 
| − | + | <script src="https://gist.github.com/Amritach/712bfbaeb7e7acf5d564.js"></script> | |
| − | + | </html> | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ===Using Explore Embedded Libraries :=== | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | =Using Explore Embedded Libraries:= | + | |
| In the above tutorial we just discussed how to configure the PORTS for GPIO and use them for reading/wring the pins<br> | In the above tutorial we just discussed how to configure the PORTS for GPIO and use them for reading/wring the pins<br> | ||
| Once you know the GPIO configurations, you can directly use the ExploreEmbedded libraries<br> | Once you know the GPIO configurations, you can directly use the ExploreEmbedded libraries<br> | ||
| Line 199: | Line 105: | ||
| The below sample code shows how to use the GPIO functions.<br> | The below sample code shows how to use the GPIO functions.<br> | ||
| − | Refer this link for more info on  | + | Refer this link for more info on GPIO libraries. | 
| − | < | + | <html> | 
| − | + | <script src="https://gist.github.com/Amritach/0513164b196b6b184f06.js"></script> | |
| − | + | </html> | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | / | + | |
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | + | ||
| − | </ | + | |
| = Downloads= | = Downloads= | ||
| − | + | Download the complete project folder from the below link:   | |
| − | + | https://codeload.github.com/ExploreEmbedded/Explore-Cortex-M3-LPC1768-Stick-DVB-14001/zip/master<br><br> | |
| − | + | ||
| Have a opinion, suggestion , question or feedback about the article let it out here! | Have a opinion, suggestion , question or feedback about the article let it out here! | ||
| {{DISQUS}} | {{DISQUS}} | ||
Latest revision as of 19:22, 18 July 2016
This is second tutorial on LPC1768 where we are going to read the switches and turn ON/OFF the LEDs accordingly.
LPC1768 has its GPIOs divided into five ports PORT0 - PORT4, although many of them are not physically 32bit wide. Refer the data sheet for more info.
Contents
Register Configuration
The Below registers will be used for Configuring and using the GPIOs registers for sending and receiving the Digital signals.
PINSEL: GPIO Pins Select Register
Almost all the LPC1768 pins are multiplexed to support more than 1 function. Every GPIO pin has a minimum of one function and max of four functions. The required function can be selected by configuring the PINSEL register. As there can be up to 4 functions associated with a GPIO pin, two bits for each pin are available to select the function. This implies that we need two PINSEL registers to configure a PORT pins.
By this the first 16(P0.0-P0.16) pin functions of PORT0 can be selected by 32 bits of PINSELO register. The remaining 16 bits(P0.16-P0.32) are configured using 32bits of PINSEL1 register.  
As mentioned earlier every pin has max of four functions. Below table shows how to select the function for a particular pin using two bits of the PINSEL register.
| Value | Function | Enumeration | 
| 00 | Primary (default) function, typically GPIO port | PINSEL_FUNC_0 | 
| 01 | First alternate function | PINSEL_FUNC_1 | 
| 10 | Second alternate function | PINSEL_FUNC_2 | 
| 11 | Third alternate function | PINSEL_FUNC_3 | 
FIODIR:Fast GPIO Direction Control Register.
This register individually controls the direction of each port pin.
| Values | Direction | 
| 0 | Input | 
| 1 | Output | 
FIOSET:Fast Port Output Set Register.
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 not the physical port value.
| Values | FIOSET | 
| 0 | No Effect | 
| 1 | Sets High on Pin | 
FIOCLR:Fast Port Output Clear Register.
This register controls the state of output pins. Writing 1s produces lows at the corresponding port pins. Writing 0s has no effect. 
| Values | FIOCLR | 
| 0 | No Effect | 
| 1 | Sets Low on Pin | 
FIOPIN:Fast Port Pin Value Register.
This register is used for both reading and writing data from/to the PORT.
Output: Writing to this register places corresponding values in all bits of the particular PORT pins.
Input:  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).
Note:It is recommended to configure the PORT direction and pin function before using it.
Hardware Connections
Examples
Example 1
In this program, we are going to do both INPUT and OUTPUT operation. The port pin to which switch is connected is configured as Input and the pin to which LED is connected is configured as OUTPUT. Here the switch status is read and accordingly the LED will be turned ON/OFF.
Example 2
This is the alternate method using the stdutils macros.
Example 3
In this program multiple(3) switches are read and multiple LEDs are turned ON/OFF depending on the respective switch status. As shown in the schematic the LEDs are connected from P2.0 to P2.3. And the switches are connected to P2.10 to P2.12, accordingly the 3bit mask will be 0x07.
Using Explore Embedded Libraries :
In the above tutorial we just discussed how to configure the PORTS for GPIO and use them for reading/wring the pins
Once you know the GPIO configurations, you can directly use the ExploreEmbedded libraries
For that you need to include the gpio.c/gpio.h and the associated files(delay/stdutils).
 
The below sample code shows how to use the GPIO functions.
Refer this link for more info on GPIO libraries.
Downloads
Download the complete project folder from the below link: 
https://codeload.github.com/ExploreEmbedded/Explore-Cortex-M3-LPC1768-Stick-DVB-14001/zip/master
Have a opinion, suggestion , question or feedback about the article let it out here!

