Skip to content

Commit b4ef725

Browse files
committed
iommu: Introduce wrappers around dev->iommu_fwspec
These wrappers will be used to easily change the location of the field later when all users are converted. Signed-off-by: Joerg Roedel <jroedel@suse.de>
1 parent c4b17af commit b4ef725

File tree

2 files changed

+18
-7
lines changed

2 files changed

+18
-7
lines changed

drivers/iommu/iommu.c

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1976,7 +1976,7 @@ const struct iommu_ops *iommu_ops_from_fwnode(struct fwnode_handle *fwnode)
19761976
int iommu_fwspec_init(struct device *dev, struct fwnode_handle *iommu_fwnode,
19771977
const struct iommu_ops *ops)
19781978
{
1979-
struct iommu_fwspec *fwspec = dev->iommu_fwspec;
1979+
struct iommu_fwspec *fwspec = dev_iommu_fwspec_get(dev);
19801980

19811981
if (fwspec)
19821982
return ops == fwspec->ops ? 0 : -EINVAL;
@@ -1988,26 +1988,26 @@ int iommu_fwspec_init(struct device *dev, struct fwnode_handle *iommu_fwnode,
19881988
of_node_get(to_of_node(iommu_fwnode));
19891989
fwspec->iommu_fwnode = iommu_fwnode;
19901990
fwspec->ops = ops;
1991-
dev->iommu_fwspec = fwspec;
1991+
dev_iommu_fwspec_set(dev, fwspec);
19921992
return 0;
19931993
}
19941994
EXPORT_SYMBOL_GPL(iommu_fwspec_init);
19951995

19961996
void iommu_fwspec_free(struct device *dev)
19971997
{
1998-
struct iommu_fwspec *fwspec = dev->iommu_fwspec;
1998+
struct iommu_fwspec *fwspec = dev_iommu_fwspec_get(dev);
19991999

20002000
if (fwspec) {
20012001
fwnode_handle_put(fwspec->iommu_fwnode);
20022002
kfree(fwspec);
2003-
dev->iommu_fwspec = NULL;
2003+
dev_iommu_fwspec_set(dev, NULL);
20042004
}
20052005
}
20062006
EXPORT_SYMBOL_GPL(iommu_fwspec_free);
20072007

20082008
int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids)
20092009
{
2010-
struct iommu_fwspec *fwspec = dev->iommu_fwspec;
2010+
struct iommu_fwspec *fwspec = dev_iommu_fwspec_get(dev);
20112011
size_t size;
20122012
int i;
20132013

@@ -2016,11 +2016,11 @@ int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids)
20162016

20172017
size = offsetof(struct iommu_fwspec, ids[fwspec->num_ids + num_ids]);
20182018
if (size > sizeof(*fwspec)) {
2019-
fwspec = krealloc(dev->iommu_fwspec, size, GFP_KERNEL);
2019+
fwspec = krealloc(fwspec, size, GFP_KERNEL);
20202020
if (!fwspec)
20212021
return -ENOMEM;
20222022

2023-
dev->iommu_fwspec = fwspec;
2023+
dev_iommu_fwspec_set(dev, fwspec);
20242024
}
20252025

20262026
for (i = 0; i < num_ids; i++)

include/linux/iommu.h

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -398,6 +398,17 @@ void iommu_fwspec_free(struct device *dev);
398398
int iommu_fwspec_add_ids(struct device *dev, u32 *ids, int num_ids);
399399
const struct iommu_ops *iommu_ops_from_fwnode(struct fwnode_handle *fwnode);
400400

401+
static inline struct iommu_fwspec *dev_iommu_fwspec_get(struct device *dev)
402+
{
403+
return dev->iommu_fwspec;
404+
}
405+
406+
static inline void dev_iommu_fwspec_set(struct device *dev,
407+
struct iommu_fwspec *fwspec)
408+
{
409+
dev->iommu_fwspec = fwspec;
410+
}
411+
401412
#else /* CONFIG_IOMMU_API */
402413

403414
struct iommu_ops {};

0 commit comments

Comments
 (0)