[RFC] Device Tree Overlays Proposal (Was Re: capebus moving omap_devices to mach-omap2)
Pantelis Antoniou
panto at antoniou-consulting.com
Wed Nov 7 06:41:00 EST 2012
Hi Russ,
On Nov 6, 2012, at 8:29 PM, Russ Dill wrote:
> On Tue, Nov 6, 2012 at 10:35 AM, Tony Lindgren <tony at atomide.com> wrote:
>> * Grant Likely <grant.likely at secretlab.ca> [121106 03:16]:
>>> On Tue, Nov 6, 2012 at 10:30 AM, Pantelis Antoniou
>>> <panto at antoniou-consulting.com> wrote:
>>>>
>>>> Another can of worms is the pinctrl nodes.
>>>
>>> Yes... new pinctrl data would need to trigger adding new data to
>>> pinctrl. I don't know if the pinctrl api supports that.
>>
>> The actual pins stay the same, just their configuration
>> changes. AFAIK all that is already supported using the
>> pinctrl framework.
>>
>> For example, considering hotplugging capes on the beaglebone:
>>
>> 1. You need to map all the sensible modes for the pins exposed
>> to the capes in the board specific .dts file. This will
>> add roughly 4 x nr_capbus_pins named modes in the .dts file
>> so not too bad.
>>
>> 2. Claim all the capebus pins during the capbus driver probe
>> and set them to some safe mode.
>>
>> 3. Try to detect the connected cape(s) over i2c.
>>
>> 4. Use pinctr_select_state to set the desired modes for
>> the pins used by the cape(s).
>>
>> 5. Enable capebus regulators and clocks etc.
>>
>> 6. Load the driver modules for whatever omap internal
>> devices the cape supports.
>>
>> You could also claim the pin for the omap internal
>> devices instead of claiming them in the capebus, but then
>> things can get messy with binding and unbinding the
>> drivers. So just claiming all the pins in the capebus
>> probably keeps things simpler.
>
> That assumes that for a particular external bus, certain pins aren't
> already shared with functions already on the board, for instance if an
> I²C bus brought out to the external bus already has a chip connected
> to it.
This is our case on the bone. We don't enable the peripheral until
a cape that references it is enabled.
I don't think that very big changes are going to be needed TBH.
So now we use:
am3358_pinmux: pinmux at 44e10800 {
....
bone_dvi_cape_led_pins: pinmux_bone_dvi_cape_led_pins {
pinctrl-single,pins = <
0x48 0x07 /* gpmc_a2.gpio1_18, OUTPUT | MODE7 */
0x4c 0x07 /* gpmc_a3.gpio1_19, OUTPUT | MODE7 */
>;
};
....
};
And in the cape definition:
pinctrl-0 = <&bone_geiger_cape_pins>;
Ideally if we could do this in the cape definition:
cape_pinmux {
parent = <&am3358_pinmux>;
bone_dvi_cape_led_pins: pinmux_bone_dvi_cape_led_pins {
pinctrl-single,pins = <
0x48 0x07 /* gpmc_a2.gpio1_18, OUTPUT | MODE7 */
0x4c 0x07 /* gpmc_a3.gpio1_19, OUTPUT | MODE7 */
>;
};
pinctrl-0 = <&bone_geiger_cape_pins>;
It would be just fine.
Regards
-- Pantelis
More information about the devicetree-discuss
mailing list