This change moves host OS and arch dependent code for the sysarch system call related to the -strace functionality into the appropriate host OS and target arch directories. Signed-off-by: Stacey Son <sson@FreeBSD.org> Signed-off-by: Sean Bruno <sburno@FreeBSD.org> [ imp integrated minor build fixes from sbruno ] Signed-off-by: Warner Losh <imp@FreeBSD.org> Message-Id: <20201218205451.10559-4-imp@freebsd.org> Signed-off-by: Thomas Huth <thuth@redhat.com>
		
			
				
	
	
		
			141 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 *  x86_64 system call definitions
 | 
						|
 *
 | 
						|
 *
 | 
						|
 *  This program is free software; you can redistribute it and/or modify
 | 
						|
 *  it under the terms of the GNU General Public License as published by
 | 
						|
 *  the Free Software Foundation; either version 2 of the License, or
 | 
						|
 *  (at your option) any later version.
 | 
						|
 *
 | 
						|
 *  This program is distributed in the hope that it will be useful,
 | 
						|
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
 *  GNU General Public License for more details.
 | 
						|
 *
 | 
						|
 *  You should have received a copy of the GNU General Public License
 | 
						|
 *  along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
						|
 */
 | 
						|
#ifndef TARGET_SYSCALL_H
 | 
						|
#define TARGET_SYSCALL_H
 | 
						|
 | 
						|
#define __USER_CS	(0x33)
 | 
						|
#define __USER_DS	(0x2B)
 | 
						|
 | 
						|
struct target_pt_regs {
 | 
						|
	abi_ulong r15;
 | 
						|
	abi_ulong r14;
 | 
						|
	abi_ulong r13;
 | 
						|
	abi_ulong r12;
 | 
						|
	abi_ulong rbp;
 | 
						|
	abi_ulong rbx;
 | 
						|
/* arguments: non interrupts/non tracing syscalls only save up to here */
 | 
						|
	abi_ulong r11;
 | 
						|
	abi_ulong r10;
 | 
						|
	abi_ulong r9;
 | 
						|
	abi_ulong r8;
 | 
						|
	abi_ulong rax;
 | 
						|
	abi_ulong rcx;
 | 
						|
	abi_ulong rdx;
 | 
						|
	abi_ulong rsi;
 | 
						|
	abi_ulong rdi;
 | 
						|
	abi_ulong orig_rax;
 | 
						|
/* end of arguments */
 | 
						|
/* cpu exception frame or undefined */
 | 
						|
	abi_ulong rip;
 | 
						|
	abi_ulong cs;
 | 
						|
	abi_ulong eflags;
 | 
						|
	abi_ulong rsp;
 | 
						|
	abi_ulong ss;
 | 
						|
/* top of stack page */
 | 
						|
};
 | 
						|
 | 
						|
/* Maximum number of LDT entries supported. */
 | 
						|
#define TARGET_LDT_ENTRIES	8192
 | 
						|
/* The size of each LDT entry. */
 | 
						|
#define TARGET_LDT_ENTRY_SIZE	8
 | 
						|
 | 
						|
#define TARGET_GDT_ENTRIES 16
 | 
						|
#define TARGET_GDT_ENTRY_TLS_ENTRIES 3
 | 
						|
#define TARGET_GDT_ENTRY_TLS_MIN 12
 | 
						|
#define TARGET_GDT_ENTRY_TLS_MAX 14
 | 
						|
 | 
						|
#if 0 // Redefine this
 | 
						|
struct target_modify_ldt_ldt_s {
 | 
						|
	unsigned int  entry_number;
 | 
						|
        abi_ulong     base_addr;
 | 
						|
	unsigned int  limit;
 | 
						|
	unsigned int  seg_32bit:1;
 | 
						|
	unsigned int  contents:2;
 | 
						|
	unsigned int  read_exec_only:1;
 | 
						|
	unsigned int  limit_in_pages:1;
 | 
						|
	unsigned int  seg_not_present:1;
 | 
						|
	unsigned int  useable:1;
 | 
						|
	unsigned int  lm:1;
 | 
						|
};
 | 
						|
#else
 | 
						|
struct target_modify_ldt_ldt_s {
 | 
						|
	unsigned int  entry_number;
 | 
						|
        abi_ulong     base_addr;
 | 
						|
	unsigned int  limit;
 | 
						|
        unsigned int flags;
 | 
						|
};
 | 
						|
#endif
 | 
						|
 | 
						|
struct target_ipc64_perm
 | 
						|
{
 | 
						|
	int		key;
 | 
						|
	uint32_t	uid;
 | 
						|
	uint32_t	gid;
 | 
						|
	uint32_t	cuid;
 | 
						|
	uint32_t	cgid;
 | 
						|
	unsigned short		mode;
 | 
						|
	unsigned short		__pad1;
 | 
						|
	unsigned short		seq;
 | 
						|
	unsigned short		__pad2;
 | 
						|
	abi_ulong		__unused1;
 | 
						|
	abi_ulong		__unused2;
 | 
						|
};
 | 
						|
 | 
						|
struct target_msqid64_ds {
 | 
						|
	struct target_ipc64_perm msg_perm;
 | 
						|
	unsigned int msg_stime;	/* last msgsnd time */
 | 
						|
	unsigned int msg_rtime;	/* last msgrcv time */
 | 
						|
	unsigned int msg_ctime;	/* last change time */
 | 
						|
	abi_ulong  msg_cbytes;	/* current number of bytes on queue */
 | 
						|
	abi_ulong  msg_qnum;	/* number of messages in queue */
 | 
						|
	abi_ulong  msg_qbytes;	/* max number of bytes on queue */
 | 
						|
	unsigned int msg_lspid;	/* pid of last msgsnd */
 | 
						|
	unsigned int msg_lrpid;	/* last receive pid */
 | 
						|
	abi_ulong  __unused4;
 | 
						|
	abi_ulong  __unused5;
 | 
						|
};
 | 
						|
 | 
						|
/* FreeBSD sysarch(2) */
 | 
						|
#define TARGET_FREEBSD_I386_GET_LDT	0
 | 
						|
#define TARGET_FREEBSD_I386_SET_LDT	1
 | 
						|
				/* I386_IOPL */
 | 
						|
#define TARGET_FREEBSD_I386_GET_IOPERM	3
 | 
						|
#define TARGET_FREEBSD_I386_SET_IOPERM	4
 | 
						|
				/* xxxxx */
 | 
						|
#define TARGET_FREEBSD_I386_GET_FSBASE	7
 | 
						|
#define TARGET_FREEBSD_I386_SET_FSBASE	8
 | 
						|
#define TARGET_FREEBSD_I386_GET_GSBASE	9
 | 
						|
#define TARGET_FREEBSD_I386_SET_GSBASE	10
 | 
						|
 | 
						|
#define TARGET_FREEBSD_AMD64_GET_FSBASE	128
 | 
						|
#define TARGET_FREEBSD_AMD64_SET_FSBASE	129
 | 
						|
#define TARGET_FREEBSD_AMD64_GET_GSBASE	130
 | 
						|
#define TARGET_FREEBSD_AMD64_SET_GSBASE	131
 | 
						|
 | 
						|
 | 
						|
#define UNAME_MACHINE           "x86_64"
 | 
						|
#define TARGET_HW_MACHINE       "amd64"
 | 
						|
#define TARGET_HW_MACHINE_ARCH  "amd64"
 | 
						|
 | 
						|
#define TARGET_ARCH_SET_GS 0x1001
 | 
						|
#define TARGET_ARCH_SET_FS 0x1002
 | 
						|
#define TARGET_ARCH_GET_FS 0x1003
 | 
						|
#define TARGET_ARCH_GET_GS 0x1004
 | 
						|
 | 
						|
#endif /* TARGET_SYSCALL_H */
 |