diff options
-rw-r--r-- | include/asm-x86_64/desc.h | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/include/asm-x86_64/desc.h b/include/asm-x86_64/desc.h index 68ac3c62fe3..b837820c907 100644 --- a/include/asm-x86_64/desc.h +++ b/include/asm-x86_64/desc.h | |||
@@ -129,9 +129,16 @@ static inline void set_tssldt_descriptor(void *ptr, unsigned long tss, unsigned | |||
129 | 129 | ||
130 | static inline void set_tss_desc(unsigned cpu, void *addr) | 130 | static inline void set_tss_desc(unsigned cpu, void *addr) |
131 | { | 131 | { |
132 | set_tssldt_descriptor(&cpu_gdt_table[cpu][GDT_ENTRY_TSS], (unsigned long)addr, | 132 | /* |
133 | DESC_TSS, | 133 | * sizeof(unsigned long) coming from an extra "long" at the end |
134 | sizeof(struct tss_struct) - 1); | 134 | * of the iobitmap. See tss_struct definition in processor.h |
135 | * | ||
136 | * -1? seg base+limit should be pointing to the address of the | ||
137 | * last valid byte | ||
138 | */ | ||
139 | set_tssldt_descriptor(&cpu_gdt_table[cpu][GDT_ENTRY_TSS], | ||
140 | (unsigned long)addr, DESC_TSS, | ||
141 | IO_BITMAP_OFFSET + IO_BITMAP_BYTES + sizeof(unsigned long) - 1); | ||
135 | } | 142 | } |
136 | 143 | ||
137 | static inline void set_ldt_desc(unsigned cpu, void *addr, int size) | 144 | static inline void set_ldt_desc(unsigned cpu, void *addr, int size) |