On Mon, Dec 20, 2021 at 03:16:55PM +0100, Nicolas Frattaroli wrote: > On Montag, 20. Dezember 2021 12:06:30 CET Sascha Hauer wrote: > > From: Andy Yan <andy....@rock-chips.com> > > > > The VOP2 unit is found on Rockchip SoCs beginning with rk3566/rk3568. > > It replaces the VOP unit found in the older Rockchip SoCs. > > > > This driver has been derived from the downstream Rockchip Kernel and > > heavily modified: > > > > - All nonstandard DRM properties have been removed > > - dropped struct vop2_plane_state and pass around less data between > > functions > > - Dropped all DRM_FORMAT_* not known on upstream > > - rework register access to get rid of excessively used macros > > - Drop all waiting for framesyncs > > > > The driver is tested with HDMI and MIPI-DSI display on a RK3568-EVB > > board. Overlay support is tested with the modetest utility. AFBC support > > on the cluster windows is tested with weston-simple-dmabuf-egl on > > weston using the (yet to be upstreamed) panfrost driver support. > > > > Signed-off-by: Sascha Hauer <s.ha...@pengutronix.de> > > --- > > Hi Sascha, > > sadly I'm getting > > [ 1.668856] rockchip-drm display-subsystem: [drm] *ERROR* failed to get > vop2 register byname > [ 1.669621] rockchip-drm display-subsystem: failed to bind fe040000.vop > (ops vop2_component_ops): -22 > [ 1.670584] rockchip-drm display-subsystem: master bind failed: -22 > [ 1.671164] dwhdmi-rockchip: probe of fe0a0000.hdmi failed with error -22 > > on a Quartz64 Model A. > > > > + res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "regs"); > > + if (!res) { > > + drm_err(vop2->drm, "failed to get vop2 register byname\n"); > > + return -EINVAL; > > + } > > This seems to be the code that triggers it. > > Any ideas as to what could be causing this?
Gnaa, this was a last minute change I did and thought it was too trivial to fail :( The binding previously had: reg = <0x0 0xfe040000 0x0 0x3000>, <0x0 0xfe044000 0x0 0x1000>; reg-names = "regs", "gamma_lut"; I thought that I can merge these two regions into one bigger region. Apart from the fact that I got it wrong (The driver still requests a resource "regs" as you found out), it doesnt work, because the space between those two regions is not unused, the iommu is in between them. I'll have to revert that change for the next round. Please use the attached fixup patch in the meantime. Sascha -------------------------------8<------------------------------ >From 9b3dee3d8584f5a9cc24f21ff8c5895465c4b3ae Mon Sep 17 00:00:00 2001 From: Sascha Hauer <s.ha...@pengutronix.de> Date: Mon, 20 Dec 2021 19:49:14 +0100 Subject: [PATCH] fixup! arm64: dts: rockchip: rk356x: Add VOP2 nodes --- arch/arm64/boot/dts/rockchip/rk356x.dtsi | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/arch/arm64/boot/dts/rockchip/rk356x.dtsi b/arch/arm64/boot/dts/rockchip/rk356x.dtsi index 6d93b8fcee179..cce4b789d6d58 100644 --- a/arch/arm64/boot/dts/rockchip/rk356x.dtsi +++ b/arch/arm64/boot/dts/rockchip/rk356x.dtsi @@ -453,7 +453,8 @@ gmac1_mtl_tx_setup: tx-queues-config { }; vop: vop@fe040000 { - reg = <0x0 0xfe040000 0x0 0x5000>; + reg = <0x0 0xfe040000 0x0 0x3000>, <0x0 0xfe044000 0x0 0x1000>; + reg-names = "regs", "gamma_lut"; interrupts = <GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>; clocks = <&cru ACLK_VOP>, <&cru HCLK_VOP>, <&cru DCLK_VOP0>, <&cru DCLK_VOP1>, <&cru DCLK_VOP2>; clock-names = "aclk_vop", "hclk_vop", "dclk_vp0", "dclk_vp1", "dclk_vp2"; -- 2.30.2 -- Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |