@@ -3050,15 +3050,10 @@ int iommu_fwspec_init(struct device *dev, struct fwnode_handle *iommu_fwnode,
}
EXPORT_SYMBOL_GPL(iommu_fwspec_init);
-
-int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids)
+int iommu_fwspec_append_ids(struct iommu_fwspec *fwspec, u32 *ids, int num_ids)
{
- struct iommu_fwspec *fwspec = dev_iommu_fwspec_get(dev);
int i, new_num;
- if (!fwspec)
- return -EINVAL;
-
new_num = fwspec->num_ids + num_ids;
if (new_num <= 1) {
if (fwspec->ids != &fwspec->single_id)
@@ -3080,6 +3075,16 @@ int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids)
fwspec->num_ids = new_num;
return 0;
}
+EXPORT_SYMBOL_GPL(iommu_fwspec_append_ids);
+
+int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids)
+{
+ struct iommu_fwspec *fwspec = dev_iommu_fwspec_get(dev);
+
+ if (!fwspec)
+ return -EINVAL;
+ return iommu_fwspec_append_ids(fwspec, ids, num_ids);
+}
EXPORT_SYMBOL_GPL(iommu_fwspec_add_ids);
/*
@@ -830,6 +830,7 @@ static inline void iommu_fwspec_free(struct device *dev)
}
int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids);
const struct iommu_ops *iommu_ops_from_fwnode(struct fwnode_handle *fwnode);
+int iommu_fwspec_append_ids(struct iommu_fwspec *fwspec, u32 *ids, int num_ids);
static inline struct iommu_fwspec *dev_iommu_fwspec_get(struct device *dev)
{