From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from viefep18-int.chello.at ([213.46.255.22]:36786 "EHLO viefep12-int.chello.at" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1750957AbXFNVSZ (ORCPT ); Thu, 14 Jun 2007 17:18:25 -0400 Subject: Re: [patch 0/3] no MAX_ARG_PAGES -v2 From: Peter Zijlstra In-Reply-To: <65dd6fd50706141358i39bba32aq139766c8a1a3de2b@mail.gmail.com> References: <20070613100334.635756997@chello.nl> <617E1C2C70743745A92448908E030B2A01AF860A@scsmsx411.amr.corp.intel.com> <65dd6fd50706132323i9c760f4m6e23687914d0c46e@mail.gmail.com> <1181810319.7348.345.camel@twins> <65dd6fd50706141358i39bba32aq139766c8a1a3de2b@mail.gmail.com> Content-Type: text/plain Date: Thu, 14 Jun 2007 23:18:00 +0200 Message-Id: <1181855880.5806.5.camel@lappy> Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-arch-owner@vger.kernel.org To: Ollie Wild Cc: "Luck, Tony" , linux-kernel@vger.kernel.org, parisc-linux@lists.parisc-linux.org, linux-mm@kvack.org, linux-arch@vger.kernel.org, Andrew Morton , Ingo Molnar , Andi Kleen List-ID: On Thu, 2007-06-14 at 13:58 -0700, Ollie Wild wrote: > > @@ -1385,6 +1401,10 @@ int do_execve(char * filename, > > goto out; > > bprm->argv_len = env_p - bprm->p; > > > > + retval = expand_arg_vma(bprm); > > + if (retval < 0) > > + goto out; > > + > > retval = search_binary_handler(bprm,regs); > > if (retval >= 0) { > > /* execve success */ > > At this point bprm->argc hasn't been finalized yet. For example, the > script binfmt reads the script header and adds additional arguments. > The flush_old_exec() function is a better place to call this. Sure, but at this time most of it is there, so when there are many, this allocates the most of it. > I'm not 100% sure this is the right way to handle this, though. The > problem isn't as simple as ensuring the stack doesn't overflow during > argument allocation. We also need to ensure the program has > sufficient stack space to run subsequently. Otherwise, the observable > behavior is identical. Well, not identical, but similar indeed. > Since we can't realistically predict > acceptable stack availability requirements, some amount of uncertainty > is always going to exist. > A good heuristic, though, might be to limit > argument size to a percentage (say 25%) of maximum stack size and > validate this inside copy_strings(). Right, this seems a much simpler approach. I like it.