Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753151Ab3GGTbm (ORCPT ); Sun, 7 Jul 2013 15:31:42 -0400 Received: from mx1.redhat.com ([209.132.183.28]:2808 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753043Ab3GGTbl (ORCPT ); Sun, 7 Jul 2013 15:31:41 -0400 Message-ID: <51D9C217.5030507@redhat.com> Date: Sun, 07 Jul 2013 15:31:35 -0400 From: Rik van Riel User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:17.0) Gecko/20130402 Thunderbird/17.0.5 MIME-Version: 1.0 To: Raymond Jennings CC: Valdis Kletnieks , linux-kernel@vger.kernel.org, linux-mm@kvack.org, Andrew Morton Subject: Re: [PATCH v2] swap: warn when a swap area overflows the maximum size References: <1373197450.26573.5.camel@warfang> <1373197978.26573.7.camel@warfang> <1373224421.26573.11.camel@warfang> In-Reply-To: <1373224421.26573.11.camel@warfang> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2584 Lines: 77 On 07/07/2013 03:13 PM, Raymond Jennings wrote: > Turned the comparison around for clarity of "bigger than" > > No semantic changes, if it still compiles it should do the same thing so > I've omitted the testing this time. Will be happy to retest if required > but I'm on an atom 330 and kernel rebuilds are a nightmare. Added CC: Andrew Morton, since this should probably go into -mm :) > ---- > > swap: warn when a swap area overflows the maximum size > > It is possible to swapon a swap area that is too big for the pte width > to handle. > > Presently this failure happens silently. > > Instead, emit a diagnostic to warn the user. > > Signed-off-by: Raymond Jennings > Acked-by: Valdis Kletnieks Reviewed-by: Rik van Riel > diff --git a/mm/swapfile.c b/mm/swapfile.c > index 36af6ee..5a4ce53 100644 > --- a/mm/swapfile.c > +++ b/mm/swapfile.c > @@ -1953,6 +1953,12 @@ static unsigned long read_swap_header(struct > swap_info_struct *p, > */ > maxpages = swp_offset(pte_to_swp_entry( > swp_entry_to_pte(swp_entry(0, ~0UL)))) + 1; > + if (swap_header->info.last_page > maxpages) { > + printk(KERN_WARNING > + "Truncating oversized swap area, only using %luk > out of %luk > \n", > + maxpages << (PAGE_SHIFT - 10), > + swap_header->info.last_page << (PAGE_SHIFT - > 10)); > + } > if (maxpages > swap_header->info.last_page) { > maxpages = swap_header->info.last_page + 1; > /* p->max is an unsigned int: don't overflow it */ > > ---- > > Testing results, root prompt commands and kernel log messages: > > # lvresize /dev/system/swap --size 16G > # mkswap /dev/system/swap > # swapon /dev/system/swap > > Jul 7 04:27:22 warfang kernel: Adding 16777212k swap > on /dev/mapper/system-swap. Priority:-1 extents:1 across:16777212k > > # lvresize /dev/system/swap --size 16G > # mkswap /dev/system/swap > # swapon /dev/system/swap > > Jul 7 04:27:22 warfang kernel: Truncating oversized swap area, only > using 33554432k out of 67108860k > Jul 7 04:27:22 warfang kernel: Adding 33554428k swap > on /dev/mapper/system-swap. Priority:-1 extents:1 across:33554428k > > -- All rights reversed -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/