On Fri, 2014-06-20 at 18:09 +0100, Mark Rutland wrote: > > +- clocks-names: should contain "clcdclk" and "apb_pclk" > > s/clocks-names/clock-names/ Haha - it took quite a few patch revisions to spot this one, thanks! > > + > > +- clocks: contains phandle and clock specifier pairs for the entries > > + in the clock-names property. See > > + Documentation/devicetree/binding/clock/clock-bindings.txt > > + > > +Optional properties: > > + > > +- arm,pl11x,framebuffer-base: a pair of two 32-bit values, address and size, > > + defining the framebuffer that must be used; if not present, the > > + framebuffer may be located anywhere in the memory > > The name is confusing: this is a base _and_ size. True. Can split it into two -base and -size or rename it into framebuffer or video-memory. > When should this be used, and what is valid to point it at? When the hardware design determines the address the memory transactions must be issued at. This is aimed at a situation (allegedly not impossible) when the memory map from the CLCD's point of view is different from the CPU's one (eg. the video memory is mapped at xxx for the CPU and yyy for the CLCD). > How does this play with memory carveouts (CMA, reserved-memory)? It doesn't, and wasn't intended to (the original version of the binding was trying to do something like reserved-memory before it was defined), but someone managed to convince me not to do this, if it's a "low level" feature. I guess I can be re-convinced (again). > > +- max-memory-bandwidth: maximum bandwidth in bytes per second that the > > + cell's memory interface can handle > > When should I set this, given it is optional? When there is a (significant) limitation of the bandwidth available for the cell's memory interface. One will either be told by the soc guys or will figure it out in the hard way, as we did :-( > > + > > +Required sub-nodes: > > + > > +- port: describes LCD panel signals, following the common binding > > + for video transmitter interfaces; see > > + Documentation/devicetree/bindings/media/video-interfaces.txt; > > + when it is a TFT panel, the port's endpoint must define the > > + following property: > > + > > + - arm,pl11x,tft-r0g0b0-pads: an array of three 32-bit values, > > + defining the way CLD pads are wired up; this implicitly > > + defines available color modes, for example: > > + - PL111 TFT 4:4:4 panel: > > + arm,pl11x,tft-r0g0b0-pads = <4 15 20>; > > + - PL110 TFT (1:)5:5:5 panel: > > + arm,pl11x,tft-r0g0b0-pads = <1 7 13>; > > + - PL111 TFT (1:)5:5:5 panel: > > + arm,pl11x,tft-r0g0b0-pads = <3 11 19>; > > + - PL111 TFT 5:6:5 panel: > > + arm,pl11x,tft-r0g0b0-pads = <3 10 19>; > > + - PL110 and PL111 TFT 8:8:8 panel: > > + arm,pl11x,tft-r0g0b0-pads = <0 8 16>; > > + - PL110 and PL111 TFT 8:8:8 panel, R & B components swapped: > > + arm,pl11x,tft-r0g0b0-pads = <16 8 0>; > > I'm somewhat lost trying to figure out this mapping. Am I not looking at > this in the right way, or is there any documentation which makes this > clearer? Yeah, looking at this now, it definitely needs some more explanation. Something like this? First value contains index of the "CLD" external pin (pad) used as R0 (first bit of the red component), second value index of the pad used as G0, third value index of the pad used as B0, see also "LCD panel signal multiplexing details" paragraph in the PL11x Technical Reference Manuals. Pawel -- 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