[PATCH RFC 04/18] rockchip: rk3568: syscon: Add MSCH, SGRF and DDRGRF support
Jonas Karlman
jonas at kwiboo.se
Sun May 17 22:42:59 CEST 2026
Hi Pavel,
On 5/17/2026 9:24 PM, Pavel Golikov wrote:
> Add support for the MSCH, SGRF and DDRGRF register regions in syscon,
> which are necessary for RK3568's DRAM controller initialization.
>
> Signed-off-by: Pavel Golikov <paullo612 at ya.ru>
> ---
> arch/arm/include/asm/arch-rockchip/clock.h | 1 +
> arch/arm/mach-rockchip/rk3568/syscon_rk3568.c | 26 +++++++++++++++++++++++++-
> 2 files changed, 26 insertions(+), 1 deletion(-)
>
> diff --git a/arch/arm/include/asm/arch-rockchip/clock.h b/arch/arm/include/asm/arch-rockchip/clock.h
> index 95b08bfd046..a6b399da4ff 100644
> --- a/arch/arm/include/asm/arch-rockchip/clock.h
> +++ b/arch/arm/include/asm/arch-rockchip/clock.h
> @@ -39,6 +39,7 @@ enum {
> ROCKCHIP_SYSCON_PIPE_PHY2_GRF,
> ROCKCHIP_SYSCON_VOP_GRF,
> ROCKCHIP_SYSCON_VO_GRF,
> + ROCKCHIP_SYSCON_DDRGRF,
> };
>
> /* Standard Rockchip clock numbers */
> diff --git a/arch/arm/mach-rockchip/rk3568/syscon_rk3568.c b/arch/arm/mach-rockchip/rk3568/syscon_rk3568.c
> index b9d59a4721e..7f6caf9ca67 100644
> --- a/arch/arm/mach-rockchip/rk3568/syscon_rk3568.c
> +++ b/arch/arm/mach-rockchip/rk3568/syscon_rk3568.c
> @@ -8,8 +8,11 @@
> #include <asm/arch-rockchip/clock.h>
>
> static const struct udevice_id rk3568_syscon_ids[] = {
> - { .compatible = "rockchip,rk3568-grf", .data = ROCKCHIP_SYSCON_GRF },
> + { .compatible = "rockchip,rk3568-grf", .data = ROCKCHIP_SYSCON_GRF },
> { .compatible = "rockchip,rk3568-pmugrf", .data = ROCKCHIP_SYSCON_PMUGRF },
> + { .compatible = "rockchip,rk3568-msch", .data = ROCKCHIP_SYSCON_MSCH },
> + { .compatible = "rockchip,rk3568-sgrf", .data = ROCKCHIP_SYSCON_SGRF },
> + { .compatible = "rockchip,rk3568-ddrgrf", .data = ROCKCHIP_SYSCON_DDRGRF },
Please do not add more mappings, all ROCKCHIP_SYSCON usage should
instead be removed. See [1] and [2] for some uncompleted work.
Please define constants instead of trying to do dynamic lookup. Drivers
that typically need to know these reg addresses are already specific for
a single SoC or needs to be known at compile-time to save space.
No need to waste cpu cycles at runtime trying to resolve them :-)
[1] https://source.denx.de/u-boot/contributors/kwiboo/u-boot/-/commits/optimize
[2] https://source.denx.de/u-boot/contributors/kwiboo/u-boot/-/commit/d1601adc6b0bb092b66863e0c515dda5746c6f6f
Regards,
Jonas
> { }
> };
>
> @@ -37,4 +40,25 @@ U_BOOT_DRIVER(rockchip_rk3568_pmugrf) = {
> .of_match = rk3568_syscon_ids + 1,
> .bind = rk3568_syscon_bind_of_plat,
> };
> +
> +U_BOOT_DRIVER(rockchip_rk3568_msch) = {
> + .name = "rockchip_rk3568_msch",
> + .id = UCLASS_SYSCON,
> + .of_match = rk3568_syscon_ids + 2,
> + .bind = rk3568_syscon_bind_of_plat,
> +};
> +
> +U_BOOT_DRIVER(rockchip_rk3568_sgrf) = {
> + .name = "rockchip_rk3568_sgrf",
> + .id = UCLASS_SYSCON,
> + .of_match = rk3568_syscon_ids + 3,
> + .bind = rk3568_syscon_bind_of_plat,
> +};
> +
> +U_BOOT_DRIVER(rockchip_rk3568_ddrgrf) = {
> + .name = "rockchip_rk3568_ddrgrf",
> + .id = UCLASS_SYSCON,
> + .of_match = rk3568_syscon_ids + 4,
> + .bind = rk3568_syscon_bind_of_plat,
> +};
> #endif
>
More information about the U-Boot
mailing list