diff options
Diffstat (limited to 'arch/x86/mm/init_32.c')
| -rw-r--r-- | arch/x86/mm/init_32.c | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/arch/x86/mm/init_32.c b/arch/x86/mm/init_32.c index 0e969f9f401b..f89b5bb4e93f 100644 --- a/arch/x86/mm/init_32.c +++ b/arch/x86/mm/init_32.c | |||
| @@ -226,7 +226,7 @@ page_table_range_init(unsigned long start, unsigned long end, pgd_t *pgd_base) | |||
| 226 | 226 | ||
| 227 | static inline int is_kernel_text(unsigned long addr) | 227 | static inline int is_kernel_text(unsigned long addr) |
| 228 | { | 228 | { |
| 229 | if (addr >= PAGE_OFFSET && addr <= (unsigned long)__init_end) | 229 | if (addr >= (unsigned long)_text && addr <= (unsigned long)__init_end) |
| 230 | return 1; | 230 | return 1; |
| 231 | return 0; | 231 | return 0; |
| 232 | } | 232 | } |
| @@ -912,6 +912,23 @@ void set_kernel_text_ro(void) | |||
| 912 | set_pages_ro(virt_to_page(start), size >> PAGE_SHIFT); | 912 | set_pages_ro(virt_to_page(start), size >> PAGE_SHIFT); |
| 913 | } | 913 | } |
| 914 | 914 | ||
| 915 | static void mark_nxdata_nx(void) | ||
| 916 | { | ||
| 917 | /* | ||
| 918 | * When this called, init has already been executed and released, | ||
| 919 | * so everything past _etext sould be NX. | ||
| 920 | */ | ||
| 921 | unsigned long start = PFN_ALIGN(_etext); | ||
| 922 | /* | ||
| 923 | * This comes from is_kernel_text upper limit. Also HPAGE where used: | ||
| 924 | */ | ||
| 925 | unsigned long size = (((unsigned long)__init_end + HPAGE_SIZE) & HPAGE_MASK) - start; | ||
| 926 | |||
| 927 | if (__supported_pte_mask & _PAGE_NX) | ||
| 928 | printk(KERN_INFO "NX-protecting the kernel data: %luk\n", size >> 10); | ||
| 929 | set_pages_nx(virt_to_page(start), size >> PAGE_SHIFT); | ||
| 930 | } | ||
| 931 | |||
| 915 | void mark_rodata_ro(void) | 932 | void mark_rodata_ro(void) |
| 916 | { | 933 | { |
| 917 | unsigned long start = PFN_ALIGN(_text); | 934 | unsigned long start = PFN_ALIGN(_text); |
| @@ -946,6 +963,7 @@ void mark_rodata_ro(void) | |||
| 946 | printk(KERN_INFO "Testing CPA: write protecting again\n"); | 963 | printk(KERN_INFO "Testing CPA: write protecting again\n"); |
| 947 | set_pages_ro(virt_to_page(start), size >> PAGE_SHIFT); | 964 | set_pages_ro(virt_to_page(start), size >> PAGE_SHIFT); |
| 948 | #endif | 965 | #endif |
| 966 | mark_nxdata_nx(); | ||
| 949 | } | 967 | } |
| 950 | #endif | 968 | #endif |
| 951 | 969 | ||
