Hi Alex,

On 10/24/19 4:20 PM, Alexandre Torgue wrote:
> Hi Vlad,
> 
> On 10/24/19 2:43 PM, Vladimir Murzin wrote:
>> On 10/17/19 10:46 AM, Vladimir Murzin wrote:
>>> I'm wondering if I've missed something with diff bellow (it was a long time 
>>> ago when I touched DMA)?
>>
>> Any comments on that? I can only build test it, so lack of testing stopping 
>> me from sending it as a
>> proper patch :(
> 
> I can make some tests tomorrow. Which particular setup I need to test: cortex 
> M7 + cache + dma + xip ? Let me know.

I assume xip implies dma-ranges in dt, then yes it looks like what we need.

Great thanks!

Vladimir

> 
> regards
> alex
> 
>>
>>>
>>> diff --git a/arch/arm/mm/dma-mapping-nommu.c 
>>> b/arch/arm/mm/dma-mapping-nommu.c
>>> index db92478..287ef89 100644
>>> --- a/arch/arm/mm/dma-mapping-nommu.c
>>> +++ b/arch/arm/mm/dma-mapping-nommu.c
>>> @@ -35,7 +35,7 @@ static void *arm_nommu_dma_alloc(struct device *dev, 
>>> size_t size,
>>>                    unsigned long attrs)
>>>     {
>>> -    void *ret = dma_alloc_from_global_coherent(size, dma_handle);
>>> +    void *ret = dma_alloc_from_global_coherent(dev, size, dma_handle);
>>>         /*
>>>        * dma_alloc_from_global_coherent() may fail because:
>>> diff --git a/include/linux/dma-mapping.h b/include/linux/dma-mapping.h
>>> index 4a1c4fc..10918c5 100644
>>> --- a/include/linux/dma-mapping.h
>>> +++ b/include/linux/dma-mapping.h
>>> @@ -162,7 +162,7 @@ int dma_release_from_dev_coherent(struct device *dev, 
>>> int order, void *vaddr);
>>>   int dma_mmap_from_dev_coherent(struct device *dev, struct vm_area_struct 
>>> *vma,
>>>                   void *cpu_addr, size_t size, int *ret);
>>>   -void *dma_alloc_from_global_coherent(ssize_t size, dma_addr_t 
>>> *dma_handle);
>>> +void *dma_alloc_from_global_coherent(struct device *dev, ssize_t size, 
>>> dma_addr_t *dma_handle);
>>>   int dma_release_from_global_coherent(int order, void *vaddr);
>>>   int dma_mmap_from_global_coherent(struct vm_area_struct *vma, void 
>>> *cpu_addr,
>>>                     size_t size, int *ret);
>>> @@ -172,7 +172,7 @@ int dma_mmap_from_global_coherent(struct vm_area_struct 
>>> *vma, void *cpu_addr,
>>>   #define dma_release_from_dev_coherent(dev, order, vaddr) (0)
>>>   #define dma_mmap_from_dev_coherent(dev, vma, vaddr, order, ret) (0)
>>>   -static inline void *dma_alloc_from_global_coherent(ssize_t size,
>>> +static inline void *dma_alloc_from_global_coherent(struct device *dev, 
>>> ssize_t size,
>>>                              dma_addr_t *dma_handle)
>>>   {
>>>       return NULL;
>>> diff --git a/kernel/dma/coherent.c b/kernel/dma/coherent.c
>>> index 545e386..551b0eb 100644
>>> --- a/kernel/dma/coherent.c
>>> +++ b/kernel/dma/coherent.c
>>> @@ -123,8 +123,9 @@ int dma_declare_coherent_memory(struct device *dev, 
>>> phys_addr_t phys_addr,
>>>       return ret;
>>>   }
>>>   -static void *__dma_alloc_from_coherent(struct dma_coherent_mem *mem,
>>> -        ssize_t size, dma_addr_t *dma_handle)
>>> +static void *__dma_alloc_from_coherent(struct device *dev,
>>> +                       struct dma_coherent_mem *mem,
>>> +                       ssize_t size, dma_addr_t *dma_handle)
>>>   {
>>>       int order = get_order(size);
>>>       unsigned long flags;
>>> @@ -143,7 +144,7 @@ static void *__dma_alloc_from_coherent(struct 
>>> dma_coherent_mem *mem,
>>>       /*
>>>        * Memory was found in the coherent area.
>>>        */
>>> -    *dma_handle = mem->device_base + (pageno << PAGE_SHIFT);
>>> +    *dma_handle = dma_get_device_base(dev, mem) + (pageno << PAGE_SHIFT);
>>>       ret = mem->virt_base + (pageno << PAGE_SHIFT);
>>>       spin_unlock_irqrestore(&mem->spinlock, flags);
>>>       memset(ret, 0, size);
>>> @@ -175,17 +176,18 @@ int dma_alloc_from_dev_coherent(struct device *dev, 
>>> ssize_t size,
>>>       if (!mem)
>>>           return 0;
>>>   -    *ret = __dma_alloc_from_coherent(mem, size, dma_handle);
>>> +    *ret = __dma_alloc_from_coherent(dev, mem, size, dma_handle);
>>>       return 1;
>>>   }
>>>   -void *dma_alloc_from_global_coherent(ssize_t size, dma_addr_t 
>>> *dma_handle)
>>> +void *dma_alloc_from_global_coherent(struct device *dev, ssize_t size,
>>> +                     dma_addr_t *dma_handle)
>>>   {
>>>       if (!dma_coherent_default_memory)
>>>           return NULL;
>>>   -    return __dma_alloc_from_coherent(dma_coherent_default_memory, size,
>>> -            dma_handle);
>>> +    return __dma_alloc_from_coherent(dev, dma_coherent_default_memory, 
>>> size,
>>> +                     dma_handle);
>>>   }
>>>     static int __dma_release_from_coherent(struct dma_coherent_mem *mem,
>>
>>
>> Thanks
>> Vladimir
>>

_______________________________________________
iommu mailing list
[email protected]
https://lists.linuxfoundation.org/mailman/listinfo/iommu

Reply via email to