[PATCH 3/3] arm64: dts: rockchip: Add rkvdec2 Video Decoder on rk3588(s)

Heiko Stuebner heiko at sntech.de
Sun Jun 16 00:28:25 PDT 2024


Am Samstag, 15. Juni 2024, 21:55:54 CEST schrieb Detlev Casanova:
> On Saturday, June 15, 2024 4:25:27 A.M. EDT Jonas Karlman wrote:
> > Hi Detlev,
> > 
> > On 2024-06-15 03:56, Detlev Casanova wrote:
> > > Add the rkvdec2 Video Decoder to the RK3588s devicetree.
> > > 
> > > Signed-off-by: Detlev Casanova <detlev.casanova at collabora.com>
> > > ---
> > > 
> > >  .../boot/dts/rockchip/rk3588-rock-5b.dts      |  4 ++++
> > >  .../boot/dts/rockchip/rk3588s-orangepi-5.dts  |  4 ++++
> > >  arch/arm64/boot/dts/rockchip/rk3588s.dtsi     | 19 +++++++++++++++++++
> > >  3 files changed, 27 insertions(+)
> > > 
> > > diff --git a/arch/arm64/boot/dts/rockchip/rk3588-rock-5b.dts
> > > b/arch/arm64/boot/dts/rockchip/rk3588-rock-5b.dts index
> > > c551b676860c..965322c24a65 100644
> > > --- a/arch/arm64/boot/dts/rockchip/rk3588-rock-5b.dts
> > > +++ b/arch/arm64/boot/dts/rockchip/rk3588-rock-5b.dts
> > > @@ -503,6 +503,10 @@ &pwm1 {
> > > 
> > >  	status = "okay";
> > >  
> > >  };
> > > 
> > > +&rkvdec0 {
> > > +	status = "okay";
> > > +};
> > 
> > Enable of rkvdec0 should probably be split out from the patch that adds
> > the rkvdec0 node to soc dtsi.
> 
> Ack
> 
> > Also why is rkvdec0 only enabled on rock-5b and orangepi-5?
> 
> I only could test on those two but I can enable it on all rk3588 devices.
> 
> > > +
> > > 
> > >  &saradc {
> > >  
> > >  	vref-supply = <&avcc_1v8_s0>;
> > >  	status = "okay";
> > > 
> > > diff --git a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dts
> > > b/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dts index
> > > feea6b20a6bf..2828fb4c182a 100644
> > > --- a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dts
> > > +++ b/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dts
> > > @@ -321,6 +321,10 @@ typec5v_pwren: typec5v-pwren {
> > > 
> > >  	};
> > >  
> > >  };
> > > 
> > > +&rkvdec0 {
> > > +	status = "okay";
> > > +};
> > > +
> > > 
> > >  &saradc {
> > >  
> > >  	vref-supply = <&avcc_1v8_s0>;
> > >  	status = "okay";
> > > 
> > > diff --git a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi
> > > b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi index
> > > 0fecbf46e127..09672636dcea 100644
> > > --- a/arch/arm64/boot/dts/rockchip/rk3588s.dtsi
> > > +++ b/arch/arm64/boot/dts/rockchip/rk3588s.dtsi
> > > @@ -3034,6 +3034,9 @@ system_sram2: sram at ff001000 {
> > > 
> > >  		ranges = <0x0 0x0 0xff001000 0xef000>;
> > >  		#address-cells = <1>;
> > >  		#size-cells = <1>;
> > 
> > Blank line is missing.
> > 
> > > +		rkvdec0_sram: rkvdec-sram at 0 {
> > > +			reg = <0x0 0x78000>;
> > > +		};
> > > 
> > >  	};
> > >  	
> > >  	pinctrl: pinctrl {
> > > 
> > > @@ -3103,6 +3106,22 @@ gpio4: gpio at fec50000 {
> > > 
> > >  			#interrupt-cells = <2>;
> > >  		
> > >  		};
> > >  	
> > >  	};
> > > 
> > > +
> > > +	rkvdec0: video-decoder at fdc38100 {
> > > +		compatible = "rockchip,rk3588-vdec2";
> > > +		reg = <0x0 0xfdc38100 0x0 0x500>;
> > > +		interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH 0>;
> > > +		clocks = <&cru ACLK_RKVDEC0>, <&cru HCLK_RKVDEC0>, 
> <&cru
> > > CLK_RKVDEC0_CORE>, +			 <&cru 
> CLK_RKVDEC0_CA>, <&cru
> > > CLK_RKVDEC0_HEVC_CA>;
> > > +		clock-names = "axi", "ahb", "core",
> > > +			      "cabac", "hevc_cabac";
> > > +		assigned-clocks = <&cru ACLK_RKVDEC0>, <&cru 
> CLK_RKVDEC0_CORE>,
> > > +				  <&cru CLK_RKVDEC0_CA>, <&cru 
> CLK_RKVDEC0_HEVC_CA>;
> > > +		assigned-clock-rates = <800000000>, <600000000>,
> > > +				       <600000000>, <1000000000>;
> > > +		power-domains = <&power RK3588_PD_RKVDEC0>;
> > 
> > iommus and resets should probably be added.
> > 
> > > +		status = "disabled";
> > > +	};
> > 
> > The iommu node for rkvdec0_mmu seem to be missing, is it not required to
> > be able to use memory >4GiB as decoding buffers?
> 
> I need to check if the current rockchip iommu driver will work for this 
> decoder. I remember that the iommu code for AV1 was a bit different, not sure 
> about this rkvdec.
> 
> > I would also consider adding the rkvdec1 node(s), if I am understanding
> > correctly they can both be used in a cluster or completely independent.
> 
> They can be used independently, yes. I'll add rkvdec1 for rk3588 devices 
> (rk3588s only has  1 core)

Please check in with Sebastian Reichel about clusters/independent
controllers. He had a lot of fruitful discussions for the VEPU121/VPU121
support he is working on.

Baseline being, while we want the hw to be described correctly wrt the
multiple instances, we don't generally want to expose them individually
to userspace, because that would then require userspace to do all the
scheduling.





More information about the linux-arm-kernel mailing list