gpiops
Vitis Drivers API Documentation
Overview

Data Structures

struct  XGpioPs_Config
 This typedef contains configuration information for a device. More...
 
struct  XGpioPs
 The XGpioPs driver instance data. More...
 

Macros

#define XGPIOPS_H
 by using protection macros More...
 
#define XGPIOPS_BANK_MAX_PINS   (u32)32
 Max pins in a GPIO bank. More...
 
#define XGPIOPS_BANK0   0x00U
 GPIO Bank 0. More...
 
#define XGPIOPS_BANK1   0x01U
 GPIO Bank 1. More...
 
#define XGPIOPS_BANK2   0x02U
 GPIO Bank 2. More...
 
#define XGPIOPS_BANK3   0x03U
 GPIO Bank 3. More...
 
#define XGPIOPS_BANK4   0x04U
 GPIO Bank 4. More...
 
#define XGPIOPS_BANK5   0x05U
 GPIO Bank 5. More...
 
#define XGPIOPS_MAX_BANKS_ZYNQMP   0x06U
 Max banks in a Zynq Ultrascale+ MP GPIO device. More...
 
#define XGPIOPS_MAX_BANKS   0x04U
 Max banks in a Zynq GPIO device. More...
 
#define XGPIOPS_MAX_BANKS_CNT   0x06U
 Max banks number of all platforms. More...
 
#define XGPIOPS_DEVICE_MAX_PIN_NUM_ZYNQMP   (u32)174
 Max pins in the Zynq Ultrascale+ MP GPIO device 0 - 25, Bank 0 26 - 51, Bank 1 52 - 77, Bank 2 78 - 109, Bank 3 110 - 141, Bank 4 142 - 173, Bank 5. More...
 
#define XGPIOPS_DEVICE_MAX_PIN_NUM   (u32)118
 Max pins in the Zynq GPIO device 0 - 31, Bank 0 32 - 53, Bank 1 54 - 85, Bank 2 86 - 117, Bank 3. More...
 
#define XGPIOPS_HW_H
 by using protection macros More...
 
#define XGPIOPS_BYPM_MASK_OFFSET   (u32)0x40
 Mask for backward support. More...
 
#define XGPIOPS_PS_GPIO_BASEADDR   0xFF0B0000U
 Flag for Base Address for PS_GPIO in Versal. More...
 
#define XGPIOPS_ZERO   0U
 Flag for 0 Value. More...
 
#define XGPIOPS_ONE   1U
 Flag for 1 Value. More...
 
#define XGPIOPS_TWO   2U
 Flag for 2 Value. More...
 
#define XGPIOPS_THREE   3U
 Flag for 3 Value. More...
 
#define XGPIOPS_FOUR   4U
 Flag for 4 Value. More...
 
#define XGPIOPS_SIX   6U
 Flag for 6 Value. More...
 
#define XGpioPs_ReadReg(BaseAddr, RegOffset)   Xil_In32((BaseAddr) + (u32)(RegOffset))
 This macro reads the given register. More...
 
#define XGpioPs_WriteReg(BaseAddr, RegOffset, Data)   Xil_Out32((BaseAddr) + (u32)(RegOffset), (u32)(Data))
 This macro writes to the given register. More...
 

Typedefs

typedef void(* XGpioPs_Handler )(void *CallBackRef, u32 Bank, u32 Status)
 This handler data type allows the user to define a callback function to handle the interrupts for the GPIO device. More...
 

Functions

void StubHandler (void *CallBackRef, u32 Bank, u32 Status)
 Stub handler. More...
 
s32 XGpioPs_CfgInitialize (XGpioPs *InstancePtr, const XGpioPs_Config *ConfigPtr, u32 EffectiveAddr)
 This function initializes a XGpioPs instance/driver. More...
 
u32 XGpioPs_Read (const XGpioPs *InstancePtr, u8 Bank)
 Read the Data register of the specified GPIO bank. More...
 
u32 XGpioPs_ReadPin (const XGpioPs *InstancePtr, u32 Pin)
 Read Data from the specified pin. More...
 
void XGpioPs_Write (const XGpioPs *InstancePtr, u8 Bank, u32 Data)
 Write to the Data register of the specified GPIO bank. More...
 
void XGpioPs_WritePin (const XGpioPs *InstancePtr, u32 Pin, u32 Data)
 Write data to the specified pin. More...
 
void XGpioPs_SetDirection (const XGpioPs *InstancePtr, u8 Bank, u32 Direction)
 Set the Direction of the pins of the specified GPIO Bank. More...
 
void XGpioPs_SetDirectionPin (const XGpioPs *InstancePtr, u32 Pin, u32 Direction)
 Set the Direction of the specified pin. More...
 
u32 XGpioPs_GetDirection (const XGpioPs *InstancePtr, u8 Bank)
 Get the Direction of the pins of the specified GPIO Bank. More...
 
u32 XGpioPs_GetDirectionPin (const XGpioPs *InstancePtr, u32 Pin)
 Get the Direction of the specified pin. More...
 
void XGpioPs_SetOutputEnable (const XGpioPs *InstancePtr, u8 Bank, u32 OpEnable)
 Set the Output Enable of the pins of the specified GPIO Bank. More...
 
void XGpioPs_SetOutputEnablePin (const XGpioPs *InstancePtr, u32 Pin, u32 OpEnable)
 Set the Output Enable of the specified pin. More...
 
u32 XGpioPs_GetOutputEnable (const XGpioPs *InstancePtr, u8 Bank)
 Get the Output Enable status of the pins of the specified GPIO Bank. More...
 
u32 XGpioPs_GetOutputEnablePin (const XGpioPs *InstancePtr, u32 Pin)
 Get the Output Enable status of the specified pin. More...
 
void XGpioPs_GetBankPin (u8 PinNumber, u8 *BankNumber, u8 *PinNumberInBank)
 Get the Bank number and the Pin number in the Bank, for the given PinNumber in the GPIO device. More...
 
s32 XGpioPs_SelfTest (XGpioPs *InstancePtr)
 This function runs a self-test on the GPIO driver/device. More...
 
void XGpioPs_IntrEnable (XGpioPs *InstancePtr, u8 Bank, u32 Mask)
 This function enables the interrupts for the specified pins in the specified bank. More...
 
void XGpioPs_IntrDisable (XGpioPs *InstancePtr, u8 Bank, u32 Mask)
 This function disables the interrupts for the specified pins in the specified bank. More...
 
u32 XGpioPs_IntrGetEnabled (const XGpioPs *InstancePtr, u8 Bank)
 This function returns the interrupt enable status for a bank. More...
 
u32 XGpioPs_IntrGetStatus (const XGpioPs *InstancePtr, u8 Bank)
 This function returns interrupt status read from Interrupt Status Register. More...
 
void XGpioPs_IntrClear (const XGpioPs *InstancePtr, u8 Bank, u32 Mask)
 This function clears pending interrupt(s) with the provided mask. More...
 
void XGpioPs_SetIntrType (const XGpioPs *InstancePtr, u8 Bank, u32 IntrType, u32 IntrPolarity, u32 IntrOnAny)
 This function is used for setting the Interrupt Type, Interrupt Polarity and Interrupt On Any for the specified GPIO Bank pins. More...
 
void XGpioPs_GetIntrType (const XGpioPs *InstancePtr, u8 Bank, u32 *IntrType, u32 *IntrPolarity, u32 *IntrOnAny)
 This function is used for getting the Interrupt Type, Interrupt Polarity and Interrupt On Any for the specified GPIO Bank pins. More...
 
void XGpioPs_SetCallbackHandler (XGpioPs *InstancePtr, void *CallBackRef, XGpioPs_Handler FuncPointer)
 This function sets the status callback function. More...
 
void XGpioPs_IntrHandler (const XGpioPs *InstancePtr)
 This function is the interrupt handler for GPIO interrupts.It checks the interrupt status registers of all the banks to determine the actual bank in which an interrupt has been triggered. More...
 
void XGpioPs_SetIntrTypePin (const XGpioPs *InstancePtr, u32 Pin, u8 IrqType)
 This function is used for setting the IRQ Type of a single GPIO pin. More...
 
u8 XGpioPs_GetIntrTypePin (const XGpioPs *InstancePtr, u32 Pin)
 This function returns the IRQ Type of a given GPIO pin. More...
 
void XGpioPs_IntrEnablePin (XGpioPs *InstancePtr, u32 Pin)
 This function enables the interrupt for the specified pin. More...
 
void XGpioPs_IntrDisablePin (XGpioPs *InstancePtr, u32 Pin)
 This function disables the interrupts for the specified pin. More...
 
u32 XGpioPs_IntrGetEnabledPin (const XGpioPs *InstancePtr, u32 Pin)
 This function returns whether interrupts are enabled for the specified pin. More...
 
u32 XGpioPs_IntrGetStatusPin (const XGpioPs *InstancePtr, u32 Pin)
 This function returns interrupt enable status of the specified pin. More...
 
void XGpioPs_IntrClearPin (const XGpioPs *InstancePtr, u32 Pin)
 This function clears the specified pending interrupt. More...
 
XGpioPs_ConfigXGpioPs_LookupConfig (u16 DeviceId)
 This function looks for the device configuration based on the unique device ID. More...
 
void XGpioPs_ResetHw (UINTPTR BaseAddress)
 This function resets the GPIO module by writing reset values to all registers. More...
 

Variables

XGpioPs_Config XGpioPs_ConfigTable []
 This table contains configuration information for each GPIO device in the system. More...
 
XGpioPs_Config XGpioPs_ConfigTable [XPAR_XGPIOPS_NUM_INSTANCES]
 This table contains configuration information for each GPIO device in the system. More...
 

Interrupt types

The following constants define the interrupt types that can be set for each GPIO pin.

#define XGPIOPS_IRQ_TYPE_EDGE_RISING   0x00U
 Interrupt on Rising edge. More...
 
#define XGPIOPS_IRQ_TYPE_EDGE_FALLING   0x01U
 Interrupt Falling edge. More...
 
#define XGPIOPS_IRQ_TYPE_EDGE_BOTH   0x02U
 Interrupt on both edges. More...
 
#define XGPIOPS_IRQ_TYPE_LEVEL_HIGH   0x03U
 Interrupt on high level. More...
 
#define XGPIOPS_IRQ_TYPE_LEVEL_LOW   0x04U
 Interrupt on low level. More...
 

Register offsets for the GPIO. Each register is 32 bits.

#define XGPIOPS_DATA_LSW_OFFSET   0x00000000U
 Mask and Data Register LSW, WO. More...
 
#define XGPIOPS_DATA_MSW_OFFSET   0x00000004U
 Mask and Data Register MSW, WO. More...
 
#define XGPIOPS_DATA_OFFSET   0x00000040U
 Data Register, RW. More...
 
