40 #ifndef __DRIVERLIB_GPIO_H__
41 #define __DRIVERLIB_GPIO_H__
60 #define GPIO_PIN_0 0x00000001 // GPIO pin 0
61 #define GPIO_PIN_1 0x00000002 // GPIO pin 1
62 #define GPIO_PIN_2 0x00000004 // GPIO pin 2
63 #define GPIO_PIN_3 0x00000008 // GPIO pin 3
64 #define GPIO_PIN_4 0x00000010 // GPIO pin 4
65 #define GPIO_PIN_5 0x00000020 // GPIO pin 5
66 #define GPIO_PIN_6 0x00000040 // GPIO pin 6
67 #define GPIO_PIN_7 0x00000080 // GPIO pin 7
75 #define GPIO_DIR_MODE_IN 0x00000000 // Pin is a GPIO input
76 #define GPIO_DIR_MODE_OUT 0x00000001 // Pin is a GPIO output
77 #define GPIO_DIR_MODE_HW 0x00000002 // Pin is a peripheral function
85 #define GPIO_FALLING_EDGE 0x00000000 // Interrupt on falling edge
86 #define GPIO_RISING_EDGE 0x00000004 // Interrupt on rising edge
87 #define GPIO_BOTH_EDGES 0x00000001 // Interrupt on both edges
88 #define GPIO_LOW_LEVEL 0x00000002 // Interrupt on low level
89 #define GPIO_HIGH_LEVEL 0x00000006 // Interrupt on high level
90 #define GPIO_DISCRETE_INT 0x00010000 // Interrupt for individual pins
98 #define GPIO_STRENGTH_2MA 0x00000001 // 2mA drive strength
99 #define GPIO_STRENGTH_4MA 0x00000002 // 4mA drive strength
100 #define GPIO_STRENGTH_6MA 0x00000065 // 6mA drive strength
101 #define GPIO_STRENGTH_8MA 0x00000066 // 8mA drive strength
102 #define GPIO_STRENGTH_8MA_SC 0x0000006E // 8mA drive with slew rate control
103 #define GPIO_STRENGTH_10MA 0x00000075 // 10mA drive strength
104 #define GPIO_STRENGTH_12MA 0x00000077 // 12mA drive strength
112 #define GPIO_PIN_TYPE_STD 0x00000008 // Push-pull
113 #define GPIO_PIN_TYPE_STD_WPU 0x0000000A // Push-pull with weak pull-up
114 #define GPIO_PIN_TYPE_STD_WPD 0x0000000C // Push-pull with weak pull-down
115 #define GPIO_PIN_TYPE_OD 0x00000009 // Open-drain
116 #define GPIO_PIN_TYPE_ANALOG 0x00000000 // Analog comparator
117 #define GPIO_PIN_TYPE_WAKE_HIGH 0x00000208 // Hibernate wake, high
118 #define GPIO_PIN_TYPE_WAKE_LOW 0x00000108 // Hibernate wake, low
126 #define GPIO_INT_PIN_0 0x00000001
127 #define GPIO_INT_PIN_1 0x00000002
128 #define GPIO_INT_PIN_2 0x00000004
129 #define GPIO_INT_PIN_3 0x00000008
130 #define GPIO_INT_PIN_4 0x00000010
131 #define GPIO_INT_PIN_5 0x00000020
132 #define GPIO_INT_PIN_6 0x00000040
133 #define GPIO_INT_PIN_7 0x00000080
134 #define GPIO_INT_DMA 0x00000100
143 extern uint32_t
GPIODirModeGet(uint32_t ui32Port, uint8_t ui8Pin);
145 uint32_t ui32IntType);
146 extern uint32_t
GPIOIntTypeGet(uint32_t ui32Port, uint8_t ui8Pin);
148 uint32_t ui32Strength, uint32_t ui32PadType);
150 uint32_t *pui32Strength, uint32_t *pui32PadType);
151 extern void GPIOIntEnable(uint32_t ui32Port, uint32_t ui32IntFlags);
152 extern void GPIOIntDisable(uint32_t ui32Port, uint32_t ui32IntFlags);
153 extern uint32_t
GPIOIntStatus(uint32_t ui32Port,
bool bMasked);
154 extern void GPIOIntClear(uint32_t ui32Port, uint32_t ui32IntFlags);
155 extern void GPIOIntRegister(uint32_t ui32Port,
void (*pfnIntHandler)(
void));
157 extern int32_t
GPIOPinRead(uint32_t ui32Port, uint8_t ui8Pins);
158 extern void GPIOPinWrite(uint32_t ui32Port, uint8_t ui8Pins, uint8_t ui8Val);
196 #endif // __DRIVERLIB_GPIO_H__
void GPIOIntTypeSet(uint32_t ui32Port, uint8_t ui8Pins, uint32_t ui32IntType)
void GPIOPinTypeWakeHigh(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeEthernetMII(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinWrite(uint32_t ui32Port, uint8_t ui8Pins, uint8_t ui8Val)
void GPIOPinTypeI2C(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeUART(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOIntUnregister(uint32_t ui32Port)
void GPIOPinTypeEthernetLED(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOIntDisable(uint32_t ui32Port, uint32_t ui32IntFlags)
uint32_t GPIODirModeGet(uint32_t ui32Port, uint8_t ui8Pin)
void GPIOPinTypeEPI(uint32_t ui32Port, uint8_t ui8Pins)
uint32_t GPIOIntTypeGet(uint32_t ui32Port, uint8_t ui8Pin)
void GPIODMATriggerDisable(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPadConfigSet(uint32_t ui32Port, uint8_t ui8Pins, uint32_t ui32Strength, uint32_t ui32PadType)
void GPIOADCTriggerDisable(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeI2CSCL(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeUSBDigital(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOIntEnable(uint32_t ui32Port, uint32_t ui32IntFlags)
void GPIOPadConfigGet(uint32_t ui32Port, uint8_t ui8Pin, uint32_t *pui32Strength, uint32_t *pui32PadType)
void GPIOIntRegister(uint32_t ui32Port, void(*pfnIntHandler)(void))
void GPIOPinTypePWM(uint32_t ui32Port, uint8_t ui8Pins)
void GPIODMATriggerEnable(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOADCTriggerEnable(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeQEI(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeLCD(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeGPIOOutput(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeComparator(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeWakeLow(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinConfigure(uint32_t ui32PinConfig)
void GPIOPinTypeTimer(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeGPIOInput(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeADC(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeGPIOOutputOD(uint32_t ui32Port, uint8_t ui8Pins)
uint32_t GPIOPinWakeStatus(uint32_t ui32Port)
void GPIOPinTypeSSI(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeUSBAnalog(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOIntClear(uint32_t ui32Port, uint32_t ui32IntFlags)
int32_t GPIOPinRead(uint32_t ui32Port, uint8_t ui8Pins)
void GPIOPinTypeCAN(uint32_t ui32Port, uint8_t ui8Pins)
void GPIODirModeSet(uint32_t ui32Port, uint8_t ui8Pins, uint32_t ui32PinIO)
uint32_t GPIOIntStatus(uint32_t ui32Port, bool bMasked)