This series adds support for the Mali-450 MP2 GPU in the RK3528 SoC. The clock used for the GPU can use normal PLL to support a rate of 100, 300 or 500 MHz. Or it can use PVTPLL to reach rates up to 800 MHz.
The TF-A SCMI_CLK_GPU is used to switch use between normal PLL and PVTPLL. When a rate of up to 300 MHz is requested TF-A switch to use normal PLL, and for rates above 300 MHz the PVTPLL is used. The PVTPLL can only operate when the power domain, regulators and clocks are enabled, an opp-suspend for 300 MHz is used to ensure normal PLL is selected before GPU is PM runtime suspended. Driver init at boot: lima ff700000.gpu: gp - mali450 version major 0 minor 0 lima ff700000.gpu: pp0 - mali450 version major 0 minor 0 lima ff700000.gpu: pp1 - mali450 version major 0 minor 0 lima ff700000.gpu: l2_cache0 8K, 4-way, 64byte cache line, 128bit external bus lima ff700000.gpu: l2_cache1 64K, 4-way, 64byte cache line, 128bit external bus lima ff700000.gpu: bus rate = 297000000 lima ff700000.gpu: mod rate = 300000000 [drm] Initialized lima 1.1.0 for ff700000.gpu n minor 0 glmark2-es2-gbm (cebbb63edfba502905470c904f8e6f1c6ce28ba9): ======================================================= glmark2 2023.01 ======================================================= GL_VENDOR: Mesa GL_RENDERER: Mali450 GL_VERSION: OpenGL ES 2.0 Mesa 25.0.4 Surface Config: buf=32 r=8 g=8 b=8 a=8 depth=24 stencil=0 samples=0 Surface Size: 800x600 fullscreen ======================================================= [build] use-vbo=false: FPS: 572 FrameTime: 1.751 ms [build] use-vbo=true: FPS: 715 FrameTime: 1.400 ms [texture] texture-filter=nearest: FPS: 735 FrameTime: 1.361 ms [texture] texture-filter=linear: FPS: 744 FrameTime: 1.346 ms [texture] texture-filter=mipmap: FPS: 758 FrameTime: 1.320 ms [shading] shading=gouraud: FPS: 444 FrameTime: 2.255 ms [shading] shading=blinn-phong-inf: FPS: 442 FrameTime: 2.267 ms [shading] shading=phong: FPS: 314 FrameTime: 3.186 ms [shading] shading=cel: FPS: 258 FrameTime: 3.877 ms [bump] bump-render=high-poly: FPS: 98 FrameTime: 10.279 ms [bump] bump-render=normals: FPS: 694 FrameTime: 1.443 ms [bump] bump-render=height: FPS: 551 FrameTime: 1.818 ms [effect2d] kernel=0,1,0;1,-4,1;0,1,0;: FPS: 161 FrameTime: 6.246 ms [effect2d] kernel=1,1,1,1,1;1,1,1,1,1;1,1,1,1,1;: FPS: 47 FrameTime: 21.692 ms [pulsar] light=false:quads=5:texture=false: FPS: 1031 FrameTime: 0.970 ms [desktop] blur-radius=5:effect=blur:passes=1:separable=true:windows=4: FPS: 78 FrameTime: 12.986 ms [desktop] effect=shadow:windows=4: FPS: 331 FrameTime: 3.023 ms [buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 161 FrameTime: 6.220 ms [buffer] columns=200:interleave=false:update-dispersion=0.9:update-fraction=0.5:update-method=subdata: FPS: 160 FrameTime: 6.285 ms [buffer] columns=200:interleave=true:update-dispersion=0.9:update-fraction=0.5:update-method=map: FPS: 237 FrameTime: 4.231 ms [ideas] speed=duration: FPS: 184 FrameTime: 5.461 ms [jellyfish] <default>: FPS: 200 FrameTime: 5.006 ms Error: SceneTerrain requires Vertex Texture Fetch support, but GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS is 0 [terrain] <default>: Unsupported [shadow] <default>: FPS: 214 FrameTime: 4.691 ms [refract] <default>: FPS: 23 FrameTime: 43.776 ms [conditionals] fragment-steps=0:vertex-steps=0: FPS: 725 FrameTime: 1.380 ms [conditionals] fragment-steps=5:vertex-steps=0: FPS: 356 FrameTime: 2.816 ms [conditionals] fragment-steps=0:vertex-steps=5: FPS: 728 FrameTime: 1.375 ms [function] fragment-complexity=low:fragment-steps=5: FPS: 482 FrameTime: 2.077 ms [function] fragment-complexity=medium:fragment-steps=5: FPS: 233 FrameTime: 4.298 ms [loop] fragment-loop=false:fragment-steps=5:vertex-steps=5: FPS: 482 FrameTime: 2.079 ms [loop] fragment-steps=5:fragment-uniform=false:vertex-steps=5: FPS: 482 FrameTime: 2.076 ms [loop] fragment-steps=5:fragment-uniform=true:vertex-steps=5: FPS: 165 FrameTime: 6.076 ms ======================================================= glmark2 Score: 399 ====================================================== Trying to use a GPU clock rate above 300 MHz when the GPU is PM runtime suspended may cause the system to freeze or an SError. E.g. trying to use a different devfreq governor or set min_freq above 300 MHz. Similar issues also exist on RK3576 and RK3588 when SCMI_CLK_GPU is used for devfreq, a separate series will be sent to mitigate these issues. This series depends on patch 1-4 of the series "rockchip: Add power controller support for RK3528" [1]. [1] https://lore.kernel.org/r/20250518220707.669515-1-jo...@kwiboo.se Jonas Karlman (3): dt-bindings: gpu: mali-utgard: Add Rockchip RK3528 compatible arm64: dts: rockchip: Add GPU node for RK3528 arm64: dts: rockchip: Enable GPU on Radxa E20C .../bindings/gpu/arm,mali-utgard.yaml | 2 + .../boot/dts/rockchip/rk3528-radxa-e20c.dts | 5 ++ arch/arm64/boot/dts/rockchip/rk3528.dtsi | 58 +++++++++++++++++++ 3 files changed, 65 insertions(+) -- 2.49.0