Skip to content

Commit

Permalink
tools/nolibc: tests: add test for -fstack-protector
Browse files Browse the repository at this point in the history
Test the previously introduce stack protector functionality in nolibc.

Signed-off-by: Thomas Weißschuh <linux@weissschuh.net>
Signed-off-by: Willy Tarreau <w@1wt.eu>
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
  • Loading branch information
Thomas Weißschuh authored and Paul E. McKenney committed Mar 27, 2023
1 parent 255ffee commit 9735716
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 2 deletions.
3 changes: 3 additions & 0 deletions tools/testing/selftests/nolibc/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,9 @@ else
Q=@
endif

CFLAGS_STACKPROTECTOR = -DNOLIBC_STACKPROTECTOR \
$(call cc-option,-mstack-protector-guard=global) \
$(call cc-option,-fstack-protector-all)
CFLAGS_s390 = -m64
CFLAGS ?= -Os -fno-ident -fno-asynchronous-unwind-tables \
$(call cc-option,-fno-stack-protector) \
Expand Down
62 changes: 60 additions & 2 deletions tools/testing/selftests/nolibc/nolibc-test.c
Original file line number Diff line number Diff line change
Expand Up @@ -667,6 +667,63 @@ int run_stdlib(int min, int max)
return ret;
}

#if defined(__clang__)
__attribute__((optnone))
#elif defined(__GNUC__)
__attribute__((optimize("O0")))
#endif
static int smash_stack(void)
{
char buf[100];

for (size_t i = 0; i < 200; i++)
buf[i] = 'P';

return 1;
}

static int run_protection(int min, int max)
{
pid_t pid;
int llen = 0, status;

llen += printf("0 -fstackprotector ");

#if !defined(NOLIBC_STACKPROTECTOR)
llen += printf("not supported");
pad_spc(llen, 64, "[SKIPPED]\n");
return 0;
#endif

pid = -1;
pid = fork();

switch (pid) {
case -1:
llen += printf("fork()");
pad_spc(llen, 64, "[FAIL]\n");
return 1;

case 0:
close(STDOUT_FILENO);
close(STDERR_FILENO);

smash_stack();
return 1;

default:
pid = waitpid(pid, &status, 0);

if (pid == -1 || !WIFSIGNALED(status) || WTERMSIG(status) != SIGABRT) {
llen += printf("waitpid()");
pad_spc(llen, 64, "[FAIL]\n");
return 1;
}
pad_spc(llen, 64, " [OK]\n");
return 0;
}
}

/* prepare what needs to be prepared for pid 1 (stdio, /dev, /proc, etc) */
int prepare(void)
{
Expand Down Expand Up @@ -719,8 +776,9 @@ int prepare(void)
/* This is the definition of known test names, with their functions */
static const struct test test_names[] = {
/* add new tests here */
{ .name = "syscall", .func = run_syscall },
{ .name = "stdlib", .func = run_stdlib },
{ .name = "syscall", .func = run_syscall },
{ .name = "stdlib", .func = run_stdlib },
{ .name = "protection", .func = run_protection },
{ 0 }
};

Expand Down

0 comments on commit 9735716

Please sign in to comment.