|
@@ -933,13 +933,15 @@ int pud_set_huge(pud_t *pudp, phys_addr_t phys, pgprot_t prot)
|
|
|
{
|
|
|
pgprot_t sect_prot = __pgprot(PUD_TYPE_SECT |
|
|
|
pgprot_val(mk_sect_prot(prot)));
|
|
|
+ pud_t new_pud = pfn_pud(__phys_to_pfn(phys), sect_prot);
|
|
|
|
|
|
- /* ioremap_page_range doesn't honour BBM */
|
|
|
- if (pud_present(READ_ONCE(*pudp)))
|
|
|
+ /* Only allow permission changes for now */
|
|
|
+ if (!pgattr_change_is_safe(READ_ONCE(pud_val(*pudp)),
|
|
|
+ pud_val(new_pud)))
|
|
|
return 0;
|
|
|
|
|
|
BUG_ON(phys & ~PUD_MASK);
|
|
|
- set_pud(pudp, pfn_pud(__phys_to_pfn(phys), sect_prot));
|
|
|
+ set_pud(pudp, new_pud);
|
|
|
return 1;
|
|
|
}
|
|
|
|
|
@@ -947,13 +949,15 @@ int pmd_set_huge(pmd_t *pmdp, phys_addr_t phys, pgprot_t prot)
|
|
|
{
|
|
|
pgprot_t sect_prot = __pgprot(PMD_TYPE_SECT |
|
|
|
pgprot_val(mk_sect_prot(prot)));
|
|
|
+ pmd_t new_pmd = pfn_pmd(__phys_to_pfn(phys), sect_prot);
|
|
|
|
|
|
- /* ioremap_page_range doesn't honour BBM */
|
|
|
- if (pmd_present(READ_ONCE(*pmdp)))
|
|
|
+ /* Only allow permission changes for now */
|
|
|
+ if (!pgattr_change_is_safe(READ_ONCE(pmd_val(*pmdp)),
|
|
|
+ pmd_val(new_pmd)))
|
|
|
return 0;
|
|
|
|
|
|
BUG_ON(phys & ~PMD_MASK);
|
|
|
- set_pmd(pmdp, pfn_pmd(__phys_to_pfn(phys), sect_prot));
|
|
|
+ set_pmd(pmdp, new_pmd);
|
|
|
return 1;
|
|
|
}
|
|
|
|