lib: utils/gpio: Use FDT node offset as GPIO chip ID

Since the FDT is not modified during driver initialization, node offsets
are just as suitable as phandles for use as identifiers: they are stable
and unique. With this change, it is no longer necessary to pass the
phandle to the driver init functions, so these init functions now use
the same prototype as other kinds of drivers.

This matches what is already done for I2C adapters.

Signed-off-by: Samuel Holland <samuel.holland@sifive.com>
Reviewed-by: Anup Patel <anup@brainfault.org>
This commit is contained in:
Samuel Holland
2024-09-03 19:09:38 -07:00
committed by Anup Patel
parent 598cf961d8
commit d71150ee70
5 changed files with 15 additions and 22 deletions

View File

@@ -62,7 +62,7 @@ static void sifive_gpio_set(struct gpio_pin *gp, int value)
extern struct fdt_gpio fdt_gpio_sifive;
static int sifive_gpio_init(const void *fdt, int nodeoff, u32 phandle,
static int sifive_gpio_init(const void *fdt, int nodeoff,
const struct fdt_match *match)
{
int rc;
@@ -81,7 +81,7 @@ static int sifive_gpio_init(const void *fdt, int nodeoff, u32 phandle,
chip->addr = addr;
chip->chip.driver = &fdt_gpio_sifive;
chip->chip.id = phandle;
chip->chip.id = nodeoff;
chip->chip.ngpio = SIFIVE_GPIO_PINS_DEF;
chip->chip.direction_output = sifive_gpio_direction_output;
chip->chip.set = sifive_gpio_set;