signal: Stop special casing TRAP_FIXME and FPE_FIXME in siginfo_layout
authorEric W. Biederman <ebiederm@xmission.com>
Sat, 14 Apr 2018 19:20:30 +0000 (14:20 -0500)
committerEric W. Biederman <ebiederm@xmission.com>
Wed, 25 Apr 2018 15:40:52 +0000 (10:40 -0500)
commit0c362f96e1c6bb76ab9b0b828985655fd2516bfa
treeadb33e0cdce9a1645f8238796d5bf35b43f3fe7a
parentc999b933faa5e281e3af2e110eccaf91698b0a81
signal: Stop special casing TRAP_FIXME and FPE_FIXME in siginfo_layout

After more experience with the cases where no one the si_code of 0
is used both as a signal specific si_code, and as SI_USER it appears
that no one cares about the signal specific si_code case and the
good solution is to just fix the architectures by using
a different si_code.

In none of the conversations has anyone even suggested that
anything depends on the signal specific redefinition of SI_USER.

There are at least test cases that care when si_code as 0 does
not work as si_user.

So make things simple and keep the generic code from introducing
problems by removing the special casing of TRAP_FIXME and FPE_FIXME.
This will ensure the generic case of sending a signal with
kill will always set SI_USER and work.

The architecture specific, and signal specific overloads that
set si_code to 0 will now have problems with signalfd and
the 32bit compat versions of siginfo copying.   At least
until they are fixed.

Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
kernel/signal.c