Hi rob, ? 2017/9/22 3:40, Rob Herring ??: > On Tue, Sep 19, 2017 at 9:57 PM, Sandy Huang <hjc at rock-chips.com> wrote: >> >> >> ? 2017/9/20 9:51, Sandy Huang ??: >>> >>> Hi rob, >>> thanks for you review. >>> >>> ? 2017/9/19 22:46, Rob Herring ??: >>>> >>>> On Thu, Sep 14, 2017 at 11:43:18AM +0800, Sandy Huang wrote: >>>>> >>>>> This path add support rv1108 rgb output interface driver. >>>>> >>>>> Signed-off-by: Sandy Huang <hjc at rock-chips.com> >>>>> --- >>>>> .../bindings/display/rockchip/rockchip-rgb.txt | 80 >>>>> ++++++++++++++++++++++ >>>>> 1 file changed, 80 insertions(+) >>>>> create mode 100644 >>>>> Documentation/devicetree/bindings/display/rockchip/rockchip-rgb.txt >>>>> >>>>> diff --git >>>>> a/Documentation/devicetree/bindings/display/rockchip/rockchip-rgb.txt >>>>> b/Documentation/devicetree/bindings/display/rockchip/rockchip-rgb.txt >>>>> new file mode 100644 >>>>> index 0000000..4164512 >>>>> --- /dev/null >>>>> +++ >>>>> b/Documentation/devicetree/bindings/display/rockchip/rockchip-rgb.txt >>>>> @@ -0,0 +1,80 @@ >>>>> +Rockchip RV1108 RGB interface >>>>> +================================ >>>>> + >>>>> +Required properties: >>>>> +- compatible: matching the soc type: >>>>> + - "rockchip,rv1108-rgb"; >>>>> + >>>>> +Optional properties: >>>>> +- pinctrl-names: must contain a "lcdc" entry. >>>>> +- pinctrl-0: pin control group to be used for this interface. >>>>> + >>>>> +Required nodes: >>>>> +- rockchip,rgb-mode: should be "p888", "p666", "p565", "s888", >>>>> "s888-dummy" >>>> >>>> >>>> This should be a standard property. Any device with a parallel interface >>>> is going to need something like this. >>>> >>> so, i need to move this property to panel? or just rename >>> rockchip,rgb-mode to rgb-mode? >>> >>>>> + - p888: output r8-g8-b8 at each dclk cycle for per-pixel >>>>> + - p666: output r6-g6-b6 at each dclk cycle for per-pixel >>>>> + - p565: output r5-g6-b5 at each dclk cycle for per-pixel >>>>> + - s888: output r8-g8-b8 in three dclk cycle for per-pixel >>>>> + - s888-dmmy: output r8-g8-b8-dummy in four dclk cycle for per-pixel >>>>> + >>>>> +The rgb has two video ports described by: >>>>> + Documentation/devicetree/bindings/media/video-interfaces.txt >>>>> +Their connections are modeled using the OF graph bindings specified in >>>>> + Documentation/devicetree/bindings/graph.txt. >>>>> + >>>>> +- video port 0 for the VOP input, the remote endpoint maybe >>>>> vopb/vopl/vop >>>>> +- video port 1 for either a panel or subsequent encoder >>>>> + >>>>> +the panel described by: >>>>> + Documentation/devicetree/bindings/display/panel/simple-panel.txt >>>>> +Panel other required properties: >>>>> +- ports for remote rgb output. >>>>> + >>>>> +Example: >>>>> + >>>>> +panel: panel { >>>>> + compatible = "auo,b101ean01"; >>>>> + enable-gpios = <&gpio7 21 GPIO_ACTIVE_HIGH>; >>>>> + >>>>> + ports { >>>>> + panel_in_rgb: endpoint { >>>>> + remote-endpoint = <&rgb_out_panel>; >>>>> + }; >>>>> + }; >>>>> +}; >>>>> + >>>>> +For Rockchip RV1108: >>>>> + >>>>> + rgb: rgb { >>>>> + compatible = "rockchip,rv1108-rgb"; >>>>> + pinctrl-names = "lcdc"; >>>>> + pinctrl-0 = <&lcdc_ctl>; >>>>> + rockchip,rgb-mode = "p888"; >>>>> + >>>>> + ports { >>>>> + #address-cells = <1>; >>>>> + #size-cells = <0>; >>>>> + >>>>> + rgb_in: port at 0 { >>>>> + reg = <0>; >>>>> + #address-cells = <1>; >>>>> + #size-cells = <0>; >>>>> + >>>>> + rgb_in_vop: endpoint at 0 { >>>>> + reg = <0>; >>>> >>>> >>>> Don't need reg for a single endpoint. >>>> >>> ok, this will be deleted at next version. >>>>> >>>>> + remote-endpoint = <&vop_out_rgb>; >>>>> + }; >>>>> + }; >>>>> + >>>>> + rgb_out: port at 1 { >>>>> + reg = <1>; >>>>> + #address-cells = <1>; >>>>> + #size-cells = <0>; >>>>> + >>>>> + rgb_out_panel: endpoint at 0 { >>>>> + reg = <0>; >>>> >>>> >>>> ditto. >>>> >>> ok, this will be deleted at next version. >> >> sorry,this can't be deleted, because rgb output remote endpoint maybe panel >> or convert chip, the dts node maybe like this: >> >> panel: panel { >> status = "disabled"; >> ports { >> panel_in_rgb: endpoint { >> remote-endpoint = <&rgb_out_panel>; >> }; >> }; >> }; >> >> bridge: bridge { >> status = "okay"; >> ports { >> bridge_in_rgb: endpoint { >> remote-endpoint = <&rgb_out_bridge>; >> }; >> }; >> }; >> >> rgb_out: port at 1 { >> reg = <1>; >> #address-cells = <1>; >> #size-cells = <0>; >> rgb_out_panel: endpoint at 0 { >> reg = <0>; >> remote-endpoint = <&panel_in_rgb>; >> }; >> rgb_out_bridge: endpoint at 1 { >> reg = <1>; >> remote-endpoint = <&bridge_in_rgb>; >> }; >> }; >> >> so rockchip_rgb_bind() @ rockchip_rgb.c use reg id to find the remote >> actived endpoint. >> >> for_each_child_of_node(port, endpoint) { >> of_property_read_u32(endpoint, "reg", &endpoint_id); > > Lack of reg property here should imply 0 for endpoint_id. > ok, i will delete this reg id and set the endpoint_id default value to 0 when lack of reg property at next version, thanks. >> ret = drm_of_find_panel_or_bridge(dev->of_node, 1, endpoint_id, >> &rgb->panel, &rgb->bridge); >> if (!ret) >> break; >> } >> >>>>> + remote-endpoint = <&panel_in_rgb>; >>>>> + }; >>>>> + }; >>>>> + }; >>>>> + }; >>>>> -- >>>>> 2.7.4 >>>>> >>>>> >>>> >>>> >>>> >>> >>> >>> _______________________________________________ >>> Linux-rockchip mailing list >>> Linux-rockchip at lists.infradead.org >>> http://lists.infradead.org/mailman/listinfo/linux-rockchip >> >> > > >