Skip to content
Snippets Groups Projects
user avatar
Vineet Gupta authored
ARCv2 has some configuration dependent registers (r30, r58, r59) which
could be targetted by the compiler. To keep the ABI stable, these were
unconditionally part of the glibc ABI
(sysdeps/unix/sysv/linux/arc/sys/ucontext.h:mcontext_t) however we
missed populating them (by saving/restoring them across signal
handling).

This patch fixes the issue by
 - adding arcv2 ABI regs to kernel struct sigcontext
 - populating them during signal handling

Change to struct sigcontext might seem like a glibc ABI change (although
it primarily uses ucontext_t:mcontext_t) but the fact is
 - it has only been extended (existing fields are not touched)
 - the old sigcontext was ABI incomplete to begin with anyways

Fixes: https://github.com/foss-for-synopsys-dwc-arc-processors/linux/issues/53


Cc: <stable@vger.kernel.org>
Tested-by: default avatarkernel test robot <lkp@intel.com>
Reported-by: default avatarVladimir Isaev <isaev@synopsys.com>
Signed-off-by: default avatarVineet Gupta <vgupta@synopsys.com>
96f1b001
History
Name Last commit Last update