18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 28c2ecf20Sopenharmony_ci#ifndef _ASM_X86_COMPAT_H 38c2ecf20Sopenharmony_ci#define _ASM_X86_COMPAT_H 48c2ecf20Sopenharmony_ci 58c2ecf20Sopenharmony_ci/* 68c2ecf20Sopenharmony_ci * Architecture specific compatibility types 78c2ecf20Sopenharmony_ci */ 88c2ecf20Sopenharmony_ci#include <linux/types.h> 98c2ecf20Sopenharmony_ci#include <linux/sched.h> 108c2ecf20Sopenharmony_ci#include <linux/sched/task_stack.h> 118c2ecf20Sopenharmony_ci#include <asm/processor.h> 128c2ecf20Sopenharmony_ci#include <asm/user32.h> 138c2ecf20Sopenharmony_ci#include <asm/unistd.h> 148c2ecf20Sopenharmony_ci 158c2ecf20Sopenharmony_ci#include <asm-generic/compat.h> 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_ci#define COMPAT_USER_HZ 100 188c2ecf20Sopenharmony_ci#define COMPAT_UTS_MACHINE "i686\0\0" 198c2ecf20Sopenharmony_ci 208c2ecf20Sopenharmony_citypedef u16 __compat_uid_t; 218c2ecf20Sopenharmony_citypedef u16 __compat_gid_t; 228c2ecf20Sopenharmony_citypedef u32 __compat_uid32_t; 238c2ecf20Sopenharmony_citypedef u32 __compat_gid32_t; 248c2ecf20Sopenharmony_citypedef u16 compat_mode_t; 258c2ecf20Sopenharmony_citypedef u16 compat_dev_t; 268c2ecf20Sopenharmony_citypedef u16 compat_nlink_t; 278c2ecf20Sopenharmony_citypedef u16 compat_ipc_pid_t; 288c2ecf20Sopenharmony_citypedef u32 compat_caddr_t; 298c2ecf20Sopenharmony_citypedef __kernel_fsid_t compat_fsid_t; 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_cistruct compat_stat { 328c2ecf20Sopenharmony_ci u32 st_dev; 338c2ecf20Sopenharmony_ci compat_ino_t st_ino; 348c2ecf20Sopenharmony_ci compat_mode_t st_mode; 358c2ecf20Sopenharmony_ci compat_nlink_t st_nlink; 368c2ecf20Sopenharmony_ci __compat_uid_t st_uid; 378c2ecf20Sopenharmony_ci __compat_gid_t st_gid; 388c2ecf20Sopenharmony_ci u32 st_rdev; 398c2ecf20Sopenharmony_ci u32 st_size; 408c2ecf20Sopenharmony_ci u32 st_blksize; 418c2ecf20Sopenharmony_ci u32 st_blocks; 428c2ecf20Sopenharmony_ci u32 st_atime; 438c2ecf20Sopenharmony_ci u32 st_atime_nsec; 448c2ecf20Sopenharmony_ci u32 st_mtime; 458c2ecf20Sopenharmony_ci u32 st_mtime_nsec; 468c2ecf20Sopenharmony_ci u32 st_ctime; 478c2ecf20Sopenharmony_ci u32 st_ctime_nsec; 488c2ecf20Sopenharmony_ci u32 __unused4; 498c2ecf20Sopenharmony_ci u32 __unused5; 508c2ecf20Sopenharmony_ci}; 518c2ecf20Sopenharmony_ci 528c2ecf20Sopenharmony_cistruct compat_flock { 538c2ecf20Sopenharmony_ci short l_type; 548c2ecf20Sopenharmony_ci short l_whence; 558c2ecf20Sopenharmony_ci compat_off_t l_start; 568c2ecf20Sopenharmony_ci compat_off_t l_len; 578c2ecf20Sopenharmony_ci compat_pid_t l_pid; 588c2ecf20Sopenharmony_ci}; 598c2ecf20Sopenharmony_ci 608c2ecf20Sopenharmony_ci#define F_GETLK64 12 /* using 'struct flock64' */ 618c2ecf20Sopenharmony_ci#define F_SETLK64 13 628c2ecf20Sopenharmony_ci#define F_SETLKW64 14 638c2ecf20Sopenharmony_ci 648c2ecf20Sopenharmony_ci/* 658c2ecf20Sopenharmony_ci * IA32 uses 4 byte alignment for 64 bit quantities, 668c2ecf20Sopenharmony_ci * so we need to pack this structure. 678c2ecf20Sopenharmony_ci */ 688c2ecf20Sopenharmony_cistruct compat_flock64 { 698c2ecf20Sopenharmony_ci short l_type; 708c2ecf20Sopenharmony_ci short l_whence; 718c2ecf20Sopenharmony_ci compat_loff_t l_start; 728c2ecf20Sopenharmony_ci compat_loff_t l_len; 738c2ecf20Sopenharmony_ci compat_pid_t l_pid; 748c2ecf20Sopenharmony_ci} __attribute__((packed)); 758c2ecf20Sopenharmony_ci 768c2ecf20Sopenharmony_cistruct compat_statfs { 778c2ecf20Sopenharmony_ci int f_type; 788c2ecf20Sopenharmony_ci int f_bsize; 798c2ecf20Sopenharmony_ci int f_blocks; 808c2ecf20Sopenharmony_ci int f_bfree; 818c2ecf20Sopenharmony_ci int f_bavail; 828c2ecf20Sopenharmony_ci int f_files; 838c2ecf20Sopenharmony_ci int f_ffree; 848c2ecf20Sopenharmony_ci compat_fsid_t f_fsid; 858c2ecf20Sopenharmony_ci int f_namelen; /* SunOS ignores this field. */ 868c2ecf20Sopenharmony_ci int f_frsize; 878c2ecf20Sopenharmony_ci int f_flags; 888c2ecf20Sopenharmony_ci int f_spare[4]; 898c2ecf20Sopenharmony_ci}; 908c2ecf20Sopenharmony_ci 918c2ecf20Sopenharmony_ci#define COMPAT_RLIM_INFINITY 0xffffffff 928c2ecf20Sopenharmony_ci 938c2ecf20Sopenharmony_citypedef u32 compat_old_sigset_t; /* at least 32 bits */ 948c2ecf20Sopenharmony_ci 958c2ecf20Sopenharmony_ci#define _COMPAT_NSIG 64 968c2ecf20Sopenharmony_ci#define _COMPAT_NSIG_BPW 32 978c2ecf20Sopenharmony_ci 988c2ecf20Sopenharmony_citypedef u32 compat_sigset_word; 998c2ecf20Sopenharmony_ci 1008c2ecf20Sopenharmony_ci#define COMPAT_OFF_T_MAX 0x7fffffff 1018c2ecf20Sopenharmony_ci 1028c2ecf20Sopenharmony_cistruct compat_ipc64_perm { 1038c2ecf20Sopenharmony_ci compat_key_t key; 1048c2ecf20Sopenharmony_ci __compat_uid32_t uid; 1058c2ecf20Sopenharmony_ci __compat_gid32_t gid; 1068c2ecf20Sopenharmony_ci __compat_uid32_t cuid; 1078c2ecf20Sopenharmony_ci __compat_gid32_t cgid; 1088c2ecf20Sopenharmony_ci unsigned short mode; 1098c2ecf20Sopenharmony_ci unsigned short __pad1; 1108c2ecf20Sopenharmony_ci unsigned short seq; 1118c2ecf20Sopenharmony_ci unsigned short __pad2; 1128c2ecf20Sopenharmony_ci compat_ulong_t unused1; 1138c2ecf20Sopenharmony_ci compat_ulong_t unused2; 1148c2ecf20Sopenharmony_ci}; 1158c2ecf20Sopenharmony_ci 1168c2ecf20Sopenharmony_cistruct compat_semid64_ds { 1178c2ecf20Sopenharmony_ci struct compat_ipc64_perm sem_perm; 1188c2ecf20Sopenharmony_ci compat_ulong_t sem_otime; 1198c2ecf20Sopenharmony_ci compat_ulong_t sem_otime_high; 1208c2ecf20Sopenharmony_ci compat_ulong_t sem_ctime; 1218c2ecf20Sopenharmony_ci compat_ulong_t sem_ctime_high; 1228c2ecf20Sopenharmony_ci compat_ulong_t sem_nsems; 1238c2ecf20Sopenharmony_ci compat_ulong_t __unused3; 1248c2ecf20Sopenharmony_ci compat_ulong_t __unused4; 1258c2ecf20Sopenharmony_ci}; 1268c2ecf20Sopenharmony_ci 1278c2ecf20Sopenharmony_cistruct compat_msqid64_ds { 1288c2ecf20Sopenharmony_ci struct compat_ipc64_perm msg_perm; 1298c2ecf20Sopenharmony_ci compat_ulong_t msg_stime; 1308c2ecf20Sopenharmony_ci compat_ulong_t msg_stime_high; 1318c2ecf20Sopenharmony_ci compat_ulong_t msg_rtime; 1328c2ecf20Sopenharmony_ci compat_ulong_t msg_rtime_high; 1338c2ecf20Sopenharmony_ci compat_ulong_t msg_ctime; 1348c2ecf20Sopenharmony_ci compat_ulong_t msg_ctime_high; 1358c2ecf20Sopenharmony_ci compat_ulong_t msg_cbytes; 1368c2ecf20Sopenharmony_ci compat_ulong_t msg_qnum; 1378c2ecf20Sopenharmony_ci compat_ulong_t msg_qbytes; 1388c2ecf20Sopenharmony_ci compat_pid_t msg_lspid; 1398c2ecf20Sopenharmony_ci compat_pid_t msg_lrpid; 1408c2ecf20Sopenharmony_ci compat_ulong_t __unused4; 1418c2ecf20Sopenharmony_ci compat_ulong_t __unused5; 1428c2ecf20Sopenharmony_ci}; 1438c2ecf20Sopenharmony_ci 1448c2ecf20Sopenharmony_cistruct compat_shmid64_ds { 1458c2ecf20Sopenharmony_ci struct compat_ipc64_perm shm_perm; 1468c2ecf20Sopenharmony_ci compat_size_t shm_segsz; 1478c2ecf20Sopenharmony_ci compat_ulong_t shm_atime; 1488c2ecf20Sopenharmony_ci compat_ulong_t shm_atime_high; 1498c2ecf20Sopenharmony_ci compat_ulong_t shm_dtime; 1508c2ecf20Sopenharmony_ci compat_ulong_t shm_dtime_high; 1518c2ecf20Sopenharmony_ci compat_ulong_t shm_ctime; 1528c2ecf20Sopenharmony_ci compat_ulong_t shm_ctime_high; 1538c2ecf20Sopenharmony_ci compat_pid_t shm_cpid; 1548c2ecf20Sopenharmony_ci compat_pid_t shm_lpid; 1558c2ecf20Sopenharmony_ci compat_ulong_t shm_nattch; 1568c2ecf20Sopenharmony_ci compat_ulong_t __unused4; 1578c2ecf20Sopenharmony_ci compat_ulong_t __unused5; 1588c2ecf20Sopenharmony_ci}; 1598c2ecf20Sopenharmony_ci 1608c2ecf20Sopenharmony_ci/* 1618c2ecf20Sopenharmony_ci * The type of struct elf_prstatus.pr_reg in compatible core dumps. 1628c2ecf20Sopenharmony_ci */ 1638c2ecf20Sopenharmony_citypedef struct user_regs_struct compat_elf_gregset_t; 1648c2ecf20Sopenharmony_ci 1658c2ecf20Sopenharmony_ci/* Full regset -- prstatus on x32, otherwise on ia32 */ 1668c2ecf20Sopenharmony_ci#define PRSTATUS_SIZE(S, R) (R != sizeof(S.pr_reg) ? 144 : 296) 1678c2ecf20Sopenharmony_ci#define SET_PR_FPVALID(S, V, R) \ 1688c2ecf20Sopenharmony_ci do { *(int *) (((void *) &((S)->pr_reg)) + R) = (V); } \ 1698c2ecf20Sopenharmony_ci while (0) 1708c2ecf20Sopenharmony_ci 1718c2ecf20Sopenharmony_ci#ifdef CONFIG_X86_X32_ABI 1728c2ecf20Sopenharmony_ci#define COMPAT_USE_64BIT_TIME \ 1738c2ecf20Sopenharmony_ci (!!(task_pt_regs(current)->orig_ax & __X32_SYSCALL_BIT)) 1748c2ecf20Sopenharmony_ci#endif 1758c2ecf20Sopenharmony_ci 1768c2ecf20Sopenharmony_cistatic inline void __user *arch_compat_alloc_user_space(long len) 1778c2ecf20Sopenharmony_ci{ 1788c2ecf20Sopenharmony_ci compat_uptr_t sp; 1798c2ecf20Sopenharmony_ci 1808c2ecf20Sopenharmony_ci if (test_thread_flag(TIF_IA32)) { 1818c2ecf20Sopenharmony_ci sp = task_pt_regs(current)->sp; 1828c2ecf20Sopenharmony_ci } else { 1838c2ecf20Sopenharmony_ci /* -128 for the x32 ABI redzone */ 1848c2ecf20Sopenharmony_ci sp = task_pt_regs(current)->sp - 128; 1858c2ecf20Sopenharmony_ci } 1868c2ecf20Sopenharmony_ci 1878c2ecf20Sopenharmony_ci return (void __user *)round_down(sp - len, 16); 1888c2ecf20Sopenharmony_ci} 1898c2ecf20Sopenharmony_ci 1908c2ecf20Sopenharmony_cistatic inline bool in_x32_syscall(void) 1918c2ecf20Sopenharmony_ci{ 1928c2ecf20Sopenharmony_ci#ifdef CONFIG_X86_X32_ABI 1938c2ecf20Sopenharmony_ci if (task_pt_regs(current)->orig_ax & __X32_SYSCALL_BIT) 1948c2ecf20Sopenharmony_ci return true; 1958c2ecf20Sopenharmony_ci#endif 1968c2ecf20Sopenharmony_ci return false; 1978c2ecf20Sopenharmony_ci} 1988c2ecf20Sopenharmony_ci 1998c2ecf20Sopenharmony_cistatic inline bool in_32bit_syscall(void) 2008c2ecf20Sopenharmony_ci{ 2018c2ecf20Sopenharmony_ci return in_ia32_syscall() || in_x32_syscall(); 2028c2ecf20Sopenharmony_ci} 2038c2ecf20Sopenharmony_ci 2048c2ecf20Sopenharmony_ci#ifdef CONFIG_COMPAT 2058c2ecf20Sopenharmony_cistatic inline bool in_compat_syscall(void) 2068c2ecf20Sopenharmony_ci{ 2078c2ecf20Sopenharmony_ci return in_32bit_syscall(); 2088c2ecf20Sopenharmony_ci} 2098c2ecf20Sopenharmony_ci#define in_compat_syscall in_compat_syscall /* override the generic impl */ 2108c2ecf20Sopenharmony_ci#define compat_need_64bit_alignment_fixup in_ia32_syscall 2118c2ecf20Sopenharmony_ci#endif 2128c2ecf20Sopenharmony_ci 2138c2ecf20Sopenharmony_cistruct compat_siginfo; 2148c2ecf20Sopenharmony_ci 2158c2ecf20Sopenharmony_ci#ifdef CONFIG_X86_X32_ABI 2168c2ecf20Sopenharmony_ciint copy_siginfo_to_user32(struct compat_siginfo __user *to, 2178c2ecf20Sopenharmony_ci const kernel_siginfo_t *from); 2188c2ecf20Sopenharmony_ci#define copy_siginfo_to_user32 copy_siginfo_to_user32 2198c2ecf20Sopenharmony_ci#endif /* CONFIG_X86_X32_ABI */ 2208c2ecf20Sopenharmony_ci 2218c2ecf20Sopenharmony_ci#endif /* _ASM_X86_COMPAT_H */ 222