Merge tag 'v3.3.7' into 3.3/master
[zen-stable.git] / arch / s390 / mm / pageattr.c
blobb36537a5f43e33e3a1a6cc9907efcf3920e8d583
1 /*
2 * Copyright IBM Corp. 2011
3 * Author(s): Jan Glauber <jang@linux.vnet.ibm.com>
4 */
5 #include <linux/module.h>
6 #include <linux/mm.h>
7 #include <linux/hugetlb.h>
8 #include <asm/cacheflush.h>
9 #include <asm/pgtable.h>
11 static void change_page_attr(unsigned long addr, int numpages,
12 pte_t (*set) (pte_t))
14 pte_t *ptep, pte;
15 pmd_t *pmdp;
16 pud_t *pudp;
17 pgd_t *pgdp;
18 int i;
20 for (i = 0; i < numpages; i++) {
21 pgdp = pgd_offset(&init_mm, addr);
22 pudp = pud_offset(pgdp, addr);
23 pmdp = pmd_offset(pudp, addr);
24 if (pmd_huge(*pmdp)) {
25 WARN_ON_ONCE(1);
26 continue;
28 ptep = pte_offset_kernel(pmdp, addr);
30 pte = *ptep;
31 pte = set(pte);
32 __ptep_ipte(addr, ptep);
33 *ptep = pte;
34 addr += PAGE_SIZE;
38 int set_memory_ro(unsigned long addr, int numpages)
40 change_page_attr(addr, numpages, pte_wrprotect);
41 return 0;
43 EXPORT_SYMBOL_GPL(set_memory_ro);
45 int set_memory_rw(unsigned long addr, int numpages)
47 change_page_attr(addr, numpages, pte_mkwrite);
48 return 0;
50 EXPORT_SYMBOL_GPL(set_memory_rw);
52 /* not possible */
53 int set_memory_nx(unsigned long addr, int numpages)
55 return 0;
57 EXPORT_SYMBOL_GPL(set_memory_nx);
59 int set_memory_x(unsigned long addr, int numpages)
61 return 0;