[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <AANLkTik+1k76vGccjwQWeEWZFng61ZoodDyWbN8wvPgE@mail.gmail.com>
Date: Fri, 24 Sep 2010 09:07:33 -0700
From: Linus Torvalds <torvalds@...ux-foundation.org>
To: Al Viro <viro@...iv.linux.org.uk>
Cc: tglx@...utronix.de, mingo@...hat.com, linux-kernel@...r.kernel.org
Subject: Re: what's papered over by set_fs(USER_DS) in amd64 signal delivery?
On Fri, Sep 24, 2010 at 8:52 AM, Al Viro <viro@...iv.linux.org.uk> wrote:
> What the hell is going on in amd64 handle_signal()? We do
>
> #ifdef CONFIG_X86_64
> /*
> * This has nothing to do with segment registers,
> * despite the name. This magic affects uaccess.h
> * macros' behavior. Reset it to the normal setting.
> */
> set_fs(USER_DS);
> #endif
I _think_ it is historical, and probably relates to just restoring all
the user mode state at signal delivery to a known state. IOW, I think
it really does go hand-in-hand with the whole "clear bits in the
eflags register" thing.
x86-64 has historically had some left-over crap that we already
cleaned up in 32-bit mode, for the simple reason that the original
x86-64 code was forked from an earlier base, and then hacked up
somewhat. So I think this "#ifdef CONFIG_X86_64" is just a case of
that.
But maybe we should have a WARN_ON_ONCE() to verify it, rather than
just kill it outright.
Linus
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists