background image

LatticeMico32 Microprocessor Software Support

LatticeMico GPIO

21

Services

The GPIO device driver registers GPIO instances with the LatticeMico32 
lookup service, using their instance names for device names and 
“GPIODevice” as the device type. 

For more information about using the lookup service, refer to the 

LatticeMico32 Software Developer User Guide

.

Software Usage Examples

This section provides two code examples that demonstrate how to access the 
GPIO registers.

Using the GPIO Register Structure

The code example shown in Figure 16 shows how to locate a GPIO device, 
with 32 programmable I/Os, that is instantiated in the platform and how to 
directly access the registers using the GPIO register structure.

Using Provided Macros

The code example shown in Figure 17 shows how to locate a GPIO device 
that is instantiated in the platform and how to directly access the data register 
using the macros provided in MicoGPIO.h header file.

Figure 16: Locating a GPIO and Accessing Its Registers

/* Fetch GPIO instance named "LED" */
volatile MicoGPIO_t *pGPIO;
MicoGPIOCtx_t *leds = (MicoGPIOCtx_t *)MicoGetDevice("led");
if(leds == 0) {

/* failed to find a component named "leds" */
return(-1);

}

/* get access to the GPIO registers */
pGPIO = (volatile MicoGPIO_t *)(leds->base);

/* write 0x80 to programmable I/O pins 7 through 0 via the data 
register. */
pGPIO->data = 0x80000000;

Figure 17: Locating a GPIO and Accessing Its Data Register

/* Fetch GPIO instance named "LED" */
unsigned int iValue;
MicoGPIOCtx_t *leds = (MicoGPIOCtx_t *)MicoGetDevice("led");
if (leds == 0) {
/* failed to find a component named "leds" */
return(-1);
}

Summary of Contents for LatticeMico GPIO

Page 1: ...atures The LatticeMico GPIO includes the following features WISHBONE B 3 interface WISHBONE data base size configurable to 8 or 32 bits wide Four transfer port types tristate input output independent...

Page 2: ...with inputs only outputs only or both inputs and outputs A bidirectional mode with tristate control is also provided for bidirectional I O pins that are available on the device Bidirectional mode I O...

Page 3: ...ad from the PIO_DATA register is always delayed one CLK_I cycle from the current state of the PIO_IN port The PIO_DATA read cycle does not prevent the input flip flop from changing state Output Data P...

Page 4: ...o the input pin transitions from 0 to 1 The edge is detected when the input signal transitions between two WISHBONE clock cycles CLK_I Clearing a bit that is setting it to zero in the edge capture reg...

Page 5: ...il the interrupt condition is cleared Edge sensitive An IRQ is generated whenever a specific bit in the edge capture register is high and interrupt requests are enabled for that bit in the IRQ_MASK re...

Page 6: ...eters Table 1 shows the UI parameters available for configuring the LatticeMico GPIO through the Mico System Builder MSB interface HDL Parameters Table 2 describes the parameters that appear in the HD...

Page 7: ...0X80000000 Port Types Output Ports Only Specifies the transfer mode of PIO ports as output only selected not selected selected Input Ports Only Specifies the transfer mode of PIO ports as input only...

Page 8: ...selected generates an IRQ on either low to high or high to low transitions selected not selected not selected Positive Edge When selected generates an IRQ on low to high transitions selected not sele...

Page 9: ...ed for that bit in the IRQ MASK register 0 1 EITHER_EDGE_IRQ With a value of 1 an IRQ is generated on either low to high or high to low transitions 0 1 POSE_EDGE_IRQ With a value of 1 an IRQ is genera...

Page 10: ...th input and output mode The GPIO s number of output bits is configurable PIO_IO I O 0 X Appears in tristate mode only Each GPIO bit shares one device pin for driving and capturing data The direction...

Page 11: ...ss Mode Description PIO_TRI DATA_WIDTH 1 0 Read Write This is the PIO read write tristate enable mask Setting a bit to 1 puts the corresponding PIO_IO pin in output mode Setting a bit to 0 puts the co...

