[revert request for commit 9fff2fa] Re: [git pull] signals pile 3
Al Viro
viro at ZenIV.linux.org.uk
Sun Oct 14 15:24:03 EDT 2012
On Sun, Oct 14, 2012 at 06:26:40PM +0100, Al Viro wrote:
> and the last 3 make no sense whatsoever. Note that on normal execve() we'll
> be going through the syscall return, so the userland will see 0 in there,
> no matter what do we do here. Theoretically, it might've been done for
> ptrace sake (it will be able to observe the values in those registers before
> the tracee reaches userland),
Except that it won't be able to see what start_thread() puts in r0 either;
on successful exceve(2) we will store return value of sys_execve() (i.e. 0)
in regs->ARM_r0 before we get to any of the places where it could have
examine the sucker. So what was that assignment for? And as far as I can
see, ARM ELF ABI says that general register values on process startup are
undefined, so r1 and r2 assignments also seem to be pointless. OTOH, they
predate the ELF conversion by quite a but - that code had been there since
1.x times, when we used to use a.out... In any case, they were *not* going
to be usable as main() arguments - zero argc would make userland rather
unhappy. I don't have arm libc sources from those times, but I'd expect
it to have all those suckers read from userland stack...
Russell, could you recall what those had been about? I'm not sure if that
had been oopsable that far back (again, oops scenario is userland stack
page getting swapped out before we get to start_thread(), leading to
direct read from an absent page in start_thread() by plain ldr, without
anything in exception table about that insn), but it looks very odd
regardless of that problem.
More information about the linux-arm-kernel
mailing list