[PATCH 04/11] pinctrl: single: get register area size by device API
Simon Glass
sjg at chromium.org
Sun Jan 24 03:03:35 CET 2021
Hi Dario,
On Sat, 23 Jan 2021 at 11:27, Dario Binacchi <dariobin at libero.it> wrote:
>
> Use dev_read_addr_size to get size of the controller's register area.
>
> Signed-off-by: Dario Binacchi <dariobin at libero.it>
> ---
>
> drivers/pinctrl/pinctrl-single.c | 9 +++------
> 1 file changed, 3 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/pinctrl/pinctrl-single.c b/drivers/pinctrl/pinctrl-single.c
> index cec00e289c..c80a42a193 100644
> --- a/drivers/pinctrl/pinctrl-single.c
> +++ b/drivers/pinctrl/pinctrl-single.c
> @@ -182,17 +182,14 @@ static int single_set_state(struct udevice *dev,
> static int single_of_to_plat(struct udevice *dev)
> {
> fdt_addr_t addr;
> - u32 of_reg[2];
> - int res;
> + fdt_size_t size;
> struct single_pdata *pdata = dev_get_plat(dev);
>
> pdata->width =
> dev_read_u32_default(dev, "pinctrl-single,register-width", 0);
>
> - res = dev_read_u32_array(dev, "reg", of_reg, 2);
> - if (res)
> - return res;
> - pdata->offset = of_reg[1] - pdata->width / 8;
> + dev_read_addr_size(dev, "reg", &size);
Please check return value.
> + pdata->offset = size - pdata->width / BITS_PER_BYTE;
>
> addr = dev_read_addr(dev);
> if (addr == FDT_ADDR_T_NONE) {
> --
> 2.17.1
>
Regards,
Simon
More information about the U-Boot
mailing list