Re: [PATCH 1/2] ARM: memory: da8xx-ddrctl: new driver

From: Kevin Hilman
Date: Thu Oct 27 2016 - 12:56:04 EST


Bartosz Golaszewski <bgolaszewski@xxxxxxxxxxxx> writes:

> Create a new driver for the da8xx DDR2/mDDR controller and implement
> support for writing to the Peripheral Bus Burst Priority Register.
>
> Signed-off-by: Bartosz Golaszewski <bgolaszewski@xxxxxxxxxxxx>

[...]

> + for (; setting->name; setting++) {
> + knob = da8xx_ddrctl_match_knob(setting);
> + if (!knob) {
> + dev_warn(dev,
> + "no such config option: %s\n", setting->name);
> + continue;
> + }
> +
> + if (knob->reg > (res->end - res->start - sizeof(u32))) {

Why the "- sizeof(u32)"? Shouldn't this just be resource_size(res)?
(c.f. linux/ioport.h)

> + dev_warn(dev,
> + "register offset of '%s' exceeds mapped memory size\n",
> + knob->name);
> + continue;
> + }
> +
> + reg = __raw_readl(ddrctl + knob->reg);
> + reg &= knob->mask;
> + reg |= setting->val << knob->shift;
> +
> + dev_dbg(dev, "writing 0x%08x to %s\n", reg, setting->name);
> +
> + __raw_writel(reg, ddrctl + knob->reg);

Can you use the normal readl/writel here? Or explain why the raw ones
are needed?

> + }
> +
> + return 0;
> +}
> +

Otherwise, looks good to me. With the changes above, feel free to add

Reviewed-by: Kevin Hilman <khilman@xxxxxxxxxxxx>

Kevin