On 07/07/16 17:56, Lorenzo Pieralisi wrote:
> On Fri, Jul 01, 2016 at 05:50:14PM +0100, Robin Murphy wrote:
> 
> [...]
> 
>> +int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids)
>> +{
>> +    struct iommu_fwspec *fwspec = dev->archdata.iommu;
>> +    size_t size;
>> +
>> +    if (!fwspec)
>> +            return -EINVAL;
>> +
>> +    size = offsetof(struct iommu_fwspec, ids[fwspec->num_ids + 1]);
>                                                               ^^^^
> 
> + num_ids ?

Oops, quite right. Thanks!

Robin.

> Lorenzo
> 
>> +    fwspec = krealloc(dev->archdata.iommu, size, GFP_KERNEL);
>> +    if (!fwspec)
>> +            return -ENOMEM;
>> +
>> +    while (num_ids--)
>> +            fwspec->ids[fwspec->num_ids++] = *ids++;
>> +
>> +    dev->archdata.iommu = fwspec;
>> +    return 0;
>> +}
>> +
>> +inline struct iommu_fwspec *dev_iommu_fwspec(struct device *dev)
>> +{
>> +    return dev->archdata.iommu;
>> +}
>> diff --git a/include/linux/of_iommu.h b/include/linux/of_iommu.h
>> index bd02b44902d0..308791fca32d 100644
>> --- a/include/linux/of_iommu.h
>> +++ b/include/linux/of_iommu.h
>> @@ -15,6 +15,14 @@ extern void of_iommu_init(void);
>>  extern const struct iommu_ops *of_iommu_configure(struct device *dev,
>>                                      struct device_node *master_np);
>>  
>> +struct iommu_fwspec {
>> +    const struct iommu_ops  *iommu_ops;
>> +    struct device_node      *iommu_np;
>> +    void                    *iommu_priv;
>> +    unsigned int            num_ids;
>> +    u32                     ids[];
>> +};
>> +
>>  #else
>>  
>>  static inline int of_get_dma_window(struct device_node *dn, const char 
>> *prefix,
>> @@ -31,8 +39,15 @@ static inline const struct iommu_ops 
>> *of_iommu_configure(struct device *dev,
>>      return NULL;
>>  }
>>  
>> +struct iommu_fwspec;
>> +
>>  #endif      /* CONFIG_OF_IOMMU */
>>  
>> +int iommu_fwspec_init(struct device *dev, struct device_node *iommu_np);
>> +void iommu_fwspec_free(struct device *dev);
>> +int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids);
>> +struct iommu_fwspec *dev_iommu_fwspec(struct device *dev);
>> +
>>  void of_iommu_set_ops(struct device_node *np, const struct iommu_ops *ops);
>>  const struct iommu_ops *of_iommu_get_ops(struct device_node *np);
>>  
>> -- 
>> 2.8.1.dirty
>>
> 

_______________________________________________
iommu mailing list
iommu@lists.linux-foundation.org
https://lists.linuxfoundation.org/mailman/listinfo/iommu

Reply via email to