#define XGPIOPS_DATA_RO_OFFSET   0x00000060U
 Data Register - Input, RO. More...
 
#define XGPIOPS_DIRM_OFFSET   0x00000204U
 Direction Mode Register, RW. More...
 
#define XGPIOPS_OUTEN_OFFSET   0x00000208U
 Output Enable Register, RW. More...
 
#define XGPIOPS_INTMASK_OFFSET   0x0000020CU
 Interrupt Mask Register, RO. More...
 
#define XGPIOPS_INTEN_OFFSET   0x00000210U
 Interrupt Enable Register, WO. More...
 
#define XGPIOPS_INTDIS_OFFSET   0x00000214U
 Interrupt Disable Register, WO. More...
 
#define XGPIOPS_INTSTS_OFFSET   0x00000218U
 Interrupt Status Register, RO. More...
 
#define XGPIOPS_INTTYPE_OFFSET   0x0000021CU
 Interrupt Type Register, RW. More...
 
#define XGPIOPS_INTPOL_OFFSET   0x00000220U
 Interrupt Polarity Register, RW. More...
 
#define XGPIOPS_INTANY_OFFSET   0x00000224U
 Interrupt On Any Register, RW. More...
 

Register offsets for each Bank.

#define XGPIOPS_DATA_MASK_OFFSET   0x00000008U
 Data/Mask Registers offset. More...
 
#define XGPIOPS_DATA_BANK_OFFSET   0x00000004U
 Data Registers offset. More...
 
#define XGPIOPS_REG_MASK_OFFSET   0x00000040U
 Registers offset. More...
 

Interrupt type reset values for each bank

#define XGPIOPS_INTTYPE_BANK0_RESET   0xFFFFFFFFU
 Resets specific to Zynq. More...
 
#define XGPIOPS_INTTYPE_BANK1_RESET   0x003FFFFFU
 Resets specific to Zynq. More...
 
#define XGPIOPS_INTTYPE_BANK2_RESET   0xFFFFFFFFU
 Resets specific to Zynq. More...
 
#define XGPIOPS_INTTYPE_BANK3_RESET   0xFFFFFFFFU
 Reset common to both platforms. More...
 
#define XGPIOPS_INTTYPE_BANK4_RESET   0xFFFFFFFFU
 Resets specific to Zynq Ultrascale+ MP. More...
 
#define XGPIOPS_INTTYPE_BANK5_RESET   0xFFFFFFFFU
 Resets specific to Zynq Ultrascale+ MP. More...
 

Macro Definition Documentation

#define XGPIOPS_BANK0   0x00U

GPIO Bank 0.

Referenced by XGpioPs_SelfTest().

#define XGPIOPS_BANK1   0x01U

GPIO Bank 1.

#define XGPIOPS_BANK2   0x02U

GPIO Bank 2.

#define XGPIOPS_BANK3   0x03U

GPIO Bank 3.

#define XGPIOPS_BANK4   0x04U

GPIO Bank 4.

#define XGPIOPS_BANK5   0x05U

GPIO Bank 5.

#define XGPIOPS_BANK_MAX_PINS   (u32)32

Max pins in a GPIO bank.

#define XGPIOPS_BYPM_MASK_OFFSET   (u32)0x40

Mask for backward support.

#define XGPIOPS_DATA_BANK_OFFSET   0x00000004U

Data Registers offset.

Referenced by XGpioPs_Read(), XGpioPs_ReadPin(), XGpioPs_ResetHw(), and XGpioPs_Write().

#define XGPIOPS_DATA_LSW_OFFSET   0x00000000U

Mask and Data Register LSW, WO.

Referenced by XGpioPs_ResetHw(), and XGpioPs_WritePin().

#define XGPIOPS_DATA_MASK_OFFSET   0x00000008U

Data/Mask Registers offset.

Referenced by XGpioPs_ResetHw(), and XGpioPs_WritePin().

#define XGPIOPS_DATA_MSW_OFFSET   0x00000004U

Mask and Data Register MSW, WO.

Referenced by XGpioPs_ResetHw(), and XGpioPs_WritePin().

#define XGPIOPS_DATA_OFFSET   0x00000040U

Data Register, RW.

Referenced by XGpioPs_ResetHw(), and XGpioPs_Write().

#define XGPIOPS_DATA_RO_OFFSET   0x00000060U

Data Register - Input, RO.

Referenced by XGpioPs_Read(), and XGpioPs_ReadPin().

#define XGPIOPS_DEVICE_MAX_PIN_NUM   (u32)118

Max pins in the Zynq GPIO device 0 - 31, Bank 0 32 - 53, Bank 1 54 - 85, Bank 2 86 - 117, Bank 3.

#define XGPIOPS_DEVICE_MAX_PIN_NUM_ZYNQMP   (u32)174

Max pins in the Zynq Ultrascale+ MP GPIO device 0 - 25, Bank 0 26 - 51, Bank 1 52 - 77, Bank 2 78 - 109, Bank 3 110 - 141, Bank 4 142 - 173, Bank 5.

#define XGPIOPS_DIRM_OFFSET   0x00000204U
#define XGPIOPS_FOUR   4U

Flag for 4 Value.

Referenced by XGpioPs_GetBankPin().

#define XGPIOPS_H

by using protection macros

#define XGPIOPS_HW_H

by using protection macros

#define XGPIOPS_INTANY_OFFSET   0x00000224U
#define XGPIOPS_INTDIS_OFFSET   0x00000214U

Interrupt Disable Register, WO.

