summaryrefslogtreecommitdiffstats
path: root/lib/libcrypto/dsa/dsa_lib.c
diff options
context:
space:
mode:
authorderaadt <deraadt@openbsd.org>2018-04-12 17:13:34 +0000
committerderaadt <deraadt@openbsd.org>2018-04-12 17:13:34 +0000
commit003f5e42bbc90263e30dbce6eb150fc5e31b56eb (patch)
tree04d47971c19a950593b40d0a8bba6cc3c78f0cbd /lib/libcrypto/dsa/dsa_lib.c
parentRestore the original BSDI $Id$ strings. Those were mangled by CVS (diff)
downloadwireguard-openbsd-003f5e42bbc90263e30dbce6eb150fc5e31b56eb.tar.xz
wireguard-openbsd-003f5e42bbc90263e30dbce6eb150fc5e31b56eb.zip
Implement MAP_STACK option for mmap(). Synchronous faults (pagefault and
syscall) confirm the stack register points at MAP_STACK memory, otherwise SIGSEGV is delivered. sigaltstack() and pthread_attr_setstack() are modified to create a MAP_STACK sub-region which satisfies alignment requirements. Observe that MAP_STACK can only be set/cleared by mmap(), which zeroes the contents of the region -- there is no mprotect() equivalent operation, so there is no MAP_STACK-adding gadget. This opportunistic software-emulation of a stack protection bit makes stack-pivot operations during ROPchain fragile (kind of like removing a tool from the toolbox). original discussion with tedu, uvm work by stefan, testing by mortimer ok kettenis
Diffstat (limited to 'lib/libcrypto/dsa/dsa_lib.c')
0 files changed, 0 insertions, 0 deletions