[PATCH 0/3] rockchip: Add GPU support for RK3528
Jonas Karlman
jonas at kwiboo.se
Sun May 18 22:54:10 UTC 2025
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-jonas@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
More information about the dri-devel
mailing list