Browse Source

x86: cpa: clean up change_page_attr_set/clear()

Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Thomas Gleixner 17 years ago
parent
commit
6eade8ff46
1 changed files with 9 additions and 8 deletions
  1. 9 8
      arch/x86/mm/pageattr.c

+ 9 - 8
arch/x86/mm/pageattr.c

@@ -312,10 +312,10 @@ static int change_page_attr_set(unsigned long addr, int numpages,
 	for (i = 0; i < numpages ; i++) {
 	for (i = 0; i < numpages ; i++) {
 
 
 		pte = lookup_address(addr, &level);
 		pte = lookup_address(addr, &level);
-		if (pte)
-			current_prot = pte_pgprot(*pte);
-		else
-			pgprot_val(current_prot) = 0;
+		if (!pte)
+			return -EINVAL;
+
+		current_prot = pte_pgprot(*pte);
 
 
 		pgprot_val(new_prot) =
 		pgprot_val(new_prot) =
 			pgprot_val(current_prot) | pgprot_val(prot);
 			pgprot_val(current_prot) | pgprot_val(prot);
@@ -356,11 +356,12 @@ static int change_page_attr_clear(unsigned long addr, int numpages,
 	int i, ret;
 	int i, ret;
 
 
 	for (i = 0; i < numpages; i++) {
 	for (i = 0; i < numpages; i++) {
+
 		pte = lookup_address(addr, &level);
 		pte = lookup_address(addr, &level);
-		if (pte)
-			current_prot = pte_pgprot(*pte);
-		else
-			pgprot_val(current_prot) = 0;
+		if (!pte)
+			return -EINVAL;
+
+		current_prot = pte_pgprot(*pte);
 
 
 		pgprot_val(new_prot) =
 		pgprot_val(new_prot) =
 				pgprot_val(current_prot) & ~pgprot_val(prot);
 				pgprot_val(current_prot) & ~pgprot_val(prot);