Yes, that is an old guide based on VFIO v4. We will update it soon.

Regards,
alvise

Il 19/06/2014 12:18, Eric Auger ha scritto:
> On 06/19/2014 12:15 PM, [email protected] wrote:
>>
>>
>>> -----Original Message-----
>>> From: Eric Auger [mailto:[email protected]]
>>> Sent: Thursday, June 19, 2014 3:41 PM
>>> To: Shannon Zhao; Bhushan Bharat-R65777; Alvise Rigo;
>>> [email protected]; [email protected];
>>> [email protected]
>>> Subject: Re: Vfio-on-arm: the device tree does not contain the DMA device
>>>
>>> On 06/19/2014 11:38 AM, Shannon Zhao wrote:
>>>> Hi Bharat,
>>>>
>>>> On 2014/6/19 17:19, [email protected] wrote:
>>>>>
>>>>>
>>>>>> -----Original Message-----
>>>>>> From: [email protected] [mailto:kvmarm-
>>>>>> [email protected]] On Behalf Of Shannon Zhao
>>>>>> Sent: Thursday, June 19, 2014 2:45 PM
>>>>>> To: Alvise Rigo; [email protected]; [email protected]
>>>>>> foundation.org; [email protected]
>>>>>> 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 .
>>>
>>> Hi Shannon,
>>>
>>> you may try following cmd to unbind the native dma driver
>>> echo 2c0a0000.dma | sudo tee -a
>>> /sys/bus/platform/devices/2c0a0000.dma/driver/unbind
>>>
>>> and then the following one to bing the meta-driver to the device
>>> echo 2c0a0000.dma | sudo tee -a
>>> /sys/bus/platform/drivers/vfio-platform/vfio_bind
>>
>> Should not we use "driver-override" mechanism for binding with vfio-platform 
>> driver?
>>
>> Thanks
>> -Bharat
> 
> Hi Bharat,
> 
> I guess Shannon is using an older version of the kernel. With
> vfio-platform v4 this is the old unbind/bin mechanism that is in place,
> if I am not wrong.
> 
> Best Regards
> 
> Eric
>>
>>>
>>> Best Regards
>>>
>>> Eric
>>>
>>>>
>>>>>
>>>>> 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
>>>>>> [email protected]
>>>>>> https://lists.cs.columbia.edu/mailman/listinfo/kvmarm
>>>>>
>>>>> .
>>>>>
>>>>
>>
> 
_______________________________________________
iommu mailing list
[email protected]
https://lists.linuxfoundation.org/mailman/listinfo/iommu

Reply via email to