mirror of
https://github.com/riscv-software-src/opensbi.git
synced 2025-08-24 23:41:23 +01:00

FDT gpio drivers have an extra .xlate operation, so they need to embed the `struct fdt_driver` inside the subsystem-specific type. The gpio subsystem always initializes the driver for a specific DT node. Signed-off-by: Samuel Holland <samuel.holland@sifive.com> Reviewed-by: Anup Patel <anup@brainfault.org>
36 lines
882 B
C
36 lines
882 B
C
/*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*
|
|
* Copyright (c) 2021 Western Digital Corporation or its affiliates.
|
|
*
|
|
* Authors:
|
|
* Anup Patel <anup.patel@wdc.com>
|
|
*/
|
|
|
|
#ifndef __FDT_GPIO_H__
|
|
#define __FDT_GPIO_H__
|
|
|
|
#include <sbi_utils/fdt/fdt_driver.h>
|
|
#include <sbi_utils/gpio/gpio.h>
|
|
|
|
struct fdt_phandle_args;
|
|
|
|
/** FDT based GPIO driver */
|
|
struct fdt_gpio {
|
|
struct fdt_driver driver;
|
|
int (*xlate)(struct gpio_chip *chip,
|
|
const struct fdt_phandle_args *pargs,
|
|
struct gpio_pin *out_pin);
|
|
};
|
|
|
|
/** Get a GPIO pin using "gpios" DT property of client DT node */
|
|
int fdt_gpio_pin_get(const void *fdt, int nodeoff, int index,
|
|
struct gpio_pin *out_pin);
|
|
|
|
/** Simple xlate function to convert two GPIO FDT cells into GPIO pin */
|
|
int fdt_gpio_simple_xlate(struct gpio_chip *chip,
|
|
const struct fdt_phandle_args *pargs,
|
|
struct gpio_pin *out_pin);
|
|
|
|
#endif
|