Re: [PATCH 1/2] Check PageUnevictable in lru_deactivate_fn

From: Minchan Kim
Date: Sun May 01 2011 - 19:00:51 EST


On Mon, May 2, 2011 at 7:10 AM, Ying Han <yinghan@xxxxxxxxxx> wrote:
> On Sun, May 1, 2011 at 8:03 AM, Minchan Kim <minchan.kim@xxxxxxxxx> wrote:
>> The lru_deactivate_fn should not move page which in on unevictable lru
>> into inactive list. Otherwise, we can meet BUG when we use isolate_lru_pages
>> as __isolate_lru_page could return -EINVAL.
>> It's really BUG and let's fix it.
>>
>> Reported-by: Ying Han <yinghan@xxxxxxxxxx>
>> Tested-by: Ying Han <yinghan@xxxxxxxxxx>
>> Signed-off-by: Minchan Kim <minchan.kim@xxxxxxxxx>
>> ---
>> Âmm/swap.c | Â Â3 +++
>> Â1 files changed, 3 insertions(+), 0 deletions(-)
>>
>> diff --git a/mm/swap.c b/mm/swap.c
>> index a83ec5a..2e9656d 100644
>> --- a/mm/swap.c
>> +++ b/mm/swap.c
>> @@ -429,6 +429,9 @@ static void lru_deactivate_fn(struct page *page, void *arg)
>> Â Â Â Âif (!PageLRU(page))
>> Â Â Â Â Â Â Â Âreturn;
>>
>> + Â Â Â if (PageUnevictable(page))
>> + Â Â Â Â Â Â Â return;
>> +
>> Â Â Â Â/* Some processes are using the page */
>> Â Â Â Âif (page_mapped(page))
>> Â Â Â Â Â Â Â Âreturn;
>> --
>> 1.7.1
>
> Thanks Minchan for the fix, and i haven't been able to reproducing the
> issue after applying the patch.

Thanks for the help, Ying.

--
Kind regards,
Minchan Kim
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/