Referenced by XGpioPs_CfgInitialize(), XGpioPs_IntrDisable(), XGpioPs_IntrDisablePin(), and XGpioPs_ResetHw().

#define XGPIOPS_INTEN_OFFSET   0x00000210U

Interrupt Enable Register, WO.

Referenced by XGpioPs_IntrEnable(), XGpioPs_IntrEnablePin(), and XGpioPs_ResetHw().

#define XGPIOPS_INTMASK_OFFSET   0x0000020CU

Interrupt Mask Register, RO.

Referenced by XGpioPs_IntrGetEnabled(), XGpioPs_IntrGetEnabledPin(), and XGpioPs_ResetHw().

#define XGPIOPS_INTPOL_OFFSET   0x00000220U
#define XGPIOPS_INTSTS_OFFSET   0x00000218U
#define XGPIOPS_INTTYPE_BANK0_RESET   0xFFFFFFFFU

Resets specific to Zynq.

Referenced by XGpioPs_ResetHw().

#define XGPIOPS_INTTYPE_BANK1_RESET   0x003FFFFFU

Resets specific to Zynq.

Referenced by XGpioPs_ResetHw().

#define XGPIOPS_INTTYPE_BANK2_RESET   0xFFFFFFFFU

Resets specific to Zynq.

Referenced by XGpioPs_ResetHw().

#define XGPIOPS_INTTYPE_BANK3_RESET   0xFFFFFFFFU

Reset common to both platforms.

Referenced by XGpioPs_ResetHw().

#define XGPIOPS_INTTYPE_BANK4_RESET   0xFFFFFFFFU

Resets specific to Zynq Ultrascale+ MP.

Referenced by XGpioPs_ResetHw().

#define XGPIOPS_INTTYPE_BANK5_RESET   0xFFFFFFFFU

Resets specific to Zynq Ultrascale+ MP.

Referenced by XGpioPs_ResetHw().

#define XGPIOPS_INTTYPE_OFFSET   0x0000021CU
#define XGPIOPS_IRQ_TYPE_EDGE_BOTH   0x02U

Interrupt on both edges.

Referenced by XGpioPs_GetIntrTypePin(), and XGpioPs_SetIntrTypePin().

#define XGPIOPS_IRQ_TYPE_EDGE_FALLING   0x01U

Interrupt Falling edge.

Referenced by XGpioPs_GetIntrTypePin(), and XGpioPs_SetIntrTypePin().

#define XGPIOPS_IRQ_TYPE_EDGE_RISING   0x00U

Interrupt on Rising edge.

Referenced by XGpioPs_GetIntrTypePin(), and XGpioPs_SetIntrTypePin().

#define XGPIOPS_IRQ_TYPE_LEVEL_HIGH   0x03U

Interrupt on high level.

Referenced by XGpioPs_GetIntrTypePin(), and XGpioPs_SetIntrTypePin().

#define XGPIOPS_IRQ_TYPE_LEVEL_LOW   0x04U

Interrupt on low level.

Referenced by XGpioPs_GetIntrTypePin(), and XGpioPs_SetIntrTypePin().

#define XGPIOPS_MAX_BANKS   0x04U

Max banks in a Zynq GPIO device.

#define XGPIOPS_MAX_BANKS_CNT   0x06U

Max banks number of all platforms.

#define XGPIOPS_MAX_BANKS_ZYNQMP   0x06U

Max banks in a Zynq Ultrascale+ MP GPIO device.

#define XGPIOPS_OUTEN_OFFSET   0x00000208U
#define XGPIOPS_PS_GPIO_BASEADDR   0xFF0B0000U

Flag for Base Address for PS_GPIO in Versal.

Referenced by XGpioPs_ResetHw().

#define XGpioPs_ReadReg (   BaseAddr,
  RegOffset 
)    Xil_In32((BaseAddr) + (u32)(RegOffset))
#define XGPIOPS_SIX   6U

Flag for 6 Value.

Referenced by XGpioPs_GetBankPin().

#define XGPIOPS_THREE   3U

Flag for 3 Value.

Referenced by XGpioPs_GetBankPin().

#define XGpioPs_WriteReg (   BaseAddr,
  RegOffset,
  Data 
)    Xil_Out32((BaseAddr) + (u32)(RegOffset), (u32)(Data))

This macro writes to the given register.

Parameters
BaseAddris the base address of the device.
RegOffsetis the offset of the register to be written.
Datais the 32-bit value to write to the register.
Returns
None.
Note
None.

Referenced by XGpioPs_CfgInitialize(), XGpioPs_IntrClear(), XGpioPs_IntrClearPin(), XGpioPs_IntrDisable(), XGpioPs_IntrDisablePin(), XGpioPs_IntrEnable(), XGpioPs_IntrEnablePin(), XGpioPs_ResetHw(), XGpioPs_SetDirection(), XGpioPs_SetDirectionPin(), XGpioPs_SetIntrType(), XGpioPs_SetIntrTypePin(), XGpioPs_SetOutputEnable(), XGpioPs_SetOutputEnablePin(), XGpioPs_Write(), and XGpioPs_WritePin().

#define XGPIOPS_ZERO   0U

Flag for 0 Value.

Referenced by XGpioPs_GetBankPin().

Typedef Documentation

typedef void(* XGpioPs_Handler)(void *CallBackRef, u32 Bank, u32 Status)

This handler data type allows the user to define a callback function to handle the interrupts for the GPIO device.

The application using this driver is expected to define a handler of this type, to support interrupt driven mode. The handler executes in an interrupt context such that minimal processing should be performed.

Parameters
CallBackRefis a callback reference passed in by the upper layer when setting the callback functions for a GPIO bank. It is passed back to the upper layer when the callback is invoked. Its type is not important to the driver component, so it is a void pointer.
Bankis the bank for which the interrupt status has changed.
Statusis the Interrupt status of the GPIO bank.

Function Documentation

void StubHandler ( void *  CallBackRef,
u32  Bank,
u32  Status 
)

Stub handler.

This is a stub for the status callback.

The stub is here in case the upper layers do not set the handler.

Parameters
CallBackRefis a pointer to the upper layer callback reference
Bankis the GPIO Bank in which an interrupt occurred.
Statusis the Interrupt status of the GPIO bank.
Returns
None.
Note
None.

Referenced by XGpioPs_CfgInitialize().

s32 XGpioPs_CfgInitialize ( XGpioPs InstancePtr,
const XGpioPs_Config ConfigPtr,
u32  EffectiveAddr 
)

This function initializes a XGpioPs instance/driver.

All members of the XGpioPs instance structure are initialized and StubHandlers are assigned to the Bank Status Handlers.

Parameters
InstancePtris a pointer to the XGpioPs instance.
ConfigPtrpoints to the XGpioPs device configuration structure.
EffectiveAddris the device base address in the virtual memory address space. If the address translation is not used then the physical address should be passed. Unexpected errors may occur if the address mapping is changed after this function is invoked.
Returns
XST_SUCCESS always.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::CoreIntrMask, XGpioPs_Config::DeviceId, XGpioPs::GpioConfig, XGpioPs::Handler, XGpioPs::IsReady, XGpioPs::MaxBanks, XGpioPs::MaxPinNum, XGpioPs::Platform, XGpioPs::PmcGpio, StubHandler(), XGPIOPS_INTDIS_OFFSET, XGPIOPS_ONE, XGPIOPS_REG_MASK_OFFSET, XGPIOPS_TWO, and XGpioPs_WriteReg.

Referenced by GpioPolledExample().

void XGpioPs_GetBankPin ( u8  PinNumber,
u8 *  BankNumber,
u8 *  PinNumberInBank 
)

Get the Bank number and the Pin number in the Bank, for the given PinNumber in the GPIO device.

Parameters
PinNumberis the Pin number in the GPIO device.
BankNumberreturns the Bank in which this GPIO pin is present. Valid values are 0 to XGPIOPS_MAX_BANKS - 1.
PinNumberInBankreturns the Pin Number within the Bank.
Returns
None.
Note
None.

References XGpioPs::PmcGpio, XGPIOPS_FOUR, XGPIOPS_ONE, XGPIOPS_SIX, XGPIOPS_THREE, XGPIOPS_TWO, and XGPIOPS_ZERO.

Referenced by XGpioPs_GetDirectionPin(), XGpioPs_GetIntrTypePin(), XGpioPs_GetOutputEnablePin(), XGpioPs_IntrClearPin(), XGpioPs_IntrDisablePin(), XGpioPs_IntrEnablePin(), XGpioPs_IntrGetEnabledPin(), XGpioPs_IntrGetStatusPin(), XGpioPs_ReadPin(), XGpioPs_SetDirectionPin(), XGpioPs_SetIntrTypePin(), XGpioPs_SetOutputEnablePin(), and XGpioPs_WritePin().

u32 XGpioPs_GetDirection ( const XGpioPs InstancePtr,
u8  Bank 
)

Get the Direction of the pins of the specified GPIO Bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Returns
Returns a 32 bit mask of the Direction register. Bits with 0 are in Input mode, bits with 1 are in Output Mode.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_DIRM_OFFSET, XGPIOPS_ONE, XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGPIOPS_TWO.

u32 XGpioPs_GetDirectionPin ( const XGpioPs InstancePtr,
u32  Pin 
)

Get the Direction of the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number for which the Direction is to be retrieved.
Returns
Direction of the specified pin.
  • 0 for Input Direction
  • 1 for Output Direction
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGPIOPS_DIRM_OFFSET, XGpioPs_GetBankPin(), XGpioPs_ReadReg, and XGPIOPS_REG_MASK_OFFSET.

void XGpioPs_GetIntrType ( const XGpioPs InstancePtr,
u8  Bank,
u32 *  IntrType,
u32 *  IntrPolarity,
u32 *  IntrOnAny 
)

This function is used for getting the Interrupt Type, Interrupt Polarity and Interrupt On Any for the specified GPIO Bank pins.

Parameters
InstancePtris a pointer to an XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
IntrTypereturns the 32 bit mask of the interrupt type. 0 means Level Sensitive and 1 means Edge Sensitive.
IntrPolarityreturns the 32 bit mask of the interrupt polarity. 0 means Active Low or Falling Edge and 1 means Active High or Rising Edge.
IntrOnAnyreturns the 32 bit mask of the interrupt trigger for edge triggered interrupts. 0 means trigger on single edge using the configured interrupt polarity and 1 means trigger on both edges.
Returns
None.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_INTANY_OFFSET, XGPIOPS_INTPOL_OFFSET, XGPIOPS_INTTYPE_OFFSET, XGPIOPS_ONE, XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGPIOPS_TWO.

Referenced by XGpioPs_SelfTest().

u8 XGpioPs_GetIntrTypePin ( const XGpioPs InstancePtr,
u32  Pin 
)

This function returns the IRQ Type of a given GPIO pin.

Parameters
InstancePtris a pointer to an XGpioPs instance.
Pinis the pin number whose IRQ type is to be obtained.
Returns
None.
Note
Use XGPIOPS_IRQ_TYPE_* defined in xgpiops.h for the IRQ type returned by this function.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_INTANY_OFFSET, XGPIOPS_INTPOL_OFFSET, XGPIOPS_INTTYPE_OFFSET, XGPIOPS_IRQ_TYPE_EDGE_BOTH, XGPIOPS_IRQ_TYPE_EDGE_FALLING, XGPIOPS_IRQ_TYPE_EDGE_RISING, XGPIOPS_IRQ_TYPE_LEVEL_HIGH, XGPIOPS_IRQ_TYPE_LEVEL_LOW, XGpioPs_ReadReg, and XGPIOPS_REG_MASK_OFFSET.

u32 XGpioPs_GetOutputEnable ( const XGpioPs InstancePtr,
u8  Bank 
)

Get the Output Enable status of the pins of the specified GPIO Bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Returns
Returns a a 32 bit mask of the Output Enable register. Bits with 0 are in Disabled state, bits with 1 are in Enabled State.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_ONE, XGPIOPS_OUTEN_OFFSET, XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGPIOPS_TWO.

u32 XGpioPs_GetOutputEnablePin ( const XGpioPs InstancePtr,
u32  Pin 
)

Get the Output Enable status of the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number for which the Output Enable status is to be retrieved.
Returns
Output Enable of the specified pin.
  • 0 if Output Enable is disabled for this pin
  • 1 if Output Enable is enabled for this pin
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_OUTEN_OFFSET, XGpioPs_ReadReg, and XGPIOPS_REG_MASK_OFFSET.

void XGpioPs_IntrClear ( const XGpioPs InstancePtr,
u8  Bank,
u32  Mask 
)

This function clears pending interrupt(s) with the provided mask.

This function should be called after the software has serviced the interrupts that are pending.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Maskis the mask of the interrupts to be cleared. Bit positions of 1 will be cleared. Bit positions of 0 will not change the previous interrupt status.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_INTSTS_OFFSET, XGPIOPS_ONE, XGPIOPS_REG_MASK_OFFSET, XGPIOPS_TWO, and XGpioPs_WriteReg.

Referenced by XGpioPs_IntrHandler().

void XGpioPs_IntrClearPin ( const XGpioPs InstancePtr,
u32  Pin 
)

This function clears the specified pending interrupt.

This function should be called after the software has serviced the interrupts that are pending.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number for which the interrupt status is to be cleared.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_INTSTS_OFFSET, XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGpioPs_WriteReg.

void XGpioPs_IntrDisable ( XGpioPs InstancePtr,
u8  Bank,
u32  Mask 
)

This function disables the interrupts for the specified pins in the specified bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Maskis the bit mask of the pins for which interrupts are to be disabled. Bit positions of 1 will be disabled. Bit positions of 0 will keep the previous setting.
Returns
None.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::CoreIntrMask, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_INTDIS_OFFSET, XGPIOPS_ONE, XGPIOPS_REG_MASK_OFFSET, XGPIOPS_TWO, and XGpioPs_WriteReg.

Referenced by XGpioPs_SelfTest().

void XGpioPs_IntrDisablePin ( XGpioPs InstancePtr,
u32  Pin 
)

This function disables the interrupts for the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number for which the interrupt is to be disabled.
Returns
None.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::CoreIntrMask, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_INTDIS_OFFSET, XGPIOPS_REG_MASK_OFFSET, and XGpioPs_WriteReg.

void XGpioPs_IntrEnable ( XGpioPs InstancePtr,
u8  Bank,
u32  Mask 
)

This function enables the interrupts for the specified pins in the specified bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Maskis the bit mask of the pins for which interrupts are to be enabled. Bit positions of 1 will be enabled. Bit positions of 0 will keep the previous setting.
Returns
None.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::CoreIntrMask, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_INTEN_OFFSET, XGPIOPS_ONE, XGPIOPS_REG_MASK_OFFSET, XGPIOPS_TWO, and XGpioPs_WriteReg.

Referenced by XGpioPs_SelfTest().

void XGpioPs_IntrEnablePin ( XGpioPs InstancePtr,
u32  Pin 
)

This function enables the interrupt for the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number for which the interrupt is to be enabled.
Returns
None.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::CoreIntrMask, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_INTEN_OFFSET, XGPIOPS_REG_MASK_OFFSET, and XGpioPs_WriteReg.

u32 XGpioPs_IntrGetEnabled ( const XGpioPs InstancePtr,
u8  Bank 
)

This function returns the interrupt enable status for a bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Returns
Enabled interrupt(s) in a 32-bit format. Bit positions with 1 indicate that the interrupt for that pin is enabled, bit positions with 0 indicate that the interrupt for that pin is disabled.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_INTMASK_OFFSET, XGPIOPS_ONE, XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGPIOPS_TWO.

Referenced by XGpioPs_IntrHandler(), and XGpioPs_SelfTest().

u32 XGpioPs_IntrGetEnabledPin ( const XGpioPs InstancePtr,
u32  Pin 
)

This function returns whether interrupts are enabled for the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number for which the interrupt enable status is to be known.
Returns
  • TRUE if the interrupt is enabled.
  • FALSE if the interrupt is disabled.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_INTMASK_OFFSET, XGpioPs_ReadReg, and XGPIOPS_REG_MASK_OFFSET.

u32 XGpioPs_IntrGetStatus ( const XGpioPs InstancePtr,
u8  Bank 
)

This function returns interrupt status read from Interrupt Status Register.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Returns
The value read from Interrupt Status Register.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_INTSTS_OFFSET, XGPIOPS_ONE, XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGPIOPS_TWO.

Referenced by XGpioPs_IntrHandler().

u32 XGpioPs_IntrGetStatusPin ( const XGpioPs InstancePtr,
u32  Pin 
)

This function returns interrupt enable status of the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number for which the interrupt enable status is to be known.
Returns
  • TRUE if the interrupt has occurred.
  • FALSE if the interrupt has not occurred.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_INTSTS_OFFSET, XGpioPs_ReadReg, and XGPIOPS_REG_MASK_OFFSET.

void XGpioPs_IntrHandler ( const XGpioPs InstancePtr)

This function is the interrupt handler for GPIO interrupts.It checks the interrupt status registers of all the banks to determine the actual bank in which an interrupt has been triggered.

It then calls the upper layer callback handler set by the function XGpioPs_SetBankHandler(). The callback is called when an interrupt

Parameters
InstancePtris a pointer to the XGpioPs instance.
Returns
None.
Note
This function does not save and restore the processor context such that the user must provide this processing.

References XGpioPs::CallBackRef, XGpioPs::CoreIntrMask, XGpioPs::Handler, XGpioPs::IsReady, XGpioPs::MaxBanks, XGpioPs::PmcGpio, XGpioPs_IntrClear(), XGpioPs_IntrGetEnabled(), XGpioPs_IntrGetStatus(), XGPIOPS_ONE, and XGPIOPS_TWO.

XGpioPs_Config * XGpioPs_LookupConfig ( u16  DeviceId)

This function looks for the device configuration based on the unique device ID.

The table XGpioPs_ConfigTable[] contains the configuration information for each device in the system.

Parameters
DeviceIdis the unique device ID of the device being looked up.
Returns
A pointer to the configuration table entry corresponding to the given device ID, or NULL if no match is found.
Note
None.

References XGpioPs_ConfigTable.

Referenced by GpioPolledExample().

u32 XGpioPs_Read ( const XGpioPs InstancePtr,
u8  Bank 
)

Read the Data register of the specified GPIO bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Returns
Current value of the Data register.
Note
This function is used for reading the state of all the GPIO pins of specified bank.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_DATA_BANK_OFFSET, XGPIOPS_DATA_RO_OFFSET, XGPIOPS_ONE, XGpioPs_ReadReg, and XGPIOPS_TWO.

u32 XGpioPs_ReadPin ( const XGpioPs InstancePtr,
u32  Pin 
)

Read Data from the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number for which the data has to be read.
Returns
Current value of the Pin (0 or 1).
Note
This function is used for reading the state of the specified GPIO pin.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGPIOPS_DATA_BANK_OFFSET, XGPIOPS_DATA_RO_OFFSET, XGpioPs_GetBankPin(), and XGpioPs_ReadReg.

s32 XGpioPs_SelfTest ( XGpioPs InstancePtr)

This function runs a self-test on the GPIO driver/device.

This function does a register read/write test on some of the Interrupt Registers.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Returns
  • XST_SUCCESS if the self-test passed.
    • XST_FAILURE otherwise.

References XGpioPs::IsReady, XGPIOPS_BANK0, XGpioPs_GetIntrType(), XGpioPs_IntrDisable(), XGpioPs_IntrEnable(), XGpioPs_IntrGetEnabled(), and XGpioPs_SetIntrType().

void XGpioPs_SetCallbackHandler ( XGpioPs InstancePtr,
void *  CallBackRef,
XGpioPs_Handler  FuncPointer 
)

This function sets the status callback function.

The callback function is called by the XGpioPs_IntrHandler when an interrupt occurs.

Parameters
InstancePtris a pointer to the XGpioPs instance.
CallBackRefis the upper layer callback reference passed back when the callback function is invoked.
FuncPointeris the pointer to the callback function.
Returns
None.
Note
The handler is called within interrupt context, so it should do its work quickly and queue potentially time-consuming work to a task-level thread.

References XGpioPs::CallBackRef, XGpioPs::Handler, and XGpioPs::IsReady.

void XGpioPs_SetDirection ( const XGpioPs InstancePtr,
u8  Bank,
u32  Direction 
)

Set the Direction of the pins of the specified GPIO Bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Directionis the 32 bit mask of the Pin direction to be set for all the pins in the Bank. Bits with 0 are set to Input mode, bits with 1 are set to Output Mode.
Returns
None.
Note
This function is used for setting the direction of all the pins in the specified bank. The previous state of the pins is not maintained.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_DIRM_OFFSET, XGPIOPS_ONE, XGPIOPS_REG_MASK_OFFSET, XGPIOPS_TWO, and XGpioPs_WriteReg.

void XGpioPs_SetDirectionPin ( const XGpioPs InstancePtr,
u32  Pin,
u32  Direction 
)

Set the Direction of the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number to which the Data is to be written.
Directionis the direction to be set for the specified pin. Valid values are 0 for Input Direction, 1 for Output Direction.
Returns
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGPIOPS_DIRM_OFFSET, XGpioPs_GetBankPin(), XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGpioPs_WriteReg.

void XGpioPs_SetIntrType ( const XGpioPs InstancePtr,
u8  Bank,
u32  IntrType,
u32  IntrPolarity,
u32  IntrOnAny 
)

This function is used for setting the Interrupt Type, Interrupt Polarity and Interrupt On Any for the specified GPIO Bank pins.

Parameters
InstancePtris a pointer to an XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
IntrTypeis the 32 bit mask of the interrupt type. 0 means Level Sensitive and 1 means Edge Sensitive.
IntrPolarityis the 32 bit mask of the interrupt polarity. 0 means Active Low or Falling Edge and 1 means Active High or Rising Edge.
IntrOnAnyis the 32 bit mask of the interrupt trigger for edge triggered interrupts. 0 means trigger on single edge using the configured interrupt polarity and 1 means trigger on both edges.
Returns
None.
Note
This function is used for setting the interrupt related properties of all the pins in the specified bank. The previous state of the pins is not maintained. To change the Interrupt properties of a single GPIO pin, use the function XGpioPs_SetPinIntrType().

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_INTANY_OFFSET, XGPIOPS_INTPOL_OFFSET, XGPIOPS_INTTYPE_OFFSET, XGPIOPS_ONE, XGPIOPS_REG_MASK_OFFSET, XGPIOPS_TWO, and XGpioPs_WriteReg.

Referenced by XGpioPs_SelfTest().

void XGpioPs_SetIntrTypePin ( const XGpioPs InstancePtr,
u32  Pin,
u8  IrqType 
)

This function is used for setting the IRQ Type of a single GPIO pin.

Parameters
InstancePtris a pointer to an XGpioPs instance.
Pinis the pin number whose IRQ type is to be set.
IrqTypeis the IRQ type for GPIO Pin. Use XGPIOPS_IRQ_TYPE_* defined in xgpiops.h to specify the IRQ type.
Returns
None.
Note
None.

< Default statement is added for MISRA C compliance.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_INTANY_OFFSET, XGPIOPS_INTPOL_OFFSET, XGPIOPS_INTTYPE_OFFSET, XGPIOPS_IRQ_TYPE_EDGE_BOTH, XGPIOPS_IRQ_TYPE_EDGE_FALLING, XGPIOPS_IRQ_TYPE_EDGE_RISING, XGPIOPS_IRQ_TYPE_LEVEL_HIGH, XGPIOPS_IRQ_TYPE_LEVEL_LOW, XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGpioPs_WriteReg.

void XGpioPs_SetOutputEnable ( const XGpioPs InstancePtr,
u8  Bank,
u32  OpEnable 
)

Set the Output Enable of the pins of the specified GPIO Bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
OpEnableis the 32 bit mask of the Output Enables to be set for all the pins in the Bank. The Output Enable of bits with 0 are disabled, the Output Enable of bits with 1 are enabled.
Returns
None.
Note
This function is used for setting the Output Enables of all the pins in the specified bank. The previous state of the Output Enables is not maintained.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_ONE, XGPIOPS_OUTEN_OFFSET, XGPIOPS_REG_MASK_OFFSET, XGPIOPS_TWO, and XGpioPs_WriteReg.

void XGpioPs_SetOutputEnablePin ( const XGpioPs InstancePtr,
u32  Pin,
u32  OpEnable 
)

Set the Output Enable of the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number to which the Data is to be written.
OpEnablespecifies whether the Output Enable for the specified pin should be enabled. Valid values are 0 for Disabling Output Enable, 1 for Enabling Output Enable.
Returns
None.
Note
None.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs_GetBankPin(), XGPIOPS_OUTEN_OFFSET, XGpioPs_ReadReg, XGPIOPS_REG_MASK_OFFSET, and XGpioPs_WriteReg.

void XGpioPs_Write ( const XGpioPs InstancePtr,
u8  Bank,
u32  Data 
)

Write to the Data register of the specified GPIO bank.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Bankis the bank number of the GPIO to operate on.
Datais the value to be written to the Data register.
Returns
None.
Note
This function is used for writing to all the GPIO pins of the bank. The previous state of the pins is not maintained.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGpioPs::PmcGpio, XGPIOPS_DATA_BANK_OFFSET, XGPIOPS_DATA_OFFSET, XGPIOPS_ONE, XGPIOPS_TWO, and XGpioPs_WriteReg.

void XGpioPs_WritePin ( const XGpioPs InstancePtr,
u32  Pin,
u32  Data 
)

Write data to the specified pin.

Parameters
InstancePtris a pointer to the XGpioPs instance.
Pinis the pin number to which the Data is to be written.
Datais the data to be written to the specified pin (0 or 1).
Returns
None.
Note
This function does a masked write to the specified pin of the specified GPIO bank. The previous state of other pins is maintained.

References XGpioPs_Config::BaseAddr, XGpioPs::GpioConfig, XGpioPs::IsReady, XGPIOPS_DATA_LSW_OFFSET, XGPIOPS_DATA_MASK_OFFSET, XGPIOPS_DATA_MSW_OFFSET, XGpioPs_GetBankPin(), and XGpioPs_WriteReg.

Variable Documentation

XGpioPs_Config XGpioPs_ConfigTable[XPAR_XGPIOPS_NUM_INSTANCES]
Initial value:
= {
{
(u16)XPAR_XGPIOPS_0_DEVICE_ID,
(u32)XPAR_XGPIOPS_0_BASEADDR
}
}

This table contains configuration information for each GPIO device in the system.

Referenced by XGpioPs_LookupConfig().

XGpioPs_Config XGpioPs_ConfigTable[]

This table contains configuration information for each GPIO device in the system.

Referenced by XGpioPs_LookupConfig().