mirror of https://gitee.com/openkylin/linux.git
media: staging: rkisp1: remove unecessary clocks
aclk_isp_wrap is a child of aclk_isp, and hclk_isp_wrap is a child of hclk_isp, thus we can remove parents from the list. Also, for the isp0, we only need the ISP clock, ACLK and HCLK. In the future we'll need a pixel clock for RK3288 and RK3399, and a JPEG clock for RK3288. So with the goal to cleanup the dt-bindings and remove it from staging, simplify clock names to isp, aclk and hclk. Assigned clocks are meant to refer to the full path in the clock tree, i.e. the leaf in the tree. For instance, in RK3399, the clock responsible for ACLK (ISP AXI CLOCK) is aclk_isp0_wrapper. For reference, this is the isp clock topology on RK3399: xin24m pll_npll npll clk_isp1 clk_isp0 pll_cpll cpll aclk_isp1 aclk_isp1_noc hclk_isp1 aclk_isp1_wrapper hclk_isp1_noc aclk_isp0 hclk_isp1_wrapper aclk_isp0_wrapper aclk_isp0_noc hclk_isp0 hclk_isp0_wrapper hclk_isp0_noc pclkin_isp1_wrapper Signed-off-by: Helen Koike <helen.koike@collabora.com> Reviewed-by: Tomasz Figa <tfiga@chromium.org> Reviewed-by: Rob Herring <robh@kernel.org> Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
This commit is contained in:
parent
4b69709aa0
commit
099d801bcd
|
@ -24,20 +24,24 @@ properties:
|
|||
maxItems: 1
|
||||
|
||||
clocks:
|
||||
minItems: 3
|
||||
items:
|
||||
# isp0 and isp1
|
||||
- description: ISP clock
|
||||
- description: ISP AXI clock clock
|
||||
- description: ISP AXI clock wrapper clock
|
||||
- description: ISP AHB clock clock
|
||||
- description: ISP AHB wrapper clock
|
||||
- description: ISP AXI clock
|
||||
- description: ISP AHB clock
|
||||
# only for isp1
|
||||
- description: ISP Pixel clock
|
||||
|
||||
clock-names:
|
||||
minItems: 3
|
||||
items:
|
||||
- const: clk_isp
|
||||
- const: aclk_isp
|
||||
- const: aclk_isp_wrap
|
||||
- const: hclk_isp
|
||||
- const: hclk_isp_wrap
|
||||
# isp0 and isp1
|
||||
- const: isp
|
||||
- const: aclk
|
||||
- const: hclk
|
||||
# only for isp1
|
||||
- const: pclk_isp
|
||||
|
||||
iommus:
|
||||
maxItems: 1
|
||||
|
@ -116,6 +120,20 @@ required:
|
|||
- power-domains
|
||||
- ports
|
||||
|
||||
if:
|
||||
properties:
|
||||
compatible:
|
||||
contains:
|
||||
const: rockchip,rk3399-cif-isp
|
||||
then:
|
||||
properties:
|
||||
clocks:
|
||||
minItems: 3
|
||||
maxItems: 4
|
||||
clock-names:
|
||||
minItems: 3
|
||||
maxItems: 4
|
||||
|
||||
additionalProperties: false
|
||||
|
||||
examples:
|
||||
|
@ -134,11 +152,9 @@ examples:
|
|||
reg = <0x0 0xff910000 0x0 0x4000>;
|
||||
interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH 0>;
|
||||
clocks = <&cru SCLK_ISP0>,
|
||||
<&cru ACLK_ISP0>, <&cru ACLK_ISP0_WRAPPER>,
|
||||
<&cru HCLK_ISP0>, <&cru HCLK_ISP0_WRAPPER>;
|
||||
clock-names = "clk_isp",
|
||||
"aclk_isp", "aclk_isp_wrap",
|
||||
"hclk_isp", "hclk_isp_wrap";
|
||||
<&cru ACLK_ISP0_WRAPPER>,
|
||||
<&cru HCLK_ISP0_WRAPPER>;
|
||||
clock-names = "isp", "aclk", "hclk";
|
||||
iommus = <&isp0_mmu>;
|
||||
phys = <&dphy>;
|
||||
phy-names = "dphy";
|
||||
|
|
|
@ -405,11 +405,9 @@ static irqreturn_t rkisp1_isr(int irq, void *ctx)
|
|||
}
|
||||
|
||||
static const char * const rk3399_isp_clks[] = {
|
||||
"clk_isp",
|
||||
"aclk_isp",
|
||||
"hclk_isp",
|
||||
"aclk_isp_wrap",
|
||||
"hclk_isp_wrap",
|
||||
"isp",
|
||||
"aclk",
|
||||
"hclk",
|
||||
};
|
||||
|
||||
static const struct rkisp1_match_data rk3399_isp_clk_data = {
|
||||
|
|
Loading…
Reference in New Issue