| 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
| 2 | /* |
| 3 | * AArch32 sigreturn code. |
| 4 | * Based on the kuser helpers in arch/arm/kernel/entry-armv.S. |
| 5 | * |
| 6 | * Copyright (C) 2005-2011 Nicolas Pitre <nico@fluxnic.net> |
| 7 | * Copyright (C) 2012-2018 ARM Ltd. |
| 8 | * |
| 9 | * For ARM syscalls, the syscall number has to be loaded into r7. |
| 10 | * We do not support an OABI userspace. |
| 11 | * |
| 12 | * For Thumb syscalls, we also pass the syscall number via r7. We therefore |
| 13 | * need two 16-bit instructions. |
| 14 | */ |
| 15 | |
| 16 | #include <asm/unistd_compat_32.h> |
| 17 | |
| 18 | .section .rodata |
| 19 | .globl __aarch32_sigret_code_start |
| 20 | __aarch32_sigret_code_start: |
| 21 | |
| 22 | /* |
| 23 | * ARM Code |
| 24 | */ |
| 25 | .byte __NR_compat32_sigreturn, 0x70, 0xa0, 0xe3 // mov r7, #__NR_compat32_sigreturn |
| 26 | .byte __NR_compat32_sigreturn, 0x00, 0x00, 0xef // svc #__NR_compat32_sigreturn |
| 27 | |
| 28 | /* |
| 29 | * Thumb code |
| 30 | */ |
| 31 | .byte __NR_compat32_sigreturn, 0x27 // svc #__NR_compat32_sigreturn |
| 32 | .byte __NR_compat32_sigreturn, 0xdf // mov r7, #__NR_compat32_sigreturn |
| 33 | |
| 34 | /* |
| 35 | * ARM code |
| 36 | */ |
| 37 | .byte __NR_compat32_rt_sigreturn, 0x70, 0xa0, 0xe3 // mov r7, #__NR_compat32_rt_sigreturn |
| 38 | .byte __NR_compat32_rt_sigreturn, 0x00, 0x00, 0xef // svc #__NR_compat32_rt_sigreturn |
| 39 | |
| 40 | /* |
| 41 | * Thumb code |
| 42 | */ |
| 43 | .byte __NR_compat32_rt_sigreturn, 0x27 // svc #__NR_compat32_rt_sigreturn |
| 44 | .byte __NR_compat32_rt_sigreturn, 0xdf // mov r7, #__NR_compat32_rt_sigreturn |
| 45 | |
| 46 | .globl __aarch32_sigret_code_end |
| 47 | __aarch32_sigret_code_end: |
| 48 | |