> -----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 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 _______________________________________________ kvmarm mailing list kvmarm@xxxxxxxxxxxxxxxxxxxxx https://lists.cs.columbia.edu/mailman/listinfo/kvmarm