[PATCH 2/2 v7] pinmux: add a driver for the U300 pinmux
Stephen Warren
swarren at nvidia.com
Wed Sep 21 15:39:46 EDT 2011
Linus Walleij wrote at Wednesday, September 21, 2011 2:25 AM:
> On Wed, Sep 21, 2011 at 12:15 AM, Stephen Warren <swarren at nvidia.com> wrote:
> > Linus Walleij wrote at Friday, September 16, 2011 6:14 AM:
> >> + for (i = 0; i < ARRAY_SIZE(u300_mux_hogs); i++) {
> >> + struct pinmux *pmx;
> >> + int ret;
> >> +
> >> + pmx = pinmux_get(u300_mux_hogs[i].dev, NULL);
> >> + if (IS_ERR(pmx)) {
> >> + pr_err("u300: could not get pinmux hog %s\n",
> >> + u300_mux_hogs[i].name);
> >> + continue;
> >> + }
> >> + ret = pinmux_enable(pmx);
> >> + if (ret) {
> >> + pr_err("u300: could enable pinmux hog %s\n",
> >> + u300_mux_hogs[i].name);
> >> + continue;
> >> + }
> >> + u300_mux_hogs[i].pmx = pmx;
> >> + }
> >> + return 0;
> >> +}
> >> +subsys_initcall(u300_pinmux_fetch);
> >
> > Why not just have the pinmux core support hogging on non-"system" mapping
> > entries; then everything I quoted above except u300_pinmux_map[] could
> > be deleted, and the "hog" flag set on the last 3 u300_pinmux_map[] entries.
>
> Very good question, luckily I have a good answer.
>
> There is no way for the pinmux core to traverse the system and look
> up the apropriate struct device * pointers.
It's unclear to me why that would be needed.
For non-system mappings, either the device-driver in question will be
get'ing and enabling them (this case isn't relevant to this discussion),
or they'll be hogged. In the hog case, I doubt anything would ever want
to disable them and switch the device to a different mapping entry; if
that were the case, the entries shouldn't be hogged, but get/enabled by
the device anyway. Hence, I don't see the need for an activation of a
hog'd non-system mapping entry to care about the device fields that are
in the mapping table at all; they could just be ignored couldn't they?
> When/if we have device tree support, I think this will be possible, then I
> will be able to have the pinmux hog look up devices from device tree
> and hog their pinmux.
>
> At that point we'll likely have the mapping in the device tree too and
> the core does not need to be involved at all.
>
> What I could do right now is add some open-ended function like
> pinmux_hog_device_pinmuxes(struct device **devices);
> that can take an array of devices and hog their respective
> pinmuxes in the hog list. Do you think it's a good idea?
--
nvpublic
More information about the linux-arm-kernel
mailing list