diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 2003-04-23 21:46:05 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 2003-04-23 21:46:05 +0000 |
commit | 428163d1426f6ea47dfb17c47436d37db3e5dd91 (patch) | |
tree | f43f54835e0f14fdd317aac275c917dd6e89478c /regress/sys/kern/noexec | |
parent | a5cbe74bb32ada37df4b6725987e937feb1261d4 (diff) |
implement mmap tests and enable the .text test (with padding now)
Diffstat (limited to 'regress/sys/kern/noexec')
-rw-r--r-- | regress/sys/kern/noexec/Makefile | 11 | ||||
-rw-r--r-- | regress/sys/kern/noexec/noexec.c | 63 |
2 files changed, 54 insertions, 20 deletions
diff --git a/regress/sys/kern/noexec/Makefile b/regress/sys/kern/noexec/Makefile index 8fbf9f0e3ce..b82ff5fd2f2 100644 --- a/regress/sys/kern/noexec/Makefile +++ b/regress/sys/kern/noexec/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.3 2002/09/03 15:28:49 mickey Exp $ +# $OpenBSD: Makefile,v 1.4 2003/04/23 21:46:04 mickey Exp $ .if ${MACHINE} == "sparc64" || ${MACHINE} == "sparc" || \ ${MACHINE} == "alpha" || ${MACHINE} == "macppc" || \ @@ -12,11 +12,12 @@ REGRESS_TARGETS= nxtext-mprotect \ nxdata nxdata-mprotect \ nxbss nxbss-mprotect \ nxheap nxheap-mprotect \ + nxmmap nxmmap-mprotect \ nxstack nxstack-mprotect .PHONY: ${REGRESS_TARGETS} nxtext-mprotect: ${PROG} -# @./${PROG} -T -p + @./${PROG} -T -p nxdata: ${PROG} @./${PROG} -D @@ -42,6 +43,12 @@ nxstack: ${PROG} nxstack-mprotect: ${PROG} @./${PROG} -S -p +nxmmap: ${PROG} + @./${PROG} -m + +nxmmap-mprotect: ${PROG} + @./${PROG} -m -p + .else REGRESS_TARGETS= # this architecture has no test for this .endif diff --git a/regress/sys/kern/noexec/noexec.c b/regress/sys/kern/noexec/noexec.c index f281d299834..68dd426ac69 100644 --- a/regress/sys/kern/noexec/noexec.c +++ b/regress/sys/kern/noexec/noexec.c @@ -1,7 +1,7 @@ -/* $OpenBSD: noexec.c,v 1.3 2003/01/05 22:41:36 deraadt Exp $ */ +/* $OpenBSD: noexec.c,v 1.4 2003/04/23 21:46:04 mickey Exp $ */ /* - * Copyright (c) 2002 Michael Shalayeff + * Copyright (c) 2002,2003 Michael Shalayeff * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -48,10 +48,7 @@ char label[64] = "non-exec "; u_int64_t data[PAD+TEST] = { 0 }; u_int64_t bss[PAD+TEST]; -void -testfly() -{ -} +void testfly(); void sigsegv(int sig, siginfo_t *sip, void *scp) @@ -62,7 +59,6 @@ sigsegv(int sig, siginfo_t *sip, void *scp) int noexec(void *p, size_t size) { - fail = 0; printf("%s: execute\n", label); ((void (*)(void))p)(); @@ -76,13 +72,15 @@ noexec_mprotect(void *p, size_t size) /* here we must fail on segv since we said it gets executable */ fail = 1; - mprotect(p, size, PROT_READ|PROT_WRITE|PROT_EXEC); + if (mprotect(p, size, PROT_READ|PROT_WRITE|PROT_EXEC) < 0) + err(1, "mprotect 1"); printf("%s: execute\n", label); ((void (*)(void))p)(); /* here we are successful on segv and fail if it still executes */ fail = 0; - mprotect(p, size, PROT_READ|PROT_WRITE); + if (mprotect(p, size, PROT_READ|PROT_WRITE) < 0) + err(1, "mprotect 2"); printf("%s: catch a signal\n", label); ((void (*)(void))p)(); @@ -105,17 +103,32 @@ getaddr(void *a) int noexec_mmap(void *p, size_t size) { - void *addr; + memcpy(p + page_size * 1, p, page_size); + memcpy(p + page_size * 2, p, page_size); + /* XXX must flush cache */ /* here we must fail on segv since we said it gets executable */ fail = 1; - if ((addr = mmap(p, size, PROT_READ|PROT_WRITE|PROT_EXEC, - MAP_ANON|MAP_FIXED, -1, 0)) == MAP_FAILED) - err(1, "mmap"); - printf("%s: execute\n", label); - ((void (*)(void))addr)(); - exit(0); + printf("%s: execute #1\n", label); + ((void (*)(void))p)(); + + /* unmap the first page to see that the higher page is still exec */ + if (munmap(p, page_size) < 0) + err(1, "munmap"); + + p += page_size; + printf("%s: execute #2\n", label); + ((void (*)(void))p)(); + + /* unmap the last page to see that the lower page is still exec */ + if (munmap(p + page_size, page_size) < 0) + err(1, "munmap"); + + printf("%s: execute #3\n", label); + ((void (*)(void))p)(); + + return (0); } void @@ -179,7 +192,11 @@ main(int argc, char *argv[]) break; case 'm': func = &noexec_mmap; - strcat(label, "-mmap"); + strcat(label, "mmap"); + if ((p = mmap(NULL, 3 * page_size, + PROT_READ|PROT_WRITE|PROT_EXEC, + MAP_ANON, -1, 0)) == MAP_FAILED) + err(1, "mmap"); break; case 'p': func = &noexec_mprotect; @@ -202,7 +219,17 @@ main(int argc, char *argv[]) sigemptyset(&sa.sa_mask); sigaction(SIGSEGV, &sa, NULL); - memcpy(p, &testfly, TEST); + if (p != &testfly) + memcpy(p, &testfly, TEST); exit((*func)(p, size)); } + +__asm (".space 8192"); + +void +testfly() +{ +} + +__asm (".space 8192"); |