RE: Vfio-on-arm: the device tree does not contain the DMA device

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




> -----Original Message-----
> From: Shannon Zhao [mailto:zhaoshenglong@xxxxxxxxxx]
> Sent: Thursday, June 19, 2014 5:47 PM
> To: Bhushan Bharat-R65777; Alvise Rigo; a.motakis@xxxxxxxxxxxxxxxxxxxxxx;
> iommu@xxxxxxxxxxxxxxxxxxxxxxxxxx; kvmarm@xxxxxxxxxxxxxxxxxxxxx
> Subject: Re: Vfio-on-arm: the device tree does not contain the DMA device
> 
> 
> 
> On 2014/6/19 20:12, Bharat.Bhushan@xxxxxxxxxxxxx wrote:
> >
> >
> >> -----Original Message-----
> >> From: Shannon Zhao [mailto:zhaoshenglong@xxxxxxxxxx]
> >> Sent: Thursday, June 19, 2014 5:38 PM
> >> To: Alvise Rigo; Bhushan Bharat-R65777;
> >> a.motakis@xxxxxxxxxxxxxxxxxxxxxx; iommu@xxxxxxxxxxxxxxxxxxxxxxxxxx;
> >> kvmarm@xxxxxxxxxxxxxxxxxxxxx
> >> Subject: Re: Vfio-on-arm: the device tree does not contain the DMA
> >> device
> >>
> >> Hi Alvise,
> >>
> >> I run following cmds :
> >> 	echo 2c0a0000.dma >
> >> /sys/bus/platform/drivers/vfio-platform/vfio_bind
> >
> > run "ls /dev/vfio/" before and after the above command
> Hi Bharat,
> 
> Nothing appeared either before or after the cmd "echo 2c0a0000.dma >
> /sys/bus/platform/drivers/vfio-platform/vfio_bind".
> There is only /dev/vfio.

I am not sure, but may be you are using pretty old rootfs with broken udev rules. Try to fetch a newer rootfs form somewhere.

Thanks
-Bharat


