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 int iort_dma_get_ranges(struct device *dev, u64 *size);
39 int iort_iommu_configure_id(struct device *dev, const u32 *id_in);
40 int iort_iommu_msi_get_resv_regions(struct device *dev, struct list_head *head);
41 phys_addr_t acpi_iort_dma_get_max_cpu_address(void);
42 #else
acpi_iort_init(void)43 static inline void acpi_iort_init(void) { }
iort_msi_map_id(struct device * dev,u32 id)44 static inline u32 iort_msi_map_id(struct device *dev, u32 id)
45 { return id; }
iort_get_device_domain(struct device * dev,u32 id,enum irq_domain_bus_token bus_token)46 static inline struct irq_domain *iort_get_device_domain(
47 struct device *dev, u32 id, enum irq_domain_bus_token bus_token)
48 { return NULL; }
acpi_configure_pmsi_domain(struct device * dev)49 static inline void acpi_configure_pmsi_domain(struct device *dev) { }
50 /* IOMMU interface */
iort_dma_get_ranges(struct device * dev,u64 * size)51 static inline int iort_dma_get_ranges(struct device *dev, u64 *size)
52 { return -ENODEV; }
iort_iommu_configure_id(struct device * dev,const u32 * id_in)53 static inline int iort_iommu_configure_id(struct device *dev, const u32 *id_in)
54 { return -ENODEV; }
55 static inline
iort_iommu_msi_get_resv_regions(struct device * dev,struct list_head * head)56 int iort_iommu_msi_get_resv_regions(struct device *dev, struct list_head *head)
57 { return 0; }
58
acpi_iort_dma_get_max_cpu_address(void)59 static inline phys_addr_t acpi_iort_dma_get_max_cpu_address(void)
60 { return PHYS_ADDR_MAX; }
61 #endif
62
63 #endif /* __ACPI_IORT_H__ */
64