blob: 546ad3110feaef59c2a607e98593d8e38f17b272 [file] [log] [blame]
Vegard Nossum77ef50a2008-06-18 17:08:48 +02001#ifndef ASM_X86__IOMMU_H
2#define ASM_X86__IOMMU_H
Yinghai Luf2cf8e02007-07-21 17:11:31 +02003
4extern void pci_iommu_shutdown(void);
5extern void no_iommu_init(void);
Alexis Bruemmer1956a962008-07-25 19:44:51 -07006extern struct dma_mapping_ops nommu_dma_ops;
Yinghai Luf2cf8e02007-07-21 17:11:31 +02007extern int force_iommu, no_iommu;
8extern int iommu_detected;
David Woodhousee51af662008-09-04 09:54:37 +01009extern int dmar_disabled;
FUJITA Tomonorie93be882008-07-10 08:27:49 +090010
FUJITA Tomonori8978b742008-07-29 13:38:53 +090011extern unsigned long iommu_num_pages(unsigned long addr, unsigned long len);
12
FUJITA Tomonori8cbfd4f42008-07-09 16:29:41 +090013#ifdef CONFIG_GART_IOMMU
FUJITA Tomonorie93be882008-07-10 08:27:49 +090014extern int gart_iommu_aperture;
15extern int gart_iommu_aperture_allowed;
16extern int gart_iommu_aperture_disabled;
17
18extern void early_gart_iommu_check(void);
Yinghai Luf2cf8e02007-07-21 17:11:31 +020019extern void gart_iommu_init(void);
20extern void gart_iommu_shutdown(void);
21extern void __init gart_parse_options(char *);
FUJITA Tomonorie93be882008-07-10 08:27:49 +090022extern void gart_iommu_hole_init(void);
23
Yinghai Luf2cf8e02007-07-21 17:11:31 +020024#else
FUJITA Tomonorie93be882008-07-10 08:27:49 +090025#define gart_iommu_aperture 0
26#define gart_iommu_aperture_allowed 0
27#define gart_iommu_aperture_disabled 1
28
29static inline void early_gart_iommu_check(void)
30{
31}
FUJITA Tomonoriac7ded22008-07-11 10:23:43 +090032static inline void gart_iommu_init(void)
33{
34}
Yinghai Luf2cf8e02007-07-21 17:11:31 +020035static inline void gart_iommu_shutdown(void)
36{
37}
FUJITA Tomonoriac7ded22008-07-11 10:23:43 +090038static inline void gart_parse_options(char *options)
39{
40}
41static inline void gart_iommu_hole_init(void)
42{
43}
Yinghai Luf2cf8e02007-07-21 17:11:31 +020044#endif
45
Vegard Nossum77ef50a2008-06-18 17:08:48 +020046#endif /* ASM_X86__IOMMU_H */