public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: David Newall <davidn@davidnewall.com>
To: Valery Reznic <valery_reznic@yahoo.com>
Cc: linux-kernel@vger.kernel.org
Subject: Re: execve for script don't return ENOEXEC, bug ?
Date: Sun, 21 Mar 2010 04:27:10 +1030	[thread overview]
Message-ID: <4BA50C76.9070603@davidnewall.com> (raw)
In-Reply-To: <435973.80037.qm@web110306.mail.gq1.yahoo.com>

Valery Reznic wrote:
> execve's man page state that script's interprtert should not be 
> interpreter itself:
> ------------------------------------------------------
>    Interpreter scripts
>        An  interpreter  script  is  a  text  file  that has execute permission
>        enabled and whose first line is of the form:
>
>            #! interpreter [optional-arg]
>
>        The interpreter must be a valid pathname for an executable which is not
>        itself  a  script. 
> ------------------------------------------------------
>
> I.e, execve should return ENOEXEC. And it did it at least in Fedora 8 and earlier.
>
> To me it looks like  execve and it's man page disagree. Do you know is it new intended behaviour of execve and just man page wasn't update or it's a bug in execve ?

Code and man pages do sometimes disagree.  I shan't address what the 
correct behaviour is, because if you ask three people you're sure to get 
four different answers, rather let's discuss what is desirable.  Without 
looking at how it works, we observe that a.sh can be executed without 
error.  If a.out were written in C it would qualify as an acceptable 
interpreter according to the man page, so why should it not qualify if 
it is interpreted?  I think it's desirable that it does qualify.  There 
could be sound reasons why only one level of interpreter can be 
invoked.  Perhaps loading a script interpreter is done as an exception 
in exec, and it's too ugly to allow recursive exceptions.  That would be 
a fair reason.  But if there's no reason, then don't have the 
restriction*.  Linux now apparently does permit interpreted 
interpreters, and I say that is the desirable result.

*Newall's second rule of programming: A program should impose no 
unnecessary restriction on its user.

  reply	other threads:[~2010-03-20 17:57 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-03-11 10:56 execve for script don't return ENOEXEC, bug ? Valery Reznic
2010-03-19 21:07 ` Andrew Morton
2010-03-20  0:37   ` David Newall
2010-03-20  6:42     ` Valery Reznic
2010-03-20  9:41       ` David Newall
2010-03-20 12:56         ` Valery Reznic
2010-03-20 17:57           ` David Newall [this message]
2010-03-21  8:33             ` Valery Reznic
2010-03-21 19:16               ` Johannes Stezenbach

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4BA50C76.9070603@davidnewall.com \
    --to=davidn@davidnewall.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=valery_reznic@yahoo.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox