~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/tools/testing/selftests/arm64/signal/signals.S

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0 */
  2 /* Copyright (C) 2019 ARM Limited */
  3 
  4 #include <asm/unistd.h>
  5 
  6 .section        .rodata, "a"
  7 call_fmt:
  8         .asciz "Calling sigreturn with fake sigframe sized:%zd at SP @%08lX\n"
  9 
 10 .text
 11 
 12 .globl fake_sigreturn
 13 
 14 /*      fake_sigreturn  x0:&sigframe,  x1:sigframe_size,  x2:misalign_bytes */
 15 fake_sigreturn:
 16         stp     x29, x30, [sp, #-16]!
 17         mov     x29, sp
 18 
 19         mov     x20, x0
 20         mov     x21, x1
 21         mov     x22, x2
 22 
 23         /* create space on the stack for fake sigframe 16 bytes-aligned */
 24         add     x0, x21, x22
 25         add     x0, x0, #15
 26         bic     x0, x0, #15 /* round_up(sigframe_size + misalign_bytes, 16) */
 27         sub     sp, sp, x0
 28         add     x23, sp, x22 /* new sigframe base with misaligment if any */
 29 
 30         ldr     x0, =call_fmt
 31         mov     x1, x21
 32         mov     x2, x23
 33         bl      printf
 34 
 35         /* memcpy the provided content, while still keeping SP aligned */
 36         mov     x0, x23
 37         mov     x1, x20
 38         mov     x2, x21
 39         bl      memcpy
 40 
 41         /*
 42          * Here saving a last minute SP to current->token acts as a marker:
 43          * if we got here, we are successfully faking a sigreturn; in other
 44          * words we are sure no bad fatal signal has been raised till now
 45          * for unrelated reasons, so we should consider the possibly observed
 46          * fatal signal like SEGV coming from Kernel restore_sigframe() and
 47          * triggered as expected from our test-case.
 48          * For simplicity this assumes that current field 'token' is laid out
 49          * as first in struct tdescr
 50          */
 51         ldr     x0, current
 52         str     x23, [x0]
 53         /* finally move SP to misaligned address...if any requested */
 54         mov     sp, x23
 55 
 56         mov     x8, #__NR_rt_sigreturn
 57         svc     #0
 58 
 59         /*
 60          * Above sigreturn should not return...looping here leads to a timeout
 61          * and ensure proper and clean test failure, instead of jumping around
 62          * on a potentially corrupted stack.
 63          */
 64         b       .

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php