diff options
Diffstat (limited to 'drivers/pci/intel-iommu.c')
-rw-r--r-- | drivers/pci/intel-iommu.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/drivers/pci/intel-iommu.c b/drivers/pci/intel-iommu.c index 29bf2d8176e2..9d06f4bb6b5e 100644 --- a/drivers/pci/intel-iommu.c +++ b/drivers/pci/intel-iommu.c | |||
@@ -90,6 +90,44 @@ get_context_addr_from_root(struct root_entry *root) | |||
90 | NULL); | 90 | NULL); |
91 | } | 91 | } |
92 | 92 | ||
93 | /* | ||
94 | * low 64 bits: | ||
95 | * 0: present | ||
96 | * 1: fault processing disable | ||
97 | * 2-3: translation type | ||
98 | * 12-63: address space root | ||
99 | * high 64 bits: | ||
100 | * 0-2: address width | ||
101 | * 3-6: aval | ||
102 | * 8-23: domain id | ||
103 | */ | ||
104 | struct context_entry { | ||
105 | u64 lo; | ||
106 | u64 hi; | ||
107 | }; | ||
108 | #define context_present(c) ((c).lo & 1) | ||
109 | #define context_fault_disable(c) (((c).lo >> 1) & 1) | ||
110 | #define context_translation_type(c) (((c).lo >> 2) & 3) | ||
111 | #define context_address_root(c) ((c).lo & VTD_PAGE_MASK) | ||
112 | #define context_address_width(c) ((c).hi & 7) | ||
113 | #define context_domain_id(c) (((c).hi >> 8) & ((1 << 16) - 1)) | ||
114 | |||
115 | #define context_set_present(c) do {(c).lo |= 1;} while (0) | ||
116 | #define context_set_fault_enable(c) \ | ||
117 | do {(c).lo &= (((u64)-1) << 2) | 1;} while (0) | ||
118 | #define context_set_translation_type(c, val) \ | ||
119 | do { \ | ||
120 | (c).lo &= (((u64)-1) << 4) | 3; \ | ||
121 | (c).lo |= ((val) & 3) << 2; \ | ||
122 | } while (0) | ||
123 | #define CONTEXT_TT_MULTI_LEVEL 0 | ||
124 | #define context_set_address_root(c, val) \ | ||
125 | do {(c).lo |= (val) & VTD_PAGE_MASK; } while (0) | ||
126 | #define context_set_address_width(c, val) do {(c).hi |= (val) & 7;} while (0) | ||
127 | #define context_set_domain_id(c, val) \ | ||
128 | do {(c).hi |= ((val) & ((1 << 16) - 1)) << 8;} while (0) | ||
129 | #define context_clear_entry(c) do {(c).lo = 0; (c).hi = 0;} while (0) | ||
130 | |||
93 | static void flush_unmaps_timeout(unsigned long data); | 131 | static void flush_unmaps_timeout(unsigned long data); |
94 | 132 | ||
95 | DEFINE_TIMER(unmap_timer, flush_unmaps_timeout, 0, 0); | 133 | DEFINE_TIMER(unmap_timer, flush_unmaps_timeout, 0, 0); |