Blame view

include/linux/dmar.h 6.77 KB
10e5247f4   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
  /*
   * Copyright (c) 2006, Intel Corporation.
   *
   * This program is free software; you can redistribute it and/or modify it
   * under the terms and conditions of the GNU General Public License,
   * version 2, as published by the Free Software Foundation.
   *
   * This program is distributed in the hope it will be useful, but WITHOUT
   * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
   * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
   * more details.
   *
   * You should have received a copy of the GNU General Public License along with
   * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
   * Place - Suite 330, Boston, MA 02111-1307 USA.
   *
   * Copyright (C) Ashok Raj <ashok.raj@intel.com>
   * Copyright (C) Shaohua Li <shaohua.li@intel.com>
   */
  
  #ifndef __DMAR_H__
  #define __DMAR_H__
  
  #include <linux/acpi.h>
  #include <linux/types.h>
ba3959276   Keshavamurthy, Anil S   Intel IOMMU: Inte...
26
  #include <linux/msi.h>
1531a6a6b   Suresh Siddha   x86, dmar: start ...
27
  #include <linux/irqreturn.h>
10e5247f4   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
28

6eea69dd8   Andrew Morton   include/linux/dma...
29
  struct acpi_dmar_header;
41750d31f   Suresh Siddha   x86, x2apic: Enab...
30
31
32
  /* DMAR Flags */
  #define DMAR_INTR_REMAP		0x1
  #define DMAR_X2APIC_OPT_OUT	0x2
ba3959276   Keshavamurthy, Anil S   Intel IOMMU: Inte...
33
  struct intel_iommu;
d3f138106   Suresh Siddha   iommu: Rename the...
34
  #ifdef CONFIG_DMAR_TABLE
41750d31f   Suresh Siddha   x86, x2apic: Enab...
35
  extern struct acpi_table_header *dmar_tbl;
2ae210106   Suresh Siddha   x64, x2apic/intr-...
36
37
38
39
40
41
  struct dmar_drhd_unit {
  	struct list_head list;		/* list of drhd units	*/
  	struct  acpi_dmar_header *hdr;	/* ACPI header		*/
  	u64	reg_base_addr;		/* register base address*/
  	struct	pci_dev **devices; 	/* target device array	*/
  	int	devices_cnt;		/* target device count	*/
276dbf997   David Woodhouse   intel-iommu: Hand...
42
  	u16	segment;		/* PCI domain		*/
2ae210106   Suresh Siddha   x64, x2apic/intr-...
43
44
45
46
47
48
49
50
51
  	u8	ignored:1; 		/* ignore drhd		*/
  	u8	include_all:1;
  	struct intel_iommu *iommu;
  };
  
  extern struct list_head dmar_drhd_units;
  
  #define for_each_drhd_unit(drhd) \
  	list_for_each_entry(drhd, &dmar_drhd_units, list)
8f912ba4d   David Woodhouse   intel-iommu: Add ...
52
53
54
55
56
57
58
  #define for_each_active_iommu(i, drhd)					\
  	list_for_each_entry(drhd, &dmar_drhd_units, list)		\
  		if (i=drhd->iommu, drhd->ignored) {} else
  
  #define for_each_iommu(i, drhd)						\
  	list_for_each_entry(drhd, &dmar_drhd_units, list)		\
  		if (i=drhd->iommu, 0) {} else 
2ae210106   Suresh Siddha   x64, x2apic/intr-...
59
  extern int dmar_table_init(void);
2ae210106   Suresh Siddha   x64, x2apic/intr-...
60
61
62
  extern int dmar_dev_scope_init(void);
  
  /* Intel IOMMU detection */
480125ba4   Konrad Rzeszutek Wilk   x86, iommu: Make ...
63
  extern int detect_intel_iommu(void);
9d783ba04   Suresh Siddha   x86, x2apic: enab...
64
  extern int enable_drhd_fault_handling(void);
2ae210106   Suresh Siddha   x64, x2apic/intr-...
65

2ae210106   Suresh Siddha   x64, x2apic/intr-...
66
67
68
  extern int parse_ioapics_under_ir(void);
  extern int alloc_iommu(struct dmar_drhd_unit *);
  #else
480125ba4   Konrad Rzeszutek Wilk   x86, iommu: Make ...
69
  static inline int detect_intel_iommu(void)
2ae210106   Suresh Siddha   x64, x2apic/intr-...
70
  {
480125ba4   Konrad Rzeszutek Wilk   x86, iommu: Make ...
71
  	return -ENODEV;
2ae210106   Suresh Siddha   x64, x2apic/intr-...
72
73
74
75
76
77
  }
  
  static inline int dmar_table_init(void)
  {
  	return -ENODEV;
  }
29b61be65   Suresh Siddha   x86, x2apic: clea...
78
79
80
81
  static inline int enable_drhd_fault_handling(void)
  {
  	return -1;
  }
d3f138106   Suresh Siddha   iommu: Rename the...
82
  #endif /* !CONFIG_DMAR_TABLE */
2ae210106   Suresh Siddha   x64, x2apic/intr-...
83

2ae210106   Suresh Siddha   x64, x2apic/intr-...
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
  struct irte {
  	union {
  		struct {
  			__u64	present 	: 1,
  				fpd		: 1,
  				dst_mode	: 1,
  				redir_hint	: 1,
  				trigger_mode	: 1,
  				dlvry_mode	: 3,
  				avail		: 4,
  				__reserved_1	: 4,
  				vector		: 8,
  				__reserved_2	: 8,
  				dest_id		: 32;
  		};
  		__u64 low;
  	};
  
  	union {
  		struct {
  			__u64	sid		: 16,
  				sq		: 2,
  				svt		: 2,
  				__reserved_3	: 44;
  		};
  		__u64 high;
  	};
  };
423f08595   Thomas Gleixner   x86: Embedd irq_2...
112

d3f138106   Suresh Siddha   iommu: Rename the...
113
  #ifdef CONFIG_IRQ_REMAP
29b61be65   Suresh Siddha   x86, x2apic: clea...
114
  extern int intr_remapping_enabled;
937582382   Weidong Han   x86, intr-remap: ...
115
  extern int intr_remapping_supported(void);
41750d31f   Suresh Siddha   x86, x2apic: Enab...
116
  extern int enable_intr_remapping(void);
b24696bc5   Fenghua Yu   Intel IOMMU Suspe...
117
118
  extern void disable_intr_remapping(void);
  extern int reenable_intr_remapping(int);
29b61be65   Suresh Siddha   x86, x2apic: clea...
119

b6fcb33ad   Suresh Siddha   x64, x2apic/intr-...
120
121
122
123
124
125
  extern int get_irte(int irq, struct irte *entry);
  extern int modify_irte(int irq, struct irte *irte_modified);
  extern int alloc_irte(struct intel_iommu *iommu, int irq, u16 count);
  extern int set_irte_irq(int irq, struct intel_iommu *iommu, u16 index,
     			u16 sub_handle);
  extern int map_irq_to_irte_handle(int irq, u16 *sub_handle);
b6fcb33ad   Suresh Siddha   x64, x2apic/intr-...
126
  extern int free_irte(int irq);
75c46fa61   Suresh Siddha   x64, x2apic/intr-...
127
  extern struct intel_iommu *map_dev_to_ir(struct pci_dev *dev);
89027d35a   Suresh Siddha   x64, x2apic/intr-...
128
  extern struct intel_iommu *map_ioapic_to_ir(int apic);
20f3097bf   Suresh Siddha   intr-remap: gener...
129
  extern struct intel_iommu *map_hpet_to_ir(u8 id);
f007e99c8   Weidong Han   Intel-IOMMU, intr...
130
  extern int set_ioapic_sid(struct irte *irte, int apic);
20f3097bf   Suresh Siddha   intr-remap: gener...
131
  extern int set_hpet_sid(struct irte *irte, u8 id);
f007e99c8   Weidong Han   Intel-IOMMU, intr...
132
  extern int set_msi_sid(struct irte *irte, struct pci_dev *dev);
2ae210106   Suresh Siddha   x64, x2apic/intr-...
133
  #else
29b61be65   Suresh Siddha   x86, x2apic: clea...
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
  static inline int alloc_irte(struct intel_iommu *iommu, int irq, u16 count)
  {
  	return -1;
  }
  static inline int modify_irte(int irq, struct irte *irte_modified)
  {
  	return -1;
  }
  static inline int free_irte(int irq)
  {
  	return -1;
  }
  static inline int map_irq_to_irte_handle(int irq, u16 *sub_handle)
  {
  	return -1;
  }
  static inline int set_irte_irq(int irq, struct intel_iommu *iommu, u16 index,
  			       u16 sub_handle)
  {
  	return -1;
  }
  static inline struct intel_iommu *map_dev_to_ir(struct pci_dev *dev)
  {
  	return NULL;
  }
  static inline struct intel_iommu *map_ioapic_to_ir(int apic)
  {
  	return NULL;
  }
20f3097bf   Suresh Siddha   intr-remap: gener...
163
164
165
166
  static inline struct intel_iommu *map_hpet_to_ir(unsigned int hpet_id)
  {
  	return NULL;
  }
f007e99c8   Weidong Han   Intel-IOMMU, intr...
167
168
169
170
  static inline int set_ioapic_sid(struct irte *irte, int apic)
  {
  	return 0;
  }
20f3097bf   Suresh Siddha   intr-remap: gener...
171
172
173
174
  static inline int set_hpet_sid(struct irte *irte, u8 id)
  {
  	return -1;
  }
f007e99c8   Weidong Han   Intel-IOMMU, intr...
175
176
177
178
  static inline int set_msi_sid(struct irte *irte, struct pci_dev *dev)
  {
  	return 0;
  }
2ae210106   Suresh Siddha   x64, x2apic/intr-...
179
  #define intr_remapping_enabled		(0)
4917b284d   Randy Dunlap   dmar, x86: Use fu...
180

41750d31f   Suresh Siddha   x86, x2apic: Enab...
181
  static inline int enable_intr_remapping(void)
4917b284d   Randy Dunlap   dmar, x86: Use fu...
182
183
184
185
186
187
188
189
190
191
192
193
  {
  	return -1;
  }
  
  static inline void disable_intr_remapping(void)
  {
  }
  
  static inline int reenable_intr_remapping(int eim)
  {
  	return 0;
  }
2ae210106   Suresh Siddha   x64, x2apic/intr-...
194
  #endif
41750d31f   Suresh Siddha   x86, x2apic: Enab...
195
196
197
198
  enum {
  	IRQ_REMAP_XAPIC_MODE,
  	IRQ_REMAP_X2APIC_MODE,
  };
3460a6d9c   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
199
200
201
  /* Can't use the common MSI interrupt functions
   * since DMAR is not a pci device
   */
5c2837fba   Thomas Gleixner   dmar: Convert to ...
202
203
204
  struct irq_data;
  extern void dmar_msi_unmask(struct irq_data *data);
  extern void dmar_msi_mask(struct irq_data *data);
3460a6d9c   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
205
206
207
  extern void dmar_msi_read(int irq, struct msi_msg *msg);
  extern void dmar_msi_write(int irq, struct msi_msg *msg);
  extern int dmar_set_interrupt(struct intel_iommu *iommu);
1531a6a6b   Suresh Siddha   x86, dmar: start ...
208
  extern irqreturn_t dmar_fault(int irq, void *dev_id);
3460a6d9c   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
209
  extern int arch_setup_dmar_msi(unsigned int irq);
d3f138106   Suresh Siddha   iommu: Rename the...
210
  #ifdef CONFIG_INTEL_IOMMU
2ae210106   Suresh Siddha   x64, x2apic/intr-...
211
  extern int iommu_detected, no_iommu;
10e5247f4   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
212
  extern struct list_head dmar_rmrr_units;
10e5247f4   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
213
214
  struct dmar_rmrr_unit {
  	struct list_head list;		/* list of rmrr units	*/
1886e8a90   Suresh Siddha   x64, x2apic/intr-...
215
  	struct acpi_dmar_header *hdr;	/* ACPI header		*/
10e5247f4   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
216
217
218
219
220
  	u64	base_address;		/* reserved base address*/
  	u64	end_address;		/* reserved end address */
  	struct pci_dev **devices;	/* target devices */
  	int	devices_cnt;		/* target device count */
  };
ba3959276   Keshavamurthy, Anil S   Intel IOMMU: Inte...
221
222
  #define for_each_rmrr_units(rmrr) \
  	list_for_each_entry(rmrr, &dmar_rmrr_units, list)
aa5d2b515   Yu Zhao   VT-d: parse ATSR ...
223
224
225
226
227
228
229
230
  
  struct dmar_atsr_unit {
  	struct list_head list;		/* list of ATSR units */
  	struct acpi_dmar_header *hdr;	/* ACPI header */
  	struct pci_dev **devices;	/* target devices */
  	int devices_cnt;		/* target device count */
  	u8 include_all:1;		/* include all ports */
  };
318fe7df9   Suresh Siddha   iommu: Move IOMMU...
231
232
233
234
235
  int dmar_parse_rmrr_atsr_dev(void);
  extern int dmar_parse_one_rmrr(struct acpi_dmar_header *header);
  extern int dmar_parse_one_atsr(struct acpi_dmar_header *header);
  extern int dmar_parse_dev_scope(void *start, void *end, int *cnt,
  				struct pci_dev ***devices, u16 segment);
2ae210106   Suresh Siddha   x64, x2apic/intr-...
236
  extern int intel_iommu_init(void);
d3f138106   Suresh Siddha   iommu: Rename the...
237
  #else /* !CONFIG_INTEL_IOMMU: */
9d5ce73a6   FUJITA Tomonori   x86: intel-iommu:...
238
  static inline int intel_iommu_init(void) { return -ENODEV; }
318fe7df9   Suresh Siddha   iommu: Move IOMMU...
239
240
241
242
243
244
245
246
247
248
249
250
  static inline int dmar_parse_one_rmrr(struct acpi_dmar_header *header)
  {
  	return 0;
  }
  static inline int dmar_parse_one_atsr(struct acpi_dmar_header *header)
  {
  	return 0;
  }
  static inline int dmar_parse_rmrr_atsr_dev(void)
  {
  	return 0;
  }
d3f138106   Suresh Siddha   iommu: Rename the...
251
  #endif /* CONFIG_INTEL_IOMMU */
9d5ce73a6   FUJITA Tomonori   x86: intel-iommu:...
252

10e5247f4   Keshavamurthy, Anil S   Intel IOMMU: DMAR...
253
  #endif /* __DMAR_H__ */