dm: gpio: MPC85XX GPIO platform data support
Define a platform data structure for the MPC85XX GPIO driver to allow use of the driver without device tree. Users should define the GPIO blocks for their platform like this: struct mpc85xx_gpio_plat gpio_blocks[] = { { .addr = 0x130000, .ngpios = 32, }, { .addr = 0x131000, .ngpios = 32, }, }; U_BOOT_DEVICES(my_platform_gpios) = { { "gpio_mpc85xx", &gpio_blocks[0] }, { "gpio_mpc85xx", &gpio_blocks[1] }, }; This is intended to build upon the recent submission of the base MPC85XX driver from Mario Six. We need to use that new driver without dts support and this patch gives us that flexibility. This has been tested on a Freescale T2080 CPU, although only the first GPIO block. Signed-off-by: Hamish Martin <hamish.martin@alliedtelesis.co.nz> Reviewed-by: Mario Six <mario.six@gdsys.cc> Tested-by: Mario Six <mario.six@gdsys.cc> Acked-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
797d1b9de1
commit
4b689f02ff
@ -18,4 +18,10 @@
|
|||||||
#include <asm/mpc85xx_gpio.h>
|
#include <asm/mpc85xx_gpio.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
struct mpc85xx_gpio_plat {
|
||||||
|
ulong addr;
|
||||||
|
unsigned long size;
|
||||||
|
uint ngpios;
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -163,23 +163,41 @@ static int mpc85xx_gpio_get_function(struct udevice *dev, unsigned gpio)
|
|||||||
return dir ? GPIOF_OUTPUT : GPIOF_INPUT;
|
return dir ? GPIOF_OUTPUT : GPIOF_INPUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if CONFIG_IS_ENABLED(OF_CONTROL)
|
||||||
static int mpc85xx_gpio_ofdata_to_platdata(struct udevice *dev) {
|
static int mpc85xx_gpio_ofdata_to_platdata(struct udevice *dev) {
|
||||||
struct mpc85xx_gpio_data *data = dev_get_priv(dev);
|
struct mpc85xx_gpio_plat *plat = dev_get_platdata(dev);
|
||||||
fdt_addr_t addr;
|
fdt_addr_t addr;
|
||||||
fdt_size_t size;
|
fdt_size_t size;
|
||||||
|
|
||||||
addr = fdtdec_get_addr_size_auto_noparent(gd->fdt_blob, dev->of_offset,
|
addr = fdtdec_get_addr_size_auto_noparent(gd->fdt_blob, dev->of_offset,
|
||||||
"reg", 0, &size);
|
"reg", 0, &size);
|
||||||
|
|
||||||
data->addr = addr;
|
plat->addr = addr;
|
||||||
data->base = map_sysmem(CONFIG_SYS_IMMR + addr, size);
|
plat->size = size;
|
||||||
|
plat->ngpios = fdtdec_get_int(gd->fdt_blob, dev->of_offset,
|
||||||
|
"ngpios", 32);
|
||||||
|
|
||||||
if (!data->base)
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static int mpc85xx_gpio_platdata_to_priv(struct udevice *dev)
|
||||||
|
{
|
||||||
|
struct mpc85xx_gpio_data *priv = dev_get_priv(dev);
|
||||||
|
struct mpc85xx_gpio_plat *plat = dev_get_platdata(dev);
|
||||||
|
unsigned long size = plat->size;
|
||||||
|
|
||||||
|
if (size == 0)
|
||||||
|
size = 0x100;
|
||||||
|
|
||||||
|
priv->addr = plat->addr;
|
||||||
|
priv->base = map_sysmem(CONFIG_SYS_IMMR + plat->addr, size);
|
||||||
|
|
||||||
|
if (!priv->base)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
data->gpio_count = fdtdec_get_int(gd->fdt_blob, dev->of_offset,
|
priv->gpio_count = plat->ngpios;
|
||||||
"ngpios", 32);
|
priv->dat_shadow = 0;
|
||||||
data->dat_shadow = 0;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -190,6 +208,8 @@ static int mpc85xx_gpio_probe(struct udevice *dev)
|
|||||||
struct mpc85xx_gpio_data *data = dev_get_priv(dev);
|
struct mpc85xx_gpio_data *data = dev_get_priv(dev);
|
||||||
char name[32], *str;
|
char name[32], *str;
|
||||||
|
|
||||||
|
mpc85xx_gpio_platdata_to_priv(dev);
|
||||||
|
|
||||||
snprintf(name, sizeof(name), "MPC@%lx_", data->addr);
|
snprintf(name, sizeof(name), "MPC@%lx_", data->addr);
|
||||||
str = strdup(name);
|
str = strdup(name);
|
||||||
|
|
||||||
@ -221,8 +241,11 @@ U_BOOT_DRIVER(gpio_mpc85xx) = {
|
|||||||
.name = "gpio_mpc85xx",
|
.name = "gpio_mpc85xx",
|
||||||
.id = UCLASS_GPIO,
|
.id = UCLASS_GPIO,
|
||||||
.ops = &gpio_mpc85xx_ops,
|
.ops = &gpio_mpc85xx_ops,
|
||||||
|
#if CONFIG_IS_ENABLED(OF_CONTROL)
|
||||||
.ofdata_to_platdata = mpc85xx_gpio_ofdata_to_platdata,
|
.ofdata_to_platdata = mpc85xx_gpio_ofdata_to_platdata,
|
||||||
|
.platdata_auto_alloc_size = sizeof(struct mpc85xx_gpio_plat),
|
||||||
.of_match = mpc85xx_gpio_ids,
|
.of_match = mpc85xx_gpio_ids,
|
||||||
|
#endif
|
||||||
.probe = mpc85xx_gpio_probe,
|
.probe = mpc85xx_gpio_probe,
|
||||||
.priv_auto_alloc_size = sizeof(struct mpc85xx_gpio_data),
|
.priv_auto_alloc_size = sizeof(struct mpc85xx_gpio_data),
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user