]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
debug: Wire up tst-longjmp_chk3
authorFlorian Weimer <fweimer@redhat.com>
Mon, 25 Nov 2024 16:32:54 +0000 (17:32 +0100)
committerFlorian Weimer <fweimer@redhat.com>
Mon, 25 Nov 2024 18:42:14 +0000 (19:42 +0100)
The test was added in commit ac8cc9e300a002228eb7e660df3e7b333d9a7414
without all the required Makefile scaffolding.  Tweak the test
so that it actually builds (including with dynamic SIGSTKSZ).

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
debug/Makefile
debug/tst-longjmp_chk3.c

index 89ee80bf4d8a1100ede3e35cbeb5d7dc5018a770..278e44c6ad95cc16b91aba929b3cd4cec3331e13 100644 (file)
@@ -288,6 +288,7 @@ tests = \
   tst-fortify-wide \
   tst-longjmp_chk \
   tst-longjmp_chk2 \
+  tst-longjmp_chk3 \
   tst-realpath-chk \
   tst-sprintf-fortify-rdonly \
   tst-sprintf-fortify-unchecked \
index 9ff99772075926ce67f3785ed0c9d4c305e1d891..7bf1646b354fd2febb6588dff52b1e113176ffa7 100644 (file)
 
 #include <setjmp.h>
 #include <signal.h>
+#include <stdio.h>
 #include <string.h>
 
-static char buf[SIGSTKSZ * 4];
+#include <support/support.h>
+
+static char *buf;
 static jmp_buf jb;
 
 static void
@@ -49,8 +52,10 @@ do_test (void)
   set_fortify_handler (handler);
 
   /* Create a valid signal stack and enable it.  */
+  size_t bufsize = SIGSTKSZ * 4;
+  buf = xmalloc (bufsize);
   ss.ss_sp = buf;
-  ss.ss_size = sizeof (buf);
+  ss.ss_size = bufsize;
   ss.ss_flags = 0;
   if (sigaltstack (&ss, NULL) < 0)
     {
@@ -65,8 +70,8 @@ do_test (void)
 
   /* Shrink the signal stack so the jmpbuf is now invalid.
      We adjust the start & end to handle stacks that grow up & down.  */
-  ss.ss_sp = buf + sizeof (buf) / 2;
-  ss.ss_size = sizeof (buf) / 4;
+  ss.ss_sp = buf + bufsize / 2;
+  ss.ss_size = bufsize / 4;
   if (sigaltstack (&ss, NULL) < 0)
     {
       printf ("second sigaltstack failed: %m\n");