Simple GPIO Functions on Nuvoton N76E003 - LED Blinking and Controlling LED using a Push Button

Published  July 31, 2020   2
GPIO Functions on Nuvoton N76E003

In our previous tutorial, we used a basic LED blinking program as a getting started with N76E003 guide, we already learned how to configure the Keil IDE and set up the environment for programming the nuvoton microcontroller unit N76E003. It is the time to move a little bit further and use the basic GPIO interface for controlling additional hardware. If you are interested you can also check other microcontroller GPIO tutorials that are listed below-

Since in our previous tutorial, we only used an LED to blink by using an IO pin as an output. In this tutorial, we will learn how to use another IO pin as an input and control an additional LED. Without wasting much time, let's evaluate what kind of hardware setup we require.

Hardware Setup and Requirement

As a switch needs to be used as input, the first thing we require is a push button. We also require an additional LED to be controlled by that push button. Other than these two, we also require a resistor to limit the LED current and an additional resistor for the pull-down purposes across the pushbutton. This will be further demonstrated in the schematic section. The components we require -

  1. A push-button (any kind of momentary switch specifically - Tactile switch)
  2. Any color of the LED
  3. 4.7k resistor for pull-down purposes
  4. 100R resistor

Not to mention, other than the above components, we need N76E003 microcontroller-based development board as well as the Nu-Link Programmer. Additionally, breadboard and hookup wires are also required for connecting all components as shown below.

Nuvoton N76E003 Hardware Setup

N76E003 LED and Push Button Interface Circuit

As we can see in the below schematic, the Test LED that is inside the development board is connected on the port 1.4 and an additional LED is connected on the port 1.5. The resistor R3 is used to limit the LED current.

N76E003 LED and Push Button Interface Circuit

In pin 1.6, a push-button named SW is connected. Whenever the button is pressed, the pin will become high. Otherwise, it will become low by the 4.7K pull-down resistor R1. You can learn more about pull-up and pull-down resistors if you are new to this concept.

The pin is also a program related pin that is accessed by the programmer. It is used to send program data. However, we will see the reason behind selecting those pins as well as get fair information about the pin mapping of N76E003.

N76E003 Pin-Out Diagram

The pin diagram of N76E003 can be seen in the below image-

Pin Diagram of N76E003

As we can see, each pin has multiple functions and can be used for different purposes. Let's take an example. The pin 1.7 can be used as an interrupt, or analog input or as a general-purpose input-output operation. Thus, if any pin is used as I/O pins, then the respective functionality will not be available.

Due to this, the pin 1.5 which is used as an LED output pin, it'll lose the PWM and other functionality. But that is not a problem as another functionality is not required for this project. The reason behind choosing pin 1.5 as output and pin 1.6 as input, because of the nearest availability of GND and VDD pins for easy connection.

However, in this microcontroller out of 20 pins, 18 pins can be used as a GPIO pin. The pin 2.0 is dedicatedly used for Reset input and it cannot be used as output. Other than this pin, all pins can be configured in the below-described mode.

N76E003 Pin Configuration

As per the datasheet, PxM1.n, and PxM2.n are two registers that are used to determine the control operation of the I/O port. Now, coming to writing and reading a GPIO port is a completely different thing. Because writing to a port control register changes the latching state of the port, whereas reading the port gets the status of the logic state. But for reading a port, it must be set into an input mode.

Simple GPIO Control Program for N76E003

The complete program used in this tutorial can be found at the bottom of this page, the explanation of the code is as follows.

Setting the pin as input

Let's start with the input first. As discussed just before, to read the status of a port, it needs to be set as input. Therefore, as we have selected P1.6 as our input switch pin, we have denoted it through the below line of code snippet.

#define SW P16

This same pin needs to be set as input. Thus, on the setup function, the pin is set as input using the below line.

void setup (void){
                P14_Quasi_Mode;
                P15_Quasi_Mode;
                P16_Input_Mode;
                }

This line P16_Input_Mode; is defined in the Function_define.h header file in the “BSP include library” that sets the pin bit as P1M1|=SET_BIT6; P1M2&=~SET_BIT6. The SET_BIT6 is also defined in the same header file as-

#define SET_BIT6               0x40

Setting the pins as output  

Same as the input pin, the output pin that is used by the onboard Test LED and the external LED1 is also defined in the first section of the code with the respective PINs.

#define Test_LED P14
#define LED1 P15

Those pins are set as an output in the setup function using the below lines.

void setup (void){
                P14_Quasi_Mode; // Output
                P15_Quasi_Mode; // Output
                P16_Input_Mode;
                }

These lines are also defined in the Function_define.h header file where it sets the pin bit as P1M1&=~SET_BIT4; P1M2&=~SET_BIT4. The SET_BIT6 is also defined in the same header file as-

#define SET_BIT4               0x10

Infinite While loop 

A Hardware, if connected with the power and working perfectly that should give output continuously, the application never stops. It does the same thing for infinite times. Here comes the function of an infinite while loop. The application inside the while loop runs infinitely.

  while(1){           
             Test_LED = 0;
            sw_delay(150);
            Test_LED = 1;
            sw_delay(150);          
             if(SW == 1){
                         LED1 = 0;
             }
             else {
                         LED1 = 1;
            }
}
}

The above while loop blinks the led as per the sw_delay value and also checks the status of the SW. If the switch is pressed, the P1.6 will be high, and thus when it is pressed, the read status will be 1. In this situation, for the time, the switch is pressed and the port P1.6 remains high, the LED1 will glow.

Programming N76E003 and Verifying Output

In our getting started with N76E003 tutorial, we learned how to program the N76E003 already, so we will just repeat the same steps here to program our board. The code compiled successfully and returned 0 warning and 0 Errors and flashed using the default flashing method by the Keil.

Getting Started with N76E003

As you can see in the above image, our external LED turns on when I press the push button. The complete working of the project can be found in the video linked below. Hope you enjoyed the tutorial and learned something useful if you have any questions, leave them in the comment section below. You can also use our forums to ask other technical questions.

Complete Project Code

#include "N76E003.h"
#include "SFR_Macro.h"
#include "Function_define.h"
#include "Common.h"
#include "Delay.h"
#define Test_LED P14
#define LED1 P15
#define SW P16
void setup (void);
void sw_delay (int ms);

void main(void){
    setup(); 
    while(1){     
     Test_LED = 0;
sw_delay(150);
Test_LED = 1;
sw_delay(150);
if(SW == 1){
LED1 = 0;
}
     else {
LED1 = 1;
}

}
}

// Software-based delay. Time is not accurate.
void sw_delay (int ms){
int a, b;
for (a=0; a<1296; a++){
for (b=0; b
Video

Have any question realated to this Article?

Ask Our Community Members

Comments

M

Submitted by M on Thu, 02/23/2023 - 02:35

Permalink

I would like to be able to HOLD the button down for 5 seconds or more and if released blink LED 3 times. If in case someone pushes it momentarily light LED once only. Could you please advise?