aboutsummaryrefslogtreecommitdiff
path: root/tools/lib/api/debug.c
diff options
context:
space:
mode:
authorAl Viro <[email protected]>2021-09-24 00:35:42 +0000
committerGuo Ren <[email protected]>2021-10-16 07:20:12 +0800
commitfbd63c08cdcca5fb1315aca3172b3c9c272cfb4f (patch)
tree9f452d718901cf5786f42de5f8401ba295a65970 /tools/lib/api/debug.c
parent64570fbc14f8d7cb3fe3995f20e26bc25ce4b2cc (diff)
csky: don't let sigreturn play with priveleged bits of status register
csky restore_sigcontext() blindly overwrites regs->sr with the value it finds in sigcontext. Attacker can store whatever they want in there, which includes things like S-bit. Userland shouldn't be able to set that, or anything other than C flag (bit 0). Do the same thing other architectures with protected bits in flags register do - preserve everything that shouldn't be settable in user mode, picking the rest from the value saved is sigcontext. Signed-off-by: Al Viro <[email protected]> Signed-off-by: Guo Ren <[email protected]> Cc: [email protected]
Diffstat (limited to 'tools/lib/api/debug.c')
0 files changed, 0 insertions, 0 deletions