Re: [RFC][PATCH V2 3/3] tegra: add pwm backlight device tree nodes
From: Alex Courbot
Date: Thu Jul 12 2012 - 06:09:37 EST
Hi Simon,
On Thu 12 Jul 2012 06:37:33 PM JST, Simon Glass wrote:
I would like to do something similar in U-Boot for Tegra, although
perhaps not right away. For now I will go with something considerably
simpler! But if this is merged into the kernel we will move to it in
U-Boot.
Cool, I'd love to see that used in U-Boot as well.
+ default-brightness-level = <12>;
+
+ pwms = <&pwm 2 5000000>;
+ pwm-names = "backlight";
+ power-supply = <&backlight_reg>;
+ enable-gpios = <&gpio 28 0>;
+
+ power-on-sequence = "REGULATOR", "power", <1>,
+ "DELAY", <10>,
+ "PWM", "backlight", <1>,
+ "GPIO", "enable", <1>;
So the names REGULATOR, DELAY, etc. here are looked up through some
existing mechanism? In general I am not a big fan of mixing strings
and numbers in a property.
Yes, these are strings we are looking up to know the type of the next
element to power on/off in the sequence. I don't like these, honestly,
and would rather have them replaced by constants - however there is no
way to define constants in the DT AFAIK (but I have heard some other
persons are interested in having them too), and this is the only way I
have found to keep the sequence readable.
Maybe something like:
power_on_sequence {
step@0 {
phandle = <&backlight_reg>;
enable = <1>;
post-delay = <10>;
}
step@1 {
phandle = <&pwm 2 5000000>;
}
step@2 {
phandle = <&gpio 28 0>;
enable = <1>;
}
I see a few problems with this: first, how do you know the types of your
phandles? At step 0, we should get a regulator, step 1 is a PWM and step
2 is a GPIO. This is why I have used strings to identify the type of the
phandle and the number (and type) of additional arguments to parse for a
step.
Second, I am afraid the representation in memory would be significantly
bigger since the properties names would have to be stored as well (I am
no DT expert, please correct me if I am wrong). Lastly, the additional
freedom of having extra properties might make the parser more complicated.
I agree the type strings are a problem in the current form - if we could
get constants in the device tree, that would be much better. Your way of
representing the sequences is interesting though, if we can solve the
type issue (and also evaluate its cost in terms of memory footprint), it
would be interesting to consider it as well.
Alex.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/