mirror of
				https://git.proxmox.com/git/qemu
				synced 2025-10-25 19:30:16 +00:00 
			
		
		
		
	 4ce6243dc6
			
		
	
	
		4ce6243dc6
		
	
	
	
	
		
			
			Linux manages to have three separate orderings of the arguments to the clone() syscall on different architectures. In the kernel these are selected via CONFIG_CLONE_BACKWARDS and CONFIG_CLONE_BACKWARDS2. Clean up our implementation of this to use similar #define names rather than a TARGET_* ifdef ladder. This includes behaviour changes fixing bugs on cris, x86-64, m68k, openrisc and unicore32. cris had explicit but wrong handling; the others were just incorrectly using QEMU's default, which happened to be the equivalent of CONFIG_CLONE_BACKWARDS. (unicore32 appears to be broken in the mainline kernel in that it tries to use arg3 for both parent_tidptr and newtls simultaneously -- we don't attempt to emulate this bug...) Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Riku Voipio <riku.voipio@linaro.org>
		
			
				
	
	
		
			149 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* default linux values for the selectors */
 | |
| #define __USER_CS	(0x23)
 | |
| #define __USER_DS	(0x2B)
 | |
| 
 | |
| struct target_pt_regs {
 | |
| 	long ebx;
 | |
| 	long ecx;
 | |
| 	long edx;
 | |
| 	long esi;
 | |
| 	long edi;
 | |
| 	long ebp;
 | |
| 	long eax;
 | |
| 	int  xds;
 | |
| 	int  xes;
 | |
| 	long orig_eax;
 | |
| 	long eip;
 | |
| 	int  xcs;
 | |
| 	long eflags;
 | |
| 	long esp;
 | |
| 	int  xss;
 | |
| };
 | |
| 
 | |
| /* ioctls */
 | |
| 
 | |
| #define TARGET_LDT_ENTRIES      8192
 | |
| #define TARGET_LDT_ENTRY_SIZE	8
 | |
| 
 | |
| #define TARGET_GDT_ENTRIES             9
 | |
| #define TARGET_GDT_ENTRY_TLS_ENTRIES   3
 | |
| #define TARGET_GDT_ENTRY_TLS_MIN       6
 | |
| #define TARGET_GDT_ENTRY_TLS_MAX       (TARGET_GDT_ENTRY_TLS_MIN + TARGET_GDT_ENTRY_TLS_ENTRIES - 1)
 | |
| 
 | |
| struct target_modify_ldt_ldt_s {
 | |
|     unsigned int  entry_number;
 | |
|     abi_ulong base_addr;
 | |
|     unsigned int limit;
 | |
|     unsigned int flags;
 | |
| };
 | |
| 
 | |
| /* vm86 defines */
 | |
| 
 | |
| #define TARGET_BIOSSEG		0x0f000
 | |
| 
 | |
| #define TARGET_CPU_086		0
 | |
| #define TARGET_CPU_186		1
 | |
| #define TARGET_CPU_286		2
 | |
| #define TARGET_CPU_386		3
 | |
| #define TARGET_CPU_486		4
 | |
| #define TARGET_CPU_586		5
 | |
| 
 | |
| #define TARGET_VM86_SIGNAL	0	/* return due to signal */
 | |
| #define TARGET_VM86_UNKNOWN	1	/* unhandled GP fault - IO-instruction or similar */
 | |
| #define TARGET_VM86_INTx	2	/* int3/int x instruction (ARG = x) */
 | |
| #define TARGET_VM86_STI	3	/* sti/popf/iret instruction enabled virtual interrupts */
 | |
| 
 | |
| /*
 | |
|  * Additional return values when invoking new vm86()
 | |
|  */
 | |
| #define TARGET_VM86_PICRETURN	4	/* return due to pending PIC request */
 | |
| #define TARGET_VM86_TRAP	6	/* return due to DOS-debugger request */
 | |
| 
 | |
| /*
 | |
|  * function codes when invoking new vm86()
 | |
|  */
 | |
| #define TARGET_VM86_PLUS_INSTALL_CHECK	0
 | |
| #define TARGET_VM86_ENTER		1
 | |
| #define TARGET_VM86_ENTER_NO_BYPASS	2
 | |
| #define	TARGET_VM86_REQUEST_IRQ	3
 | |
| #define TARGET_VM86_FREE_IRQ		4
 | |
| #define TARGET_VM86_GET_IRQ_BITS	5
 | |
| #define TARGET_VM86_GET_AND_RESET_IRQ	6
 | |
| 
 | |
| /*
 | |
|  * This is the stack-layout seen by the user space program when we have
 | |
|  * done a translation of "SAVE_ALL" from vm86 mode. The real kernel layout
 | |
|  * is 'kernel_vm86_regs' (see below).
 | |
|  */
 | |
| 
 | |
| struct target_vm86_regs {
 | |
| /*
 | |
|  * normal regs, with special meaning for the segment descriptors..
 | |
|  */
 | |
| 	abi_long ebx;
 | |
| 	abi_long ecx;
 | |
| 	abi_long edx;
 | |
| 	abi_long esi;
 | |
| 	abi_long edi;
 | |
| 	abi_long ebp;
 | |
| 	abi_long eax;
 | |
| 	abi_long __null_ds;
 | |
| 	abi_long __null_es;
 | |
| 	abi_long __null_fs;
 | |
| 	abi_long __null_gs;
 | |
| 	abi_long orig_eax;
 | |
| 	abi_long eip;
 | |
| 	unsigned short cs, __csh;
 | |
| 	abi_long eflags;
 | |
| 	abi_long esp;
 | |
| 	unsigned short ss, __ssh;
 | |
| /*
 | |
|  * these are specific to v86 mode:
 | |
|  */
 | |
| 	unsigned short es, __esh;
 | |
| 	unsigned short ds, __dsh;
 | |
| 	unsigned short fs, __fsh;
 | |
| 	unsigned short gs, __gsh;
 | |
| };
 | |
| 
 | |
| struct target_revectored_struct {
 | |
| 	abi_ulong __map[8];			/* 256 bits */
 | |
| };
 | |
| 
 | |
| struct target_vm86_struct {
 | |
| 	struct target_vm86_regs regs;
 | |
| 	abi_ulong flags;
 | |
| 	abi_ulong screen_bitmap;
 | |
| 	abi_ulong cpu_type;
 | |
| 	struct target_revectored_struct int_revectored;
 | |
| 	struct target_revectored_struct int21_revectored;
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * flags masks
 | |
|  */
 | |
| #define TARGET_VM86_SCREEN_BITMAP	0x0001
 | |
| 
 | |
| struct target_vm86plus_info_struct {
 | |
|         abi_ulong flags;
 | |
| #define TARGET_force_return_for_pic (1 << 0)
 | |
| #define TARGET_vm86dbg_active       (1 << 1)  /* for debugger */
 | |
| #define TARGET_vm86dbg_TFpendig     (1 << 2)  /* for debugger */
 | |
| #define TARGET_is_vm86pus           (1 << 31) /* for vm86 internal use */
 | |
| 	unsigned char vm86dbg_intxxtab[32];   /* for debugger */
 | |
| };
 | |
| 
 | |
| struct target_vm86plus_struct {
 | |
| 	struct target_vm86_regs regs;
 | |
| 	abi_ulong flags;
 | |
| 	abi_ulong screen_bitmap;
 | |
| 	abi_ulong cpu_type;
 | |
| 	struct target_revectored_struct int_revectored;
 | |
| 	struct target_revectored_struct int21_revectored;
 | |
| 	struct target_vm86plus_info_struct vm86plus;
 | |
| };
 | |
| 
 | |
| #define UNAME_MACHINE "i686"
 | |
| 
 | |
| #define TARGET_CLONE_BACKWARDS
 |