|
@@ -1208,6 +1208,16 @@ static int rockchip_pmx_set(struct pinctrl_dev *pctldev, unsigned selector,
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
+static int rockchip_gpio_get_direction(struct gpio_chip *chip, unsigned offset)
|
|
|
+{
|
|
|
+ struct rockchip_pin_bank *bank = gpiochip_get_data(chip);
|
|
|
+ u32 data;
|
|
|
+
|
|
|
+ data = readl_relaxed(bank->reg_base + GPIO_SWPORT_DDR);
|
|
|
+
|
|
|
+ return !(data & BIT(offset));
|
|
|
+}
|
|
|
+
|
|
|
/*
|
|
|
* The calls to gpio_direction_output() and gpio_direction_input()
|
|
|
* leads to this function call (via the pinctrl_gpio_direction_{input|output}()
|
|
@@ -1741,6 +1751,7 @@ static const struct gpio_chip rockchip_gpiolib_chip = {
|
|
|
.free = gpiochip_generic_free,
|
|
|
.set = rockchip_gpio_set,
|
|
|
.get = rockchip_gpio_get,
|
|
|
+ .get_direction = rockchip_gpio_get_direction,
|
|
|
.direction_input = rockchip_gpio_direction_input,
|
|
|
.direction_output = rockchip_gpio_direction_output,
|
|
|
.to_irq = rockchip_gpio_to_irq,
|