[PATCH v2 6/7] arm64: dts: rockchip: add core dtsi for RK3568 SoC
陈亮
cl at rock-chips.com
Wed Apr 28 04:51:55 BST 2021
Hi heiko,
I plan to drop grf stuff in next version, and make a new submit
for grf and document later, thanks.
在 2021/4/27 下午4:07, Heiko Stübner 写道:
> Am Dienstag, 27. April 2021, 09:41:40 CEST schrieb Johan Jonker:
>> On 4/25/21 11:44 AM, cl at rock-chips.com wrote:
>>> From: Liang Chen <cl at rock-chips.com>
>>>
>>> RK3568 is a high-performance and low power quad-core application processor
>>> designed for personal mobile internet device and AIoT equipments. This patch
>>> add basic core dtsi file for it.
>>>
>>> We use scmi_clk for cortex-a55 instead of standard ARMCLK, so that
>>> kernel/uboot/rtos can change cpu clk with the same code in ATF, and we will
>>> enalbe a special high-performacne PLL when high frequency is required. The
>>> smci_clk code is in ATF, and clkid for cpu is 0, as below:
>>>
>>> cpu0: cpu at 0 {
>>> device_type = "cpu";
>>> compatible = "arm,cortex-a55";
>>> reg = <0x0 0x0>;
>>> clocks = <&scmi_clk 0>;
>>> };
>>>
>>> Signed-off-by: Liang Chen <cl at rock-chips.com>
>>> ---
>>> .../boot/dts/rockchip/rk3568-pinctrl.dtsi | 3119 +++++++++++++++++
>>> arch/arm64/boot/dts/rockchip/rk3568.dtsi | 812 +++++
>>> 2 files changed, 3931 insertions(+)
>>> create mode 100644 arch/arm64/boot/dts/rockchip/rk3568-pinctrl.dtsi
>>> create mode 100644 arch/arm64/boot/dts/rockchip/rk3568.dtsi
>>>
>>> diff --git a/arch/arm64/boot/dts/rockchip/rk3568-pinctrl.dtsi b/arch/arm64/boot/dts/rockchip/rk3568-pinctrl.dtsi
>>> new file mode 100644
>>> index 000000000000..94ee3c2c38af
>>> --- /dev/null
>> [..]
>>
>>> diff --git a/arch/arm64/boot/dts/rockchip/rk3568.dtsi b/arch/arm64/boot/dts/rockchip/rk3568.dtsi
>>> new file mode 100644
>>> index 000000000000..66cb50218ca1
>>> --- /dev/null
>>> +++ b/arch/arm64/boot/dts/rockchip/rk3568.dtsi
>>> @@ -0,0 +1,812 @@
>> [..]
>>
>>> +
>>> + pmugrf: syscon at fdc20000 {
>>> + compatible = "rockchip,rk3568-pmugrf", "syscon", "simple-mfd";
>> TODO:
>>
>>> + reg = <0x0 0xfdc20000 0x0 0x10000>;
>>> +
>>> + reboot_mode: reboot-mode {
>>> + compatible = "syscon-reboot-mode";
>>> + mode-bootloader = <BOOT_BL_DOWNLOAD>;
>>> + mode-fastboot = <BOOT_FASTBOOT>;
>>> + mode-loader = <BOOT_BL_DOWNLOAD>;
>>> + mode-normal = <BOOT_NORMAL>;
>>> + mode-recovery = <BOOT_RECOVERY>;
>>> + offset = <0x200>;
>>> + };
>>> + };
>>> +
>>> + grf: syscon at fdc60000 {
>>> + compatible = "rockchip,rk3568-grf", "syscon", "simple-mfd";
>> TODO:
>>
>>> + reg = <0x0 0xfdc60000 0x0 0x10000>;
>>> + };
>>> +
>>> + pmucru: clock-controller at fdd00000 {
>>> + compatible = "rockchip,rk3568-pmucru";
>>> + reg = <0x0 0xfdd00000 0x0 0x1000>;
>>> + rockchip,grf = <&grf>;
>>> + rockchip,pmugrf = <&pmugrf>;
>> clock-controller at fdd00000: 'rockchip,grf', 'rockchip,pmugrf' do not
>> match any of the regexes: 'pinctrl-[0-9]+'
>>
>> Currently clk.c has only support for:
>>
>> ctx->grf = syscon_regmap_lookup_by_phandle(ctx->cru_node,
>> "rockchip,grf");
>>
>> Manufacturer tree:
>>
>> ctx->pmugrf = syscon_regmap_lookup_by_phandle(ctx->cru_node,
>> "rockchip,pmugrf");
>> case branch_muxpmugrf:
>> clk = rockchip_clk_register_muxgrf(list->name,
>> list->parent_names, list->num_parents,
>> flags, ctx->pmugrf, list->muxdiv_offset,
>> list->mux_shift, list->mux_width,
>> list->mux_flags);
>> break;
>>
>>
>> MUXPMUGRF(SCLK_32K_IOE, "clk_32k_ioe", clk_32k_ioe_p, 0,
>> RK3568_PMU_GRF_SOC_CON0, 0, 1, MFLAGS)
> (1) drop the rockchip,pmugrf property please
> (2) as I see it, we will only need the rockchip,grf property.
>
> For main clock controller grf points to main grf
> For pmu clock controller grf points to pmugrf
>
> Each clock controller has its own associated grf.
>
> I really see no case where main-clk would need to access the pmugrf
> same as pmu-clk would should not need to access the main grf, as the
> split into main-{clk,grf} + pmu-{clk,grf} is probably a for power-management
> reasons to separate different power-areas, the driver should also not
> cross this barrier anyway ;-) .
>
> Same as, if a clk uses the pmugrf it is a pmu-based clock, if it uses the
> main grf, it should live in the main clock driver.
>
> And as expected the clk_32k_ioe is already defined in the pmuclk
> part of the driver ;-)
>
>
> Heiko
>
>
>>> + #clock-cells = <1>;
>>> + #reset-cells = <1>;
>>> + };
>>> +
>>> + cru: clock-controller at fdd20000 {
>>> + compatible = "rockchip,rk3568-cru";
>>> + reg = <0x0 0xfdd20000 0x0 0x1000>;
>>> + rockchip,grf = <&grf>;
>> clock-controller at fdd20000: 'assigned-clock-parents',
>> 'assigned-clock-rates', 'assigned-clocks', 'rockchip,grf' do not match
>> any of the regexes:
>>
>> Add more properties to rockchip,rk3568-cru.yaml
>>
>>> + #clock-cells = <1>;
>>> + #reset-cells = <1>;
>>> +
>>> + assigned-clocks =
>>> + <&pmucru CLK_RTC_32K>, <&pmucru PLL_PPLL>,
>>> + <&pmucru PCLK_PMU>, <&cru PLL_CPLL>,
>>> + <&cru PLL_GPLL>, <&cru ACLK_BUS>,
>>> + <&cru PCLK_BUS>, <&cru ACLK_TOP_HIGH>,
>>> + <&cru ACLK_TOP_LOW>, <&cru HCLK_TOP>,
>>> + <&cru PCLK_TOP>, <&cru ACLK_PERIMID>,
>>> + <&cru HCLK_PERIMID>, <&cru PLL_NPLL>,
>>> + <&cru ACLK_PIPE>, <&cru PCLK_PIPE>,
>>> + <&cru ACLK_VOP>;
>>> + assigned-clock-rates =
>>> + <32768>, <200000000>,
>>> + <100000000>, <1000000000>,
>>> + <1188000000>, <150000000>,
>>> + <100000000>, <500000000>,
>>> + <400000000>, <150000000>,
>>> + <100000000>, <300000000>,
>>> + <150000000>, <1200000000>,
>>> + <400000000>, <100000000>,
>>> + <500000000>;
>>> + assigned-clock-parents =
>>> + <&pmucru CLK_RTC32K_FRAC>;
>>> + };
>
>
>
>
>
>
More information about the linux-arm-kernel
mailing list