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