From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from smtp2.linux-foundation.org ([207.189.120.14]:54073 "EHLO smtp2.linux-foundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756607AbXHGTUv (ORCPT ); Tue, 7 Aug 2007 15:20:51 -0400 Date: Tue, 7 Aug 2007 12:20:08 -0700 From: Andrew Morton Subject: Re: [patch 3/3] mm: variable length argument support Message-Id: <20070807122008.fcd175d6.akpm@linux-foundation.org> In-Reply-To: <20070807190357.GA31139@aepfle.de> References: <20070613100334.635756997@chello.nl> <20070613100835.014096712@chello.nl> <20070807190357.GA31139@aepfle.de> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-arch-owner@vger.kernel.org To: Olaf Hering Cc: Peter Zijlstra , linux-kernel@vger.kernel.org, parisc-linux@lists.parisc-linux.org, linux-mm@kvack.org, linux-arch@vger.kernel.org, Ollie Wild , Ingo Molnar , Andi Kleen List-ID: On Tue, 7 Aug 2007 21:03:57 +0200 Olaf Hering wrote: > On Wed, Jun 13, Peter Zijlstra wrote: > > > From: Ollie Wild > > > > Remove the arg+env limit of MAX_ARG_PAGES by copying the strings directly > > from the old mm into the new mm. > > > +++ linux-2.6-2/include/linux/binfmts.h 2007-06-13 11:52:46.000000000 +0200 > > @@ -6,11 +6,13 @@ > > struct pt_regs; > > > > /* > > - * MAX_ARG_PAGES defines the number of pages allocated for arguments > > - * and envelope for the new program. 32 should suffice, this gives > > - * a maximum env+arg of 128kB w/4KB pages! > > + * These are the maximum length and maximum number of strings passed to the > > + * execve() system call. MAX_ARG_STRLEN is essentially random but serves to > > + * prevent the kernel from being unduly impacted by misaddressed pointers. > > + * MAX_ARG_STRINGS is chosen to fit in a signed 32-bit integer. > > */ > > -#define MAX_ARG_PAGES 32 > > +#define MAX_ARG_STRLEN (PAGE_SIZE * 32) > > +#define MAX_ARG_STRINGS 0x7FFFFFFF > > This adds a new usage of PAGE_SIZE to an exported header. > How can this be fixed for 2.6.23? Put #ifdef __KERNEL__ around it?