aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/mm/init_32.c
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2008-01-30 07:34:07 -0500
committerIngo Molnar <mingo@elte.hu>2008-01-30 07:34:07 -0500
commitd7c8f21a8cad0228c7c5ce2bb6dbd95d1ee49d13 (patch)
treed1e305bec62022a0bec82a3499a372c2c7c40583 /arch/x86/mm/init_32.c
parentd1028a154c65d7fadd1b2d0276c077014d401ec7 (diff)
x86: cpa: move flush to cpa
The set_memory_* and set_pages_* family of API's currently requires the callers to do a global tlb flush after the function call; forgetting this is a very nasty deathtrap. This patch moves the global tlb flush into each of the callers Signed-off-by: Arjan van de Ven <arjan@linux.intel.com> Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'arch/x86/mm/init_32.c')
-rw-r--r--arch/x86/mm/init_32.c14
1 files changed, 0 insertions, 14 deletions
diff --git a/arch/x86/mm/init_32.c b/arch/x86/mm/init_32.c
index f7b941c3b2c3..0d3369b900e9 100644
--- a/arch/x86/mm/init_32.c
+++ b/arch/x86/mm/init_32.c
@@ -752,15 +752,11 @@ void mark_rodata_ro(void)
752 printk("Write protecting the kernel text: %luk\n", size >> 10); 752 printk("Write protecting the kernel text: %luk\n", size >> 10);
753 753
754#ifdef CONFIG_CPA_DEBUG 754#ifdef CONFIG_CPA_DEBUG
755 global_flush_tlb();
756
757 printk("Testing CPA: Reverting %lx-%lx\n", start, start+size); 755 printk("Testing CPA: Reverting %lx-%lx\n", start, start+size);
758 set_pages_rw(virt_to_page(start), size>>PAGE_SHIFT); 756 set_pages_rw(virt_to_page(start), size>>PAGE_SHIFT);
759 global_flush_tlb();
760 757
761 printk("Testing CPA: write protecting again\n"); 758 printk("Testing CPA: write protecting again\n");
762 set_pages_ro(virt_to_page(start), size>>PAGE_SHIFT); 759 set_pages_ro(virt_to_page(start), size>>PAGE_SHIFT);
763 global_flush_tlb();
764#endif 760#endif
765 } 761 }
766#endif 762#endif
@@ -770,22 +766,12 @@ void mark_rodata_ro(void)
770 printk("Write protecting the kernel read-only data: %luk\n", 766 printk("Write protecting the kernel read-only data: %luk\n",
771 size >> 10); 767 size >> 10);
772 768
773 /*
774 * set_pages_*() requires a global_flush_tlb() call after it.
775 * We do this after the printk so that if something went wrong in the
776 * change, the printk gets out at least to give a better debug hint
777 * of who is the culprit.
778 */
779 global_flush_tlb();
780
781#ifdef CONFIG_CPA_DEBUG 769#ifdef CONFIG_CPA_DEBUG
782 printk("Testing CPA: undo %lx-%lx\n", start, start + size); 770 printk("Testing CPA: undo %lx-%lx\n", start, start + size);
783 set_pages_rw(virt_to_page(start), size >> PAGE_SHIFT); 771 set_pages_rw(virt_to_page(start), size >> PAGE_SHIFT);
784 global_flush_tlb();
785 772
786 printk("Testing CPA: write protecting again\n"); 773 printk("Testing CPA: write protecting again\n");
787 set_pages_ro(virt_to_page(start), size >> PAGE_SHIFT); 774 set_pages_ro(virt_to_page(start), size >> PAGE_SHIFT);
788 global_flush_tlb();
789#endif 775#endif
790} 776}
791#endif 777#endif