53 lines
1.3 KiB
C
53 lines
1.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2021 Rockchip Electronics Co., Ltd
|
|
*/
|
|
#ifndef __SOC_ROCKCHIP_IOMMU_H
|
|
#define __SOC_ROCKCHIP_IOMMU_H
|
|
|
|
struct device;
|
|
|
|
#if IS_REACHABLE(CONFIG_ROCKCHIP_IOMMU)
|
|
int rockchip_iommu_enable(struct device *dev);
|
|
int rockchip_iommu_disable(struct device *dev);
|
|
int rockchip_pagefault_done(struct device *master_dev);
|
|
void __iomem *rockchip_get_iommu_base(struct device *master_dev, int idx);
|
|
bool rockchip_iommu_is_enabled(struct device *dev);
|
|
void rockchip_iommu_mask_irq(struct device *dev);
|
|
void rockchip_iommu_unmask_irq(struct device *dev);
|
|
int rockchip_iommu_force_reset(struct device *dev);
|
|
#else
|
|
static inline int rockchip_iommu_enable(struct device *dev)
|
|
{
|
|
return -ENODEV;
|
|
}
|
|
static inline int rockchip_iommu_disable(struct device *dev)
|
|
{
|
|
return -ENODEV;
|
|
}
|
|
static inline int rockchip_pagefault_done(struct device *master_dev)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline void __iomem *rockchip_get_iommu_base(struct device *master_dev, int idx)
|
|
{
|
|
return NULL;
|
|
}
|
|
static inline bool rockchip_iommu_is_enabled(struct device *dev)
|
|
{
|
|
return false;
|
|
}
|
|
static inline void rockchip_iommu_mask_irq(struct device *dev)
|
|
{
|
|
}
|
|
static inline void rockchip_iommu_unmask_irq(struct device *dev)
|
|
{
|
|
}
|
|
static inline int rockchip_iommu_force_reset(struct device *dev)
|
|
{
|
|
return -ENODEV;
|
|
}
|
|
#endif
|
|
|
|
#endif
|