32volatile uint32_t *
gpio = NULL;
37 return (
gpio != NULL) ? true :
false;
84 pynq_error(
"gpio_set_direction: invalid direction %d", dir);
86 int pin_bank =
pin % 32;
87 int bank =
pin < 32 ? 1 : 3;
89 gpio[bank] =
gpio[bank] | (1 << pin_bank);
91 gpio[bank] =
gpio[bank] & ~(1 << pin_bank);
97 int pin_bank =
pin % 32;
98 int bank =
pin < 32 ? 1 : 3;
107 pynq_error(
"gpio_set_level: level %d is invalid", level);
109 int pin_bank =
pin % 32;
110 int bank =
pin < 32 ? 0 : 2;
112 gpio[bank] =
gpio[bank] | (1 << pin_bank);
114 gpio[bank] =
gpio[bank] & ~(1 << pin_bank);
120 int pin_bank =
pin % 32;
121 int bank =
pin < 32 ? 0 : 2;
volatile uint32_t * intc0
void arm_shared_close(arm_shared *handle)
void * arm_shared_init(arm_shared *handle, const uint32_t address, const uint32_t length)
bool gpio_is_initialized(void)
void gpio_reset(void)
Reset all GPIO pins.
gpio_direction_t gpio_get_direction(const pin_t pin)
Returns the direction the set pin is initialized in.
void gpio_reset_pin(const pin_t pin)
Function is currently a no-op placeholder for arduino compatibility.
void gpio_set_direction(const pin_t pin, const gpio_direction_t dir)
Set the GPIO pin as in input or output.
gpio_level_t gpio_get_level(const pin_t pin)
Return the level of the GPIO pin.
void gpio_set_level(const pin_t pin, const gpio_level_t level)
Set the level of the output GPIO pin. If the pin is configured as input, this function does nothing.