mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	arm64: enable PTE type bit in the mask for pte_modify
Caught during Trinity testing. The pte_modify does not allow modification for PTE type bit. This cause the test to hang the system. It is found that the PTE can't transit from an inaccessible page (b00) to a valid page (b11) because the mask does not allow it. This happens when a big block of mmaped memory is set the PROT_NONE, then the a small piece is broken off and set to PROT_WRITE | PROT_READ cause a huge page split. Signed-off-by: Feng Kan <fkan@apm.com> Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
This commit is contained in:
		
							parent
							
								
									06ff87bae8
								
							
						
					
					
						commit
						6910fa16db
					
				| @ -460,7 +460,7 @@ static inline pud_t *pud_offset(pgd_t *pgd, unsigned long addr) | |||||||
| static inline pte_t pte_modify(pte_t pte, pgprot_t newprot) | static inline pte_t pte_modify(pte_t pte, pgprot_t newprot) | ||||||
| { | { | ||||||
| 	const pteval_t mask = PTE_USER | PTE_PXN | PTE_UXN | PTE_RDONLY | | 	const pteval_t mask = PTE_USER | PTE_PXN | PTE_UXN | PTE_RDONLY | | ||||||
| 			      PTE_PROT_NONE | PTE_VALID | PTE_WRITE; | 			      PTE_PROT_NONE | PTE_WRITE | PTE_TYPE_MASK; | ||||||
| 	pte_val(pte) = (pte_val(pte) & ~mask) | (pgprot_val(newprot) & mask); | 	pte_val(pte) = (pte_val(pte) & ~mask) | (pgprot_val(newprot) & mask); | ||||||
| 	return pte; | 	return pte; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Feng Kan
						Feng Kan