2023-07-17 18:12:09 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2023-08-03 00:08:02 +00:00
|
|
|
/* Copyright (c) 2023, NVIDIA CORPORATION & AFFILIATES.
|
|
|
|
*/
|
2023-07-17 18:12:09 +00:00
|
|
|
#ifndef __LINUX_IOMMU_PRIV_H
|
|
|
|
#define __LINUX_IOMMU_PRIV_H
|
|
|
|
|
|
|
|
#include <linux/iommu.h>
|
|
|
|
|
2023-08-18 10:10:29 +00:00
|
|
|
static inline const struct iommu_ops *dev_iommu_ops(struct device *dev)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* Assume that valid ops must be installed if iommu_probe_device()
|
|
|
|
* has succeeded. The device ops are essentially for internal use
|
|
|
|
* within the IOMMU subsystem itself, so we should be able to trust
|
|
|
|
* ourselves not to misuse the helper.
|
|
|
|
*/
|
|
|
|
return dev->iommu->iommu_dev->ops;
|
|
|
|
}
|
|
|
|
|
2024-07-02 11:40:48 +00:00
|
|
|
const struct iommu_ops *iommu_ops_from_fwnode(const struct fwnode_handle *fwnode);
|
|
|
|
|
2023-07-17 18:12:09 +00:00
|
|
|
int iommu_group_replace_domain(struct iommu_group *group,
|
|
|
|
struct iommu_domain *new_domain);
|
|
|
|
|
2023-08-03 00:08:02 +00:00
|
|
|
int iommu_device_register_bus(struct iommu_device *iommu,
|
2024-02-16 14:40:24 +00:00
|
|
|
const struct iommu_ops *ops,
|
|
|
|
const struct bus_type *bus,
|
2023-08-03 00:08:02 +00:00
|
|
|
struct notifier_block *nb);
|
|
|
|
void iommu_device_unregister_bus(struct iommu_device *iommu,
|
2024-02-16 14:40:24 +00:00
|
|
|
const struct bus_type *bus,
|
2023-08-03 00:08:02 +00:00
|
|
|
struct notifier_block *nb);
|
|
|
|
|
2023-07-17 18:12:09 +00:00
|
|
|
#endif /* __LINUX_IOMMU_PRIV_H */
|