On 03/08/2016 01:24 AM, Linus Walleij wrote:
On Sat, Feb 27, 2016 at 1:19 AM, Eric Anholt <eric@xxxxxxxxxx> wrote:
Since all of these pins were documented, we can use their names to
explain what's going on.
Signed-off-by: Eric Anholt <eric@xxxxxxxxxx>
+ pinctrl-0 = <&i2c0_gpio0
+ &i2c1_gpio2
+ &gpclk0_gpio4
+ &gpclk1_gpio5
+ &spi0_gpio7
+ &pcm_gpio18
+ &pwm0_gpio40
+ &pwm1_gpio45
+ &gpioout
+ &alt3>;
Why are all of these done as hogs instead of being in pinctrl-0
"default" for the device that is using them? i2c1, gpclk0,
etc?
The only reason I see would be if they are unused or something.
I think it makes sense to have the pinctrl driver (or even FW before the
kernel boots) set up everything at once where possible. That's the
easiest way to ensure there are never any conflicts in the pinmux table
(i.e. that two different pins don't end up being both muxed to SPI1's
MISO signal at the same time for a while before all the drivers probe).
Putting pinctrl entries into individual devices only makes sense to me
when one of:
a) That device needs to dynamically change the pinmux at run-time, e.g.
to switch between different states, so needs definitions of those
different states.
or:
b) The initial pinmux is guaranteed set up to a safe non-conflicting
state that enables very little, and we need to defer enabling various
peripherals until a later time when we know the peripheral is in use,
e.g. when loading a DT overlay from user-space.
On the RPi there are certain peripherals that fall into each category,
e.g. SD card is always used, I2S only optionally used.
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html