162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci#ifndef _ASM_S390X_COMPAT_H 362306a36Sopenharmony_ci#define _ASM_S390X_COMPAT_H 462306a36Sopenharmony_ci/* 562306a36Sopenharmony_ci * Architecture specific compatibility types 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci#include <linux/types.h> 862306a36Sopenharmony_ci#include <linux/sched.h> 962306a36Sopenharmony_ci#include <linux/sched/task_stack.h> 1062306a36Sopenharmony_ci#include <linux/thread_info.h> 1162306a36Sopenharmony_ci#include <asm/ptrace.h> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#define compat_mode_t compat_mode_t 1462306a36Sopenharmony_citypedef u16 compat_mode_t; 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#define __compat_uid_t __compat_uid_t 1762306a36Sopenharmony_citypedef u16 __compat_uid_t; 1862306a36Sopenharmony_citypedef u16 __compat_gid_t; 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci#define compat_dev_t compat_dev_t 2162306a36Sopenharmony_citypedef u16 compat_dev_t; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci#define compat_ipc_pid_t compat_ipc_pid_t 2462306a36Sopenharmony_citypedef u16 compat_ipc_pid_t; 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci#define compat_statfs compat_statfs 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci#include <asm-generic/compat.h> 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci#define __TYPE_IS_PTR(t) (!__builtin_types_compatible_p( \ 3162306a36Sopenharmony_ci typeof(0?(__force t)0:0ULL), u64)) 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci#define __SC_DELOUSE(t,v) ({ \ 3462306a36Sopenharmony_ci BUILD_BUG_ON(sizeof(t) > 4 && !__TYPE_IS_PTR(t)); \ 3562306a36Sopenharmony_ci (__force t)(__TYPE_IS_PTR(t) ? ((v) & 0x7fffffff) : (v)); \ 3662306a36Sopenharmony_ci}) 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci#define PSW32_MASK_USER 0x0000FF00UL 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci#define PSW32_USER_BITS (PSW32_MASK_DAT | PSW32_MASK_IO | PSW32_MASK_EXT | \ 4162306a36Sopenharmony_ci PSW32_DEFAULT_KEY | PSW32_MASK_BASE | \ 4262306a36Sopenharmony_ci PSW32_MASK_MCHECK | PSW32_MASK_PSTATE | \ 4362306a36Sopenharmony_ci PSW32_ASC_PRIMARY) 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci#define COMPAT_UTS_MACHINE "s390\0\0\0\0" 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_citypedef u16 compat_nlink_t; 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_citypedef struct { 5062306a36Sopenharmony_ci u32 mask; 5162306a36Sopenharmony_ci u32 addr; 5262306a36Sopenharmony_ci} __aligned(8) psw_compat_t; 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_citypedef struct { 5562306a36Sopenharmony_ci psw_compat_t psw; 5662306a36Sopenharmony_ci u32 gprs[NUM_GPRS]; 5762306a36Sopenharmony_ci u32 acrs[NUM_ACRS]; 5862306a36Sopenharmony_ci u32 orig_gpr2; 5962306a36Sopenharmony_ci} s390_compat_regs; 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_citypedef struct { 6262306a36Sopenharmony_ci u32 gprs_high[NUM_GPRS]; 6362306a36Sopenharmony_ci} s390_compat_regs_high; 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_cistruct compat_stat { 6662306a36Sopenharmony_ci compat_dev_t st_dev; 6762306a36Sopenharmony_ci u16 __pad1; 6862306a36Sopenharmony_ci compat_ino_t st_ino; 6962306a36Sopenharmony_ci compat_mode_t st_mode; 7062306a36Sopenharmony_ci compat_nlink_t st_nlink; 7162306a36Sopenharmony_ci __compat_uid_t st_uid; 7262306a36Sopenharmony_ci __compat_gid_t st_gid; 7362306a36Sopenharmony_ci compat_dev_t st_rdev; 7462306a36Sopenharmony_ci u16 __pad2; 7562306a36Sopenharmony_ci u32 st_size; 7662306a36Sopenharmony_ci u32 st_blksize; 7762306a36Sopenharmony_ci u32 st_blocks; 7862306a36Sopenharmony_ci u32 st_atime; 7962306a36Sopenharmony_ci u32 st_atime_nsec; 8062306a36Sopenharmony_ci u32 st_mtime; 8162306a36Sopenharmony_ci u32 st_mtime_nsec; 8262306a36Sopenharmony_ci u32 st_ctime; 8362306a36Sopenharmony_ci u32 st_ctime_nsec; 8462306a36Sopenharmony_ci u32 __unused4; 8562306a36Sopenharmony_ci u32 __unused5; 8662306a36Sopenharmony_ci}; 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_cistruct compat_statfs { 8962306a36Sopenharmony_ci u32 f_type; 9062306a36Sopenharmony_ci u32 f_bsize; 9162306a36Sopenharmony_ci u32 f_blocks; 9262306a36Sopenharmony_ci u32 f_bfree; 9362306a36Sopenharmony_ci u32 f_bavail; 9462306a36Sopenharmony_ci u32 f_files; 9562306a36Sopenharmony_ci u32 f_ffree; 9662306a36Sopenharmony_ci compat_fsid_t f_fsid; 9762306a36Sopenharmony_ci u32 f_namelen; 9862306a36Sopenharmony_ci u32 f_frsize; 9962306a36Sopenharmony_ci u32 f_flags; 10062306a36Sopenharmony_ci u32 f_spare[4]; 10162306a36Sopenharmony_ci}; 10262306a36Sopenharmony_ci 10362306a36Sopenharmony_cistruct compat_statfs64 { 10462306a36Sopenharmony_ci u32 f_type; 10562306a36Sopenharmony_ci u32 f_bsize; 10662306a36Sopenharmony_ci u64 f_blocks; 10762306a36Sopenharmony_ci u64 f_bfree; 10862306a36Sopenharmony_ci u64 f_bavail; 10962306a36Sopenharmony_ci u64 f_files; 11062306a36Sopenharmony_ci u64 f_ffree; 11162306a36Sopenharmony_ci compat_fsid_t f_fsid; 11262306a36Sopenharmony_ci u32 f_namelen; 11362306a36Sopenharmony_ci u32 f_frsize; 11462306a36Sopenharmony_ci u32 f_flags; 11562306a36Sopenharmony_ci u32 f_spare[5]; 11662306a36Sopenharmony_ci}; 11762306a36Sopenharmony_ci 11862306a36Sopenharmony_ci/* 11962306a36Sopenharmony_ci * A pointer passed in from user mode. This should not 12062306a36Sopenharmony_ci * be used for syscall parameters, just declare them 12162306a36Sopenharmony_ci * as pointers because the syscall entry code will have 12262306a36Sopenharmony_ci * appropriately converted them already. 12362306a36Sopenharmony_ci */ 12462306a36Sopenharmony_ci 12562306a36Sopenharmony_cistatic inline void __user *compat_ptr(compat_uptr_t uptr) 12662306a36Sopenharmony_ci{ 12762306a36Sopenharmony_ci return (void __user *)(unsigned long)(uptr & 0x7fffffffUL); 12862306a36Sopenharmony_ci} 12962306a36Sopenharmony_ci#define compat_ptr(uptr) compat_ptr(uptr) 13062306a36Sopenharmony_ci 13162306a36Sopenharmony_ci#ifdef CONFIG_COMPAT 13262306a36Sopenharmony_ci 13362306a36Sopenharmony_cistatic inline int is_compat_task(void) 13462306a36Sopenharmony_ci{ 13562306a36Sopenharmony_ci return test_thread_flag(TIF_31BIT); 13662306a36Sopenharmony_ci} 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ci#endif 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_ci#endif /* _ASM_S390X_COMPAT_H */ 141