xref: /rk3399_ARM-atf/include/drivers/gpio.h (revision 0ac23de9ce7cd5630dd55f3f8b4613faa021547e)
11ffecc24SHaojian Zhuang /*
2*9565962cSJona Stubbe  * Copyright (c) 2016-2021, ARM Limited and Contributors. All rights reserved.
31ffecc24SHaojian Zhuang  *
482cb2c1aSdp-arm  * SPDX-License-Identifier: BSD-3-Clause
51ffecc24SHaojian Zhuang  */
61ffecc24SHaojian Zhuang 
7c3cf06f1SAntonio Nino Diaz #ifndef GPIO_H
8c3cf06f1SAntonio Nino Diaz #define GPIO_H
91ffecc24SHaojian Zhuang 
1057bf6057SJulius Werner #include <export/drivers/gpio_exp.h>
111ffecc24SHaojian Zhuang 
1257bf6057SJulius Werner #define GPIO_DIR_OUT		ARM_TF_GPIO_DIR_OUT
1357bf6057SJulius Werner #define GPIO_DIR_IN		ARM_TF_GPIO_DIR_IN
141ffecc24SHaojian Zhuang 
1557bf6057SJulius Werner #define GPIO_LEVEL_LOW		ARM_TF_GPIO_LEVEL_LOW
1657bf6057SJulius Werner #define GPIO_LEVEL_HIGH		ARM_TF_GPIO_LEVEL_HIGH
1757bf6057SJulius Werner 
1857bf6057SJulius Werner #define GPIO_PULL_NONE		ARM_TF_GPIO_PULL_NONE
1957bf6057SJulius Werner #define GPIO_PULL_UP		ARM_TF_GPIO_PULL_UP
2057bf6057SJulius Werner #define GPIO_PULL_DOWN		ARM_TF_GPIO_PULL_DOWN
21*9565962cSJona Stubbe #define GPIO_PULL_REPEATER	ARM_TF_GPIO_PULL_REPEATER
2219588982SCaesar Wang 
231ffecc24SHaojian Zhuang typedef struct gpio_ops {
241ffecc24SHaojian Zhuang 	int (*get_direction)(int gpio);
251ffecc24SHaojian Zhuang 	void (*set_direction)(int gpio, int direction);
261ffecc24SHaojian Zhuang 	int (*get_value)(int gpio);
271ffecc24SHaojian Zhuang 	void (*set_value)(int gpio, int value);
2819588982SCaesar Wang 	void (*set_pull)(int gpio, int pull);
2919588982SCaesar Wang 	int (*get_pull)(int gpio);
301ffecc24SHaojian Zhuang } gpio_ops_t;
311ffecc24SHaojian Zhuang 
321ffecc24SHaojian Zhuang int gpio_get_direction(int gpio);
331ffecc24SHaojian Zhuang void gpio_set_direction(int gpio, int direction);
341ffecc24SHaojian Zhuang int gpio_get_value(int gpio);
351ffecc24SHaojian Zhuang void gpio_set_value(int gpio, int value);
3619588982SCaesar Wang void gpio_set_pull(int gpio, int pull);
3719588982SCaesar Wang int gpio_get_pull(int gpio);
381ffecc24SHaojian Zhuang void gpio_init(const gpio_ops_t *ops);
391ffecc24SHaojian Zhuang 
40c3cf06f1SAntonio Nino Diaz #endif /* GPIO_H */
41