]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/RISC-V_RV32_SiFive_HiFive1_FreedomStudio/freedom-metal/src/gpio.c
Update RISCC-V-RV32-SiFive_HiFive1_FreedomStudio project to latest tools and metal...
[freertos] / FreeRTOS / Demo / RISC-V_RV32_SiFive_HiFive1_FreedomStudio / freedom-metal / src / gpio.c
1 /* Copyright 2019 SiFive, Inc */
2 /* SPDX-License-Identifier: Apache-2.0 */
3
4 #include <metal/machine.h>
5 #include <metal/gpio.h>
6
7 extern __inline__ int metal_gpio_disable_input(struct metal_gpio *gpio, int pin);
8 extern __inline__ int metal_gpio_enable_input(struct metal_gpio *gpio, int pin);
9 extern __inline__ int metal_gpio_enable_output(struct metal_gpio *gpio, int pin);
10 extern __inline__ int metal_gpio_disable_output(struct metal_gpio *gpio, int pin);
11 extern __inline__ int metal_gpio_get_output_pin(struct metal_gpio *gpio, int pin);
12 extern __inline__ int metal_gpio_get_input_pin(struct metal_gpio *gpio, int pin);
13 extern __inline__ int metal_gpio_set_pin(struct metal_gpio *, int pin, int value);
14 extern __inline__ int metal_gpio_clear_pin(struct metal_gpio *, int pin);
15 extern __inline__ int metal_gpio_toggle_pin(struct metal_gpio *, int pin);
16 extern __inline__ int metal_gpio_enable_pinmux(struct metal_gpio *, int pin, int io_function);
17 extern __inline__ int metal_gpio_disable_pinmux(struct metal_gpio *, int pin);
18 extern __inline__ struct metal_interrupt* metal_gpio_interrupt_controller(struct metal_gpio *gpio);
19 extern __inline__ int metal_gpio_get_interrupt_id(struct metal_gpio *gpio, int pin);
20 extern __inline__ int metal_gpio_config_interrupt(struct metal_gpio *gpio, int pin, int intr_type);
21 extern __inline__ int metal_gpio_clear_interrupt(struct metal_gpio *gpio, int pin, int intr_type);
22
23 struct metal_gpio *metal_gpio_get_device(unsigned int device_num)
24 {
25     if(device_num > __MEE_DT_MAX_GPIOS) {
26         return NULL;
27     }
28
29     return (struct metal_gpio *) __metal_gpio_table[device_num];
30 }