background image

LatticeMico32 Microprocessor Software Support

16

LatticeMico GPIO

Assume that you have a design that contains a 32-bit GPIO that has been 
assigned a base address of 0x80000100. The GPIO data register for input 
and output of data is located at offset 0 from the base address. Byte 0 ( bits 7-
0) of this GPIO data register is located at byte offset 0 (address 0x80000100), 
while byte 3 (bits 31-24) is located at byte offset 3 from the base address 
(0x800001003). Lets assume that the GPIO has received a value [31:0] = 
32'h12345678 and the programmer is writing C code to read the 32-bit GPIO.

Figure 10 shows a sample code to read the 32-bit GPIO using byte reads (i.e., 
"unsigned char" or "signed char"). 

The execution of the code in Figure 10 will result in byte0 = 0x78, byte1 = 
0x56, byte2 = 0x34, and byte3 = 0x12. 

Now consider the sample code of Figure 11 in which the programmer is 
reading the same 32-bit GPIO using 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 the most-significant location. The execution of the code in Figure 11 
will result in 'word' being loaded with a value of 0x78563412.

Register Map Structure

The structure shown in Figure 5 depicts the register map layout for the GPIO 
component. The elements are self-explanatory and are based on the register, 
as shown in Table 4 on page 10. This structure, which is defined in the 
MicoGPIO.h header file, enables you to directly access the GPIO registers, if 
desired. It is used internally by the device driver for manipulating the GPIO.

Figure 10: Access to a 32-bit GPIO using byte reads

unsigned char byte0, byte1, byte2, byte3;
byte0 = *(volatile unsigned char *)0x80000100;
byte1 = *(volatile unsigned char *)0x80000101;
byte2 = *(volatile unsigned char *)0x80000102;
byte3 = *(volatile unsigned char *)0x80000103;

Figure 11: Access to a 32-bit GPIO using word reads

unsigned int word;
word = *(volatile unsigned int *)0x80000100;

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: