[ppc64] prevent infinite loop on icache sync
At moea64_sync_icache(), when the 'va' argument has page size alignment, round_page() will return the same value as 'va'. This would cause 'len' to be 0 and thus an infinite loop. With this change, 'lim' will always point to the next page boundary. This issue occurred especially during debugging sessions, when a breakpoint was placed on an exact page-aligned offset, for instance. Reviewed by: jhibbits Differential Revision: https://reviews.freebsd.org/D19149
This commit is contained in:
parent
aef0641755
commit
b8efbfb9d3
@ -2807,7 +2807,7 @@ moea64_sync_icache(mmu_t mmu, pmap_t pm, vm_offset_t va, vm_size_t sz)
|
||||
|
||||
PMAP_LOCK(pm);
|
||||
while (sz > 0) {
|
||||
lim = round_page(va);
|
||||
lim = round_page(va+1);
|
||||
len = MIN(lim - va, sz);
|
||||
pvo = moea64_pvo_find_va(pm, va & ~ADDR_POFF);
|
||||
if (pvo != NULL && !(pvo->pvo_pte.pa & LPTE_I)) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user