Re: [PATCH] mm: fix potential pte_unmap_unlock pte error

From: Michal Hocko
Date: Fri Oct 16 2020 - 09:11:18 EST


On Fri 16-10-20 14:37:08, osalvador@xxxxxxx wrote:
> On 2020-10-16 14:31, Michal Hocko wrote:
> > I do not like the fix though. The code is really confusing. Why should
> > we check for flags in each iteration of the loop when it cannot change?
> > Also why should we take the ptl lock in the first place when the look is
> > broken out immediately?
>
> About checking the flags:
>
> https://lore.kernel.org/linux-mm/20190320081643.3c4m5tec5vx653sn@xxxxxxxxxxxx/#t

This didn't really help. Maybe the code was different back then but
right now the code doesn't make much sense TBH. The only reason to check
inside the loop would be to have a completely unpopulated address range.
Note about MPOL_MF_STRICT is not checked explicitly and I do not see how
it makes any difference.

Anyway this function would benefit from some uncluttering!

--
Michal Hocko
SUSE Labs