Page 12: ...TURE DATA_WIDTH 1 0 Read Write A bit that is set to 1 indicates that an edge capture event has occurred for that input port The bit is cleared by writing a 0 to the corresponding bit in the EDGE_CAPTU...

Page 13: ...es interrupt requests when a signal is high or low Figure 8 shows how the GPIO generates interrupt requests when the PIO_DATA signal transitions from low to high After an edge is detected the Edge_Cap...

Page 14: ...Figure 9 shows how the GPIO generates interrupt requests when the PIO_DATA signal transitions from high to low EBR Resource Utilization The LatticeMico GPIO uses no EBRs Figure 8 IRQ Generation Risin...

Page 15: ...rrupt requests when the following are detected on an input port High level Positive edge Negative edge The usage scenario depends on the end user application and does not fit within a well known usage...

Page 16: ...sing word reads unsigned int or signed int As mentioned LatticeMico32 is a big endian microprocessor Therefore from the programmer s perspective the least significant byte of the GPIO will appear in t...

Page 17: ...rvice Refer to the LatticeMico32 Software Developer User Guide for more information on the device lookup service GPIO Device Context Structure This structure shown in Figure 13 contains GPIO component...

Page 18: ...s are used If interrupts are not used this value is greater than 31 If interrupts are used the value is 0 31 output_only unsigned int This value is 1 if the GPIO is configured as output only Otherwise...

Page 19: ...e Context Structure Parameters Continued Parameter Data Type Description Note You may need to access the GPIO device registers directly but some of these registers are write only Implementing shadow r...

Page 20: ...cture Y is an unsigned int variable reads data register define MICO_GPIO_READ_DATA X Y Y volatile MicoGPIO_t X base data writes data register define MICO_GPIO_WRITE_DATA X Y volatile MicoGPIO_t X base...

Page 21: ...gisters using the GPIO register structure Using Provided Macros The code example shown in Figure 17 shows how to locate a GPIO device that is instantiated in the platform and how to directly access th...

Page 22: ...s filled in by the managed build process which extracts GPIO component specific information from the platform definition file The members should not be manipulated directly because the structure is us...

Page 23: ...value is 0 7 output_only unsigned char This value is 1 if the GPIO is configured as output only Otherwise it is 0 input_only unsigned char This value is 1 if the GPIO is configured as input only Othe...

Page 24: ...TE2 X Y Y __builtin_import size_t X GPIO_DATA_OFFSET 2 define MICO_GPIO_READ_DATA_BYTE3 X Y Y __builtin_import size_t X GPIO_DATA_OFFSET 3 Macros for writing each byte of the Data Register define MICO...

Page 25: ...e MICO_GPIO_WRITE_TRISTATE_BYTE2 X Y __builtin_export char Y size_t X GPIO_TRISTATE_OFFSET 2 define MICO_GPIO_WRITE_TRISTATE_BYTE3 X Y __builtin_export char Y size_t X GPIO_TRISTATE_OFFSET 3 Macros fo...

Page 26: ...CAPTURE_BYTE0 X Y Y __builtin_import size_t X GPIO_EDGE_CAPTURE_OFFSET 0 define MICO_GPIO_READ_EDGE_CAPTURE_BYTE1 X Y Y __builtin_import size_t X GPIO_EDGE_CAPTURE_OFFSET 1 define MICO_GPIO_READ_EDGE_...

Page 27: ...READ_DATA_BYTE0 leds base iValue return 0 Revision History Component Version Description 1 0 Initial release 3 0 7 0 SP2 Cleaned up code No function change 3 1 Updated the Edge Capture Register clean...

Page 28: ...ticeECP LatticeECP DSP LatticeECP2 LatticeECP2M LatticeECP3 LatticeECP4 LatticeMico LatticeMico8 LatticeMico32 LatticeSC LatticeSCM LatticeXP LatticeXP2 MACH MachXO MachXO2 MACO mobileFPGA ORCA PAC PA...

Reviews: