1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * Copyright (C) 2016, Semihalf
4 * Author: Tomasz Nowicki <tn@semihalf.com>
5 */
6
7 #ifndef __ACPI_IORT_H__
8 #define __ACPI_IORT_H__
9
10 #include <linux/acpi.h>
11 #include <linux/fwnode.h>
12 #include <linux/irqdomain.h>
13
14 #define IORT_IRQ_MASK(irq) (irq & 0xffffffffULL)
15 #define IORT_IRQ_TRIGGER_MASK(irq) ((irq >> 32) & 0xffffffffULL)
16
17 /*
18 * PMCG model identifiers for use in smmu pmu driver. Please note
19 * that this is purely for the use of software and has nothing to
20 * do with hardware or with IORT specification.
21 */
22 #define IORT_SMMU_V3_PMCG_GENERIC 0x00000000 /* Generic SMMUv3 PMCG */
23 #define IORT_SMMU_V3_PMCG_HISI_HIP08 0x00000001 /* HiSilicon HIP08 PMCG */
24 #define IORT_SMMU_V3_PMCG_HISI_HIP09 0x00000002 /* HiSilicon HIP09 PMCG */
25
26 int iort_register_domain_token(int trans_id, phys_addr_t base,
27 struct fwnode_handle *fw_node);
28 void iort_deregister_domain_token(int trans_id);
29 struct fwnode_handle *iort_find_domain_token(int trans_id);
30 #ifdef CONFIG_ACPI_IORT
31 void acpi_iort_init(void);
32 u32 iort_msi_map_id(struct device *dev, u32 id);
33 struct irq_domain *iort_get_device_domain(struct device *dev, u32 id,
34 enum irq_domain_bus_token bus_token);
35 void acpi_configure_pmsi_domain(struct device *dev);
36 int iort_pmsi_get_dev_id(struct device *dev, u32 *dev_id);
37 /* IOMMU interface */
38 void iort_dma_setup(struct device *dev, u64 *dma_addr, u64 *size);
39 const struct iommu_ops *iort_iommu_configure_id(struct device *dev,
40 const u32 *id_in);
41 int iort_iommu_msi_get_resv_regions(struct device *dev, struct list_head *head);
42 phys_addr_t acpi_iort_dma_get_max_cpu_address(void);
43 #else
acpi_iort_init(void)44 static inline void acpi_iort_init(void) { }
iort_msi_map_id(struct device * dev,u32 id)45 static inline u32 iort_msi_map_id(struct device *dev, u32 id)
46 { return id; }
iort_get_device_domain(struct device * dev,u32 id,enum irq_domain_bus_token bus_token)47 static inline struct irq_domain *iort_get_device_domain(
48 struct device *dev, u32 id, enum irq_domain_bus_token bus_token)
49 { return NULL; }
acpi_configure_pmsi_domain(struct device * dev)50 static inline void acpi_configure_pmsi_domain(struct device *dev) { }
51 /* IOMMU interface */
iort_dma_setup(struct device * dev,u64 * dma_addr,u64 * size)52 static inline void iort_dma_setup(struct device *dev, u64 *dma_addr,
53 u64 *size) { }
iort_iommu_configure_id(struct device * dev,const u32 * id_in)54 static inline const struct iommu_ops *iort_iommu_configure_id(
55 struct device *dev, const u32 *id_in)
56 { return NULL; }
57 static inline
iort_iommu_msi_get_resv_regions(struct device * dev,struct list_head * head)58 int iort_iommu_msi_get_resv_regions(struct device *dev, struct list_head *head)
59 { return 0; }
60
acpi_iort_dma_get_max_cpu_address(void)61 static inline phys_addr_t acpi_iort_dma_get_max_cpu_address(void)
62 { return PHYS_ADDR_MAX; }
63 #endif
64
65 #endif /* __ACPI_IORT_H__ */
66