> >
> > Thanks
> > -Bharat
> >
> >
> >> 	./qemu-system-arm -enable-kvm -M vexpress-a15 -cpu cortex-a15 \
> >>         	-device
> >>
> pl330,vfio_group="/dev/vfio/0",vfio_device="2c0a0000.dma",vfio_container="/dev/v
> >> fio/vfio" \
> >>         	-append "earlyprintk ip=dhcp console=ttyAMA0 rootwait" \
> >>         	-kernel zImage -dtb guest-a15.dtb -initrd filesystem.cpio.gz  -
> >> nographic But the error still exists.
> >> 	qemu-system-arm: -device
> >>
> pl330,vfio_group=/dev/vfio/0,vfio_device=2c0a0000.dma,vfio_container=/dev/vfio/v
> >> fio: Parameter 'driver' expects pluggable device type
> >>
> >> Thanks,
> >> Shannon
> >>
> >> On 2014/6/19 19:26, Alvise Rigo wrote:
> >>>
> >>>
> >>> Il 19/06/2014 13:11, Shannon Zhao ha scritto:
> >>>>
> >>>>
> >>>> On 2014/6/19 18:47, Alvise Rigo wrote:
> >>>>> Hi,
> >>>>>
> >>>>> Il 19/06/2014 11:38, Shannon Zhao ha scritto:
> >>>>>> Hi Bharat,
> >>>>>>
> >>>>>> On 2014/6/19 17:19, Bharat.Bhushan@xxxxxxxxxxxxx wrote:
> >>>>>>>
> >>>>>>>
> >>>>>>>> -----Original Message-----
> >>>>>>>> From: kvmarm-bounces@xxxxxxxxxxxxxxxxxxxxx [mailto:kvmarm-
> >>>>>>>> bounces@xxxxxxxxxxxxxxxxxxxxx] On Behalf Of Shannon Zhao
> >>>>>>>> Sent: Thursday, June 19, 2014 2:45 PM
> >>>>>>>> To: Alvise Rigo; a.motakis@xxxxxxxxxxxxxxxxxxxxxx;
> >>>>>>>> iommu@lists.linux- foundation.org; kvmarm@xxxxxxxxxxxxxxxxxxxxx
> >>>>>>>> Subject: Re: Vfio-on-arm: the device tree does not contain the
> >>>>>>>> DMA device
> >>>>>>>>
> >>>>>>>> Hi Alvise,
> >>>>>>>>
> >>>>>>>> Thanks for your reply.
> >>>>>>>> I have apply the patch and could see the DMA devices.
> >>>>>>>> But there is no vosys_dmatest int the directory
> >>>>>>>> "/sys/kernel/debug/" after mounting debugfs.
> >>>>>>>> I found that the branch vfio-platform-v4 doesn't contain the
> >>>>>>>> module vosys_dmatest.
> >>>>>>>> Then I port it from the branch pl330_dmatest and run vosys_dmatest
> >> successfully.
> >>>>>>>>
> >>>>>>>> 	echo 1 > /sys/kernel/debug/vosys_dmatest/start
> >>>>>>>>
> >>>>>>>> 	[ 6145.343419] dmaengine: __dma_request_channel: success
> >> (dma0chan0)
> >>>>>>>> 	[ 6145.344000] vosys dmatest: callback: transfer completed
> >>>>>>>> 	[ 6145.344147] vosys dmatest: tx completed
> >>>>>>>> 	[ 6145.344589] vosys dmatest: source and destination match.
> >>>>>>>>
> >>>>>>>> Download the qemu and use following command to start a guest:
> >>>>>>>> 	./qemu-system-arm -enable-kvm -M vexpress-a15 -cpu cortex-a15 \
> >>>>>>>>         	-device
> >> pl330,vfio_group="/dev/vfio/0",vfio_device="2c0a0000.dma",\
> >>>>>>>>         	vfio_container="/dev/vfio/vfio" \
> >>>>>>>>         	-append "earlyprintk ip=dhcp console=ttyAMA0 rootwait" \
> >>>>>>>>         	-kernel zImage -dtb guest.dtb -initrd filesystem.cpio.gz
> >>>>>>>> - nographic An error reported:
> >>>>>>>> 	qemu-system-arm: -device
> >>>>>>>> pl330,vfio_group=/dev/vfio/0,vfio_device=2c0a0000.dma,:
> >>>>>>>
> >>>>>>> Why do we need to give "vfio_group=/dev/vfio/0" ?
> >>>>>> I refer to the url
> >> "http://www.virtualopensystems.com/en/solutions/guides/vfio-on-arm/";.
> >>>>>>>
> >>>>>>>
> >>>>>>>> 	could not open disk image vfio_container=/dev/vfio:
> >>>>>>>> 	Could not open 'vfio_container=/dev/vfio': No such file or
> >>>>>>>> directory
> >>>>>>>
> >>>>>>> Are you unbinding "2c0a0000.dma" from its driver and binding with "vfio-
> >> playform" driver ?
> >>>>>> How to unbind "2c0a0000.dma" from its driver?
> >>>>>> I have tried following cmd to bind "2c0a0000.dma" with "vfio-playform"
> >> driver.
> >>>>>> 	echo 2c0a0000.dma >
> >>>>>> /sys/bus/platform/drivers/vfio-platform/vfio_bind
> >>>>>> But there is no /dev/vfio/0 or /dev/vfio/vfio .
> >>>>>
> >>>>>
> >>>>> Can you please verify that while configuring the host you enabled:
> >>>>> - Device Drivers -> IOMMU Hardware Support -> ARM Ltd. System MMU
> >>>>> (SMMU) Support and
> >>>>> - Device Drivers -> VFIO Non-Privileged userspace driver framework
> >>>>> -> VFIO support for platform devices
> >>>>>
> >>>> Hi Alvise,
> >>>>
> >>>> I have checked the two configuration are enabled.
> >>>>
> >>>> Then try the following cmd, but another error reported:
> >>>> 	qemu-system-arm: -device
> >>>> pl330,vfio_group=/dev/vfio/0,vfio_device=2c0a0000.dma,vfio_container=
> >>>> /dev/vfio/vfio: Parameter 'driver' expects pluggable device type
> >>>>
> >>>> Do I need to unbind the "2c0a0000.dma" from its driver and binding with
> >> "vfio-platform" driver as Bharat mentioned ?
> >>>
> >>> Yes, the 2c0a0000.dma should not be bound to any driver at boot, so
> >>> you just need to:
> >>> echo 2c0a0000.dma > /sys/bus/platform/drivers/vfio-platform/vfio_bind
> >>> to bind the device to the VFIO driver.
> >>
> >>>
> >>> Regards,
> >>> alvise
> >>>
> >>>>
> >>>>> Then try to update the pl330-vfio-dev branch and run QEMU with the
> following
> >> command:
> >>>>>
> >>>>> ./qemu-system-arm -enable-kvm -M vexpress-a15 -cpu cortex-a15 \
> >>>>>     -device
> >>
> pl330,vfio_group="/dev/vfio/0",vfio_device="2c0a0000.dma",vfio_container="/dev/v
> >> fio/vfio" \
> >>>>>     -append "earlyprintk ip=dhcp console=ttyAMA0 rootwait" \
> >>>>>     -kernel zImage -dtb guest.dtb -initrd filesystem.cpio.gz
> >>>>>
> >>>>> that means without breaking the "-device pl330" options.
> >>>>>
> >>>>> Regards,
> >>>>> alvise
> >>>>>
> >>>>>>
> >>>>>>>
> >>>>>>> Thanks
> >>>>>>> -Bharat
> >>>>>>>
> >>>>>>>>
> >>>>>>>> Is there something I'm wrong or do I miss some steps?
> >>>>>>>>
> >>>>>>>> Thank you,
> >>>>>>>> Shannon
> >>>>>>>>
> >>>>>>>> On 2014/6/18 21:24, Alvise Rigo wrote:
> >>>>>>>>> Hi Shannon,
> >>>>>>>>>
> >>>>>>>>> Thank you for reporting this issue, the device tree file was indeed
> >> missing.
> >>>>>>>>> To solve the problem, you can apply the following patch to the
> >>>>>>>>> repository you mentioned
> >>>>>>>>> (git://github.com/virtualopensystems/arm-dts.git).
> >>>>>>>>>
> >>>>>>>>> For your information, soon we will update the guide with a newer
> >>>>>>>>> version of VFIO with this issue fixed.
> >>>>>>>>>
> >>>>>>>>> Thank you,
> >>>>>>>>> alvise
> >>>>>>>>>
> >>>>>>>>> ---
> >>>>>>>>>  fast_models/rtsm_ve-cortex_a15x4_a7x4.dts | 100
> >>>>>>>>> +++++++++++++++++++++++++++++-
> >>>>>>>>>  1 file changed, 97 insertions(+), 3 deletions(-)
> >>>>>>>>>
> >>>>>>>>> diff --git a/fast_models/rtsm_ve-cortex_a15x4_a7x4.dts
> >>>>>>>>> b/fast_models/rtsm_ve-cortex_a15x4_a7x4.dts
> >>>>>>>>> index ef1275b..79c6af2 100644
> >>>>>>>>> --- a/fast_models/rtsm_ve-cortex_a15x4_a7x4.dts
> >>>>>>>>> +++ b/fast_models/rtsm_ve-cortex_a15x4_a7x4.dts
> >>>>>>>>> @@ -142,7 +142,7 @@
> >>>>>>>>>  		cpu7: cpu@7 {
> >>>>>>>>>  			device_type = "cpu";
> >>>>>>>>>  			compatible = "arm,cortex-a7";
> >>>>>>>>> -			reg = <0x104>;
> >>>>>>>>> +			reg = <0x103>;
> >>>>>>>>>  			cluster = <&cluster1>;
> >>>>>>>>>  			core = <&core7>;
> >>>>>>>>>  		};
> >>>>>>>>> @@ -159,7 +159,7 @@
> >>>>>>>>>  		#address-cells = <0>;
> >>>>>>>>>  		interrupt-controller;
> >>>>>>>>>  		reg = <0 0x2c001000 0 0x1000>,
> >>>>>>>>> -		      <0 0x2c002000 0 0x2000>,
> >>>>>>>>> +		      <0 0x2c002000 0 0x1000>,
> >>>>>>>>>  		      <0 0x2c004000 0 0x2000>,
> >>>>>>>>>  		      <0 0x2c006000 0 0x2000>;
> >>>>>>>>>  		interrupts = <1 9 0xf04>;
> >>>>>>>>> @@ -183,6 +183,101 @@
> >>>>>>>>>  			     <1 10 0xf08>;
> >>>>>>>>>  	};
> >>>>>>>>>
> >>>>>>>>> +	smmu@2c0b0000 {
> >>>>>>>>> +                compatible = "arm,smmu-v2";
> >>>>>>>>> +                reg = <0x0 0x2c0b0000 0x0 0x10000>;
> >>>>>>>>> +                #global-interrupts = <2>;
> >>>>>>>>> +                interrupts = <0 58 4>,
> >>>>>>>>> +                             <0 59 4>,
> >>>>>>>>> +                             <0 60 4>,
> >>>>>>>>> +                             <0 60 4>,
> >>>>>>>>> +                             <0 60 4>,
> >>>>>>>>> +                             <0 60 4>,
> >>>>>>>>> +                             <0 60 4>,
> >>>>>>>>> +                             <0 60 4>,
> >>>>>>>>> +                             <0 60 4>;
> >>>>>>>>> +                mmu-masters = <&dma0 0x0 0x8>,
> >>>>>>>>> +                              <&dma1 0x1 0x9>,
> >>>>>>>>> +                              <&dma2 0x2 0xa>,
> >>>>>>>>> +                              <&dma3 0x3 0xb>;
> >>>>>>>>> +        };
> >>>>>>>>> +
> >>>>>>>>> +	dma0: dma@2c0a0000 {
> >>>>>>>>> +		compatible = "arm,pl330";
> >>>>>>>>> +		reg = <0 0x2c0a0000 0 0x1000>;
> >>>>>>>>> +		interrupts = <0 64 4>,
> >>>>>>>>> +			     <0 65 4>,
> >>>>>>>>> +			     <0 66 4>,
> >>>>>>>>> +			     <0 67 4>,
> >>>>>>>>> +			     <0 68 4>,
> >>>>>>>>> +			     <0 69 4>,
> >>>>>>>>> +			     <0 70 4>,
> >>>>>>>>> +			     <0 71 4>;
> >>>>>>>>> +		#dma-cells = <1>;
> >>>>>>>>> +		#stream-id-cells = <2>;
> >>>>>>>>> +		clocks = <&oscclk6a>;
> >>>>>>>>> +		clock-names = "apb_pclk";
> >>>>>>>>> +	};
> >>>>>>>>> +
> >>>>>>>>> +	dma1: dma@2c0a1000 {
> >>>>>>>>> +		compatible = "arm,pl330", "arm,primecell";
> >>>>>>>>> +		reg = <0 0x2c0a1000 0 0x1000>;
> >>>>>>>>> +		interrupts = <0 96 4>,
> >>>>>>>>> +			     <0 97 4>,
> >>>>>>>>> +			     <0 98 4>,
> >>>>>>>>> +			     <0 99 4>,
> >>>>>>>>> +			     <0 100 4>,
> >>>>>>>>> +			     <0 101 4>,
> >>>>>>>>> +			     <0 102 4>,
> >>>>>>>>> +			     <0 103 4>;
> >>>>>>>>> +		#dma-cells = <1>;
> >>>>>>>>> +		#stream-id-cells = <2>;
> >>>>>>>>> +		clocks = <&oscclk6a>;
> >>>>>>>>> +		clock-names = "apb_pclk";
> >>>>>>>>> +	};
> >>>>>>>>> +
> >>>>>>>>> +	dma2: dma@2c0a2000 {
> >>>>>>>>> +		compatible = "arm,pl330", "arm,primecell";
> >>>>>>>>> +		reg = <0 0x2c0a2000 0 0x1000>;
> >>>>>>>>> +		interrupts = <0 128 4>,
> >>>>>>>>> +			     <0 129 4>,
> >>>>>>>>> +			     <0 130 4>,
> >>>>>>>>> +			     <0 131 4>,
> >>>>>>>>> +			     <0 132 4>,
> >>>>>>>>> +			     <0 133 4>,
> >>>>>>>>> +			     <0 134 4>,
> >>>>>>>>> +			     <0 135 4>;
> >>>>>>>>> +		#dma-cells = <1>;
> >>>>>>>>> +		#stream-id-cells = <2>;
> >>>>>>>>> +		clocks = <&oscclk6a>;
> >>>>>>>>> +		clock-names = "apb_pclk";
> >>>>>>>>> +	};
> >>>>>>>>> +
> >>>>>>>>> +	dma3: dma@2c0a3000 {
> >>>>>>>>> +		compatible = "arm,pl330", "arm,primecell";
> >>>>>>>>> +		reg = <0 0x2c0a3000 0 0x1000>;
> >>>>>>>>> +		interrupts = <0 160 4>,
> >>>>>>>>> +			     <0 161 4>,
> >>>>>>>>> +			     <0 162 4>,
> >>>>>>>>> +			     <0 163 4>,
> >>>>>>>>> +			     <0 164 4>,
> >>>>>>>>> +			     <0 165 4>,
> >>>>>>>>> +			     <0 166 4>,
> >>>>>>>>> +			     <0 167 4>;
> >>>>>>>>> +		#dma-cells = <1>;
> >>>>>>>>> +		#stream-id-cells = <2>;
> >>>>>>>>> +		clocks = <&oscclk6a>;
> >>>>>>>>> +		clock-names = "apb_pclk";
> >>>>>>>>> +	};
> >>>>>>>>> +
> >>>>>>>>> +	oscclk6a: oscclk6a {
> >>>>>>>>> +		/* Reference 24MHz clock */
> >>>>>>>>> +		compatible = "fixed-clock";
> >>>>>>>>> +		#clock-cells = <0>;
> >>>>>>>>> +		clock-frequency = <24000000>;
> >>>>>>>>> +		clock-output-names = "oscclk6a";
> >>>>>>>>> +	};
> >>>>>>>>> +
> >>>>>>>>>  	smb {
> >>>>>>>>>  		compatible = "simple-bus";
> >>>>>>>>>
> >>>>>>>>> @@ -244,4 +339,3 @@
> >>>>>>>>>  		/include/ "rtsm_ve-motherboard.dtsi"
> >>>>>>>>>  	};
> >>>>>>>>>  };
> >>>>>>>>> -
> >>>>>>>>>
> >>>>>>>>
> >>>>>>>> --
> >>>>>>>> Shannon
> >>>>>>>>
> >>>>>>>> _______________________________________________
> >>>>>>>> kvmarm mailing list
> >>>>>>>> kvmarm@xxxxxxxxxxxxxxxxxxxxx
> >>>>>>>> https://lists.cs.columbia.edu/mailman/listinfo/kvmarm
> >>>>>>>
> >>>>>>> .
> >>>>>>>
> >>>>>>
> >>>>>
> >>>>> .
> >>>>>
> >>>>
> >>>
> >>> .
> >>>
> >>
> >> --
> >> Shannon
> >
> >
> > .
> >
> 
> --
> Shannon

_______________________________________________
kvmarm mailing list
kvmarm@xxxxxxxxxxxxxxxxxxxxx
https://lists.cs.columbia.edu/mailman/listinfo/kvmarm




[Index of Archives]     [Linux KVM]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux