GRiSP General Purpose Input/Output (GPIO) API.
General Purpose Input / Output (GPIO) is used to control digital signals on a
pin. The digital values 0
and 1
correspond to a low or high voltage
respectively. On GRiSP the voltage for GPIO pins is 3.3V.
A pin can be controlled either as an output pin or an input pin. For an output pin, it is possible to set or get the current value. For an input pin, it is possible to get the current value.
For PMOD connectors, the number column (#) maps to the respective PMOD pin (see Figure 1).
ID | Mapping | Direction | Description | |||
---|---|---|---|---|---|---|
Slot | Type | # | Schematic | |||
gpio1_1 | GPIO1 | PMOD 1A | 1 | X1404.1 | In/Out | |
gpio1_2 | GPIO1 | PMOD 1A | 2 | X1404.2 | In/Out | |
gpio1_3 | GPIO1 | PMOD 1A | 3 | X1404.3 | In/Out | |
gpio1_4 | GPIO1 | PMOD 1A | 4 | X1404.4 | In/Out | |
gpio1_7 | GPIO1 | PMOD 1A | 7 | X1404.7 | In/Out | |
gpio1_8 | GPIO1 | PMOD 1A | 8 | X1404.8 | In/Out | |
gpio1_9 | GPIO1 | PMOD 1A | 9 | X1404.9 | In/Out | |
gpio_1_3 | GPIO_1 | Generic | X1300.3 | In/Out | ||
gpio_1_4 | GPIO_1 | Generic | X1300.4 | In/Out | ||
gpio_1_5 | GPIO_1 | Generic | X1300.5 | In/Out | ||
gpio_1_6 | GPIO_1 | Generic | X1300.6 | In/Out | ||
gpio_2_3 | GPIO_2/4 | Generic | X1301.3 | In/Out | ||
gpio_2_4 | GPIO_2/4 | Generic | X1301.4 | In/Out | ||
gpio_2_5 | GPIO_2/4 | Generic | X1301.5 | In/Out | ||
gpio_2_6 | GPIO_2/4 | Generic | X1301.6 | In/Out | ||
gpio_2_7 | GPIO_2/4 | Generic | X1301.7 | In/Out | ||
gpio_2_8 | GPIO_2/4 | Generic | X1301.8 | In/Out | ||
gpio_2_9 | GPIO_2/4 | Generic | X1301.9 | In/Out | ||
gpio_2_10 | GPIO_2/4 | Generic | X1301.10 | In/Out | ||
gpio_2_11 | GPIO_2/4 | Generic | X1301.11 | In/Out | ||
gpio_2_12 | GPIO_2/4 | Generic | X1301.12 | In/Out | ||
gpio_2_13 | GPIO_2/4 | Generic | X1301.13 | In/Out | ||
gpio_2_14 | GPIO_2/4 | Generic | X1301.14 | In/Out | ||
led1_r | LED 1 | LED | RGB1red | Out | Reserved by LED driver | |
led1_g | LED 1 | LED | RGB1green | Out | Reserved by LED driver | |
led1_b | LED 1 | LED | RGB1blue | Out | Reserved by LED driver | |
led2_r | LED 2 | LED | RGB2red | Out | Reserved by LED driver | |
led2_g | LED 2 | LED | RGB2green | Out | Reserved by LED driver | |
led2_b | LED 2 | LED | RGB3blue | Out | Reserved by LED driver | |
jumper_1 | Mode | Jumper | JUMPER1 | In | Mode Switch Jumper State | |
jumper_2 | Mode | Jumper | JUMPER2 | In | Mode Switch Jumper State | |
jumper_3 | Mode | Jumper | JUMPER3 | In | Mode Switch Jumper State | |
jumper_4 | Mode | Jumper | JUMPER4 | In | Mode Switch Jumper State | |
jumper_5 | Mode | Jumper | JUMPER5 | In | Mode Switch Jumper State | |
Warning! Reserved pins should only be carefully used if their drivers are not in use |
ID | Mapping | Direction | Description | |||
---|---|---|---|---|---|---|
Slot | Type | # | Schematic | |||
gpio1_1 | GPIO1 | PMOD 1 | 1 | X502.1 | In/Out | |
gpio1_2 | GPIO1 | PMOD 1 | 2 | X502.2 | In/Out | |
gpio1_3 | GPIO1 | PMOD 1 | 3 | X502.3 | In/Out | |
gpio1_4 | GPIO1 | PMOD 1 | 4 | X502.4 | In/Out | |
gpio2_1 | GPIO2 | PMOD 1 | 1 | X503.1 | In/Out | |
gpio2_2 | GPIO2 | PMOD 1 | 2 | X503.2 | In/Out | |
gpio2_3 | GPIO2 | PMOD 1 | 3 | X503.3 | In/Out | |
gpio2_4 | GPIO2 | PMOD 1 | 4 | X503.4 | In/Out | |
led1_r | LED 1 | LED | RGB1red | Out | Reserved by LED driver | |
led1_g | LED 1 | LED | RGB1green | Out | Reserved by LED driver | |
led1_b | LED 1 | LED | RGB1blue | Out | Reserved by LED driver | |
led2_r | LED 2 | LED | RGB2red | Out | Reserved by LED driver | |
led2_g | LED 2 | LED | RGB2green | Out | Reserved by LED driver | |
led2_b | LED 2 | LED | RGB3blue | Out | Reserved by LED driver | |
jumper_1 | Mode | Jumper | JUMPER1 | In | Mode Switch Jumper State | |
jumper_2 | Mode | Jumper | JUMPER2 | In | Mode Switch Jumper State | |
jumper_3 | Mode | Jumper | JUMPER3 | In | Mode Switch Jumper State | |
jumper_4 | Mode | Jumper | JUMPER4 | In | Mode Switch Jumper State | |
jumper_5 | Mode | Jumper | JUMPER5 | In | Mode Switch Jumper State | |
spi1_pin7 | SPI1 | PMOD 2A | 7 | X501.7 | In/Out | |
spi1_pin8 | SPI1 | PMOD 2A | 8 | X501.8 | In/Out | |
spi1_pin9 | SPI1 | PMOD 2A | 9 | X501.9 | In/Out | Reserved by SPI driver |
spi1_pin10 | SPI1 | PMOD 2A | 10 | X501.10 | In/Out | Reserved by SPI driver |
spi1_pin1 | SPI1 | PMOD 2A | 1 | X501.1 | In/Out | Reserved by SPI driver |
spi2_pin1 | SPI2 | PMOD 2 | 1 | X509.1 | In/Out | Reserved by SPI driver |
uart_1_cts | UART | PMOD 3 | 1 | X508.1 | In/Out | |
uart_2_txd | UART | PMOD 3 | 2 | X508.2 | In/Out | |
uart_3_rxd | UART | PMOD 3 | 3 | X508.3 | In/Out | |
uart_4_rts | UART | PMOD 3 | 4 | X508.4 | In/Out | |
Warning! Reserved pins should only be carefully used if their drivers are not in use |
mode() = input | {output, value()}
opts() = #{mode => mode(), term() => term()}
pin() = atom()
abstract datatype: ref()
value() = 0 | 1
get/1 | Returns the current value of a pin. |
open/1 | Equivalent to open(Pin, #{}). |
open/2 | Creates a reference to a GPIO pin. |
set/2 | Sets the current value of an output pin. |
Returns the current value of a pin.
Returns the actual value for input pins or the currently set value for output pins.
1> LED1R = grisp_gpio:open(led1_r, #{mode => {output, 0}}). #Ref<0.2691682867.116916226.176944> 2> grisp_gpio:get(LED1R). 0 3> grisp_gpio:set(LED1R, 1). ok 2> grisp_gpio:get(LED1R). 1To see whether Mode Jumper 1 is on or off:
1> Jumper1 = grisp_gpio:open(jumper_1, #{mode => input}). #Ref<0.2691682867.116916226.176944> 2> grisp_gpio:get(Jumper1). 0Flip the jumper
3> grisp_gpio:get(Jumper1). 1
Equivalent to open(Pin, #{}).
Creates a reference to a GPIO pin.
If no mode is given in the options, it defaults to {output, 0}
.
0
:
1> grisp_gpio:open(led1_r, #{mode => {output, 0}}). #Ref<0.2691682867.116916226.176944>Open the GPIO pin of Mode Jumper 1 as an input pin:
1> grisp_gpio:open(jumper_1, #{mode => input}). #Ref<0.2691682867.116916226.176944>
Sets the current value of an output pin.
1> LED1R = grisp_gpio:open(led1_r, #{mode => {output, 0}}). #Ref<0.2691682867.116916226.176944> 2> grisp_gpio:set(LED1R, 0). okTurn on the red component of LED 1:
3> grisp_gpio:set(LED1R, 1). ok
Generated by EDoc