Skip to content

Commit 8195d86

Browse files
joergroedelKAGA-KOKO
authored andcommitted
x86/ldt: Define LDT_END_ADDR
It marks the end of the address-space range reserved for the LDT. The LDT-code will use it when unmapping the LDT for user-space. Signed-off-by: Joerg Roedel <jroedel@suse.de> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Tested-by: Pavel Machek <pavel@ucw.cz> Cc: "H . Peter Anvin" <hpa@zytor.com> Cc: linux-mm@kvack.org Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Andy Lutomirski <luto@kernel.org> Cc: Dave Hansen <dave.hansen@intel.com> Cc: Josh Poimboeuf <jpoimboe@redhat.com> Cc: Juergen Gross <jgross@suse.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Borislav Petkov <bp@alien8.de> Cc: Jiri Kosina <jkosina@suse.cz> Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com> Cc: Brian Gerst <brgerst@gmail.com> Cc: David Laight <David.Laight@aculab.com> Cc: Denys Vlasenko <dvlasenk@redhat.com> Cc: Eduardo Valentin <eduval@amazon.com> Cc: Greg KH <gregkh@linuxfoundation.org> Cc: Will Deacon <will.deacon@arm.com> Cc: aliguori@amazon.com Cc: daniel.gruss@iaik.tugraz.at Cc: hughd@google.com Cc: keescook@google.com Cc: Andrea Arcangeli <aarcange@redhat.com> Cc: Waiman Long <llong@redhat.com> Cc: "David H . Gutteridge" <dhgutteridge@sympatico.ca> Cc: joro@8bytes.org Link: https://lkml.kernel.org/r/1531906876-13451-35-git-send-email-joro@8bytes.org
1 parent f3e48e5 commit 8195d86

File tree

3 files changed

+4
-1
lines changed

3 files changed

+4
-1
lines changed

arch/x86/include/asm/pgtable_32_types.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -53,6 +53,8 @@ extern bool __vmalloc_start_set; /* set once high_memory is set */
5353
#define LDT_BASE_ADDR \
5454
((CPU_ENTRY_AREA_BASE - PAGE_SIZE) & PMD_MASK)
5555

56+
#define LDT_END_ADDR (LDT_BASE_ADDR + PMD_SIZE)
57+
5658
#define PKMAP_BASE \
5759
((LDT_BASE_ADDR - PAGE_SIZE) & PMD_MASK)
5860

arch/x86/include/asm/pgtable_64_types.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -115,6 +115,7 @@ extern unsigned int ptrs_per_p4d;
115115
#define LDT_PGD_ENTRY_L5 -112UL
116116
#define LDT_PGD_ENTRY (pgtable_l5_enabled() ? LDT_PGD_ENTRY_L5 : LDT_PGD_ENTRY_L4)
117117
#define LDT_BASE_ADDR (LDT_PGD_ENTRY << PGDIR_SHIFT)
118+
#define LDT_END_ADDR (LDT_BASE_ADDR + PGDIR_SIZE)
118119

119120
#define __VMALLOC_BASE_L4 0xffffc90000000000UL
120121
#define __VMALLOC_BASE_L5 0xffa0000000000000UL

arch/x86/kernel/ldt.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -206,7 +206,7 @@ static void free_ldt_pgtables(struct mm_struct *mm)
206206
#ifdef CONFIG_PAGE_TABLE_ISOLATION
207207
struct mmu_gather tlb;
208208
unsigned long start = LDT_BASE_ADDR;
209-
unsigned long end = start + (1UL << PGDIR_SHIFT);
209+
unsigned long end = LDT_END_ADDR;
210210

211211
if (!static_cpu_has(X86_FEATURE_PTI))
212212
return;

0 commit comments

Comments
 (0)