提交 27725c1d 编写于 作者: B bellard

ia64 support - fcntl uses TARGET_ constants


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@112 c046a42c-6fe2-441c-8c8c-71466251a162
上级 e026db58
...@@ -85,7 +85,7 @@ long do_rt_sigreturn(CPUX86State *env); ...@@ -85,7 +85,7 @@ long do_rt_sigreturn(CPUX86State *env);
#define __NR_sys_getdents64 __NR_getdents64 #define __NR_sys_getdents64 __NR_getdents64
#define __NR_sys_rt_sigqueueinfo __NR_rt_sigqueueinfo #define __NR_sys_rt_sigqueueinfo __NR_rt_sigqueueinfo
#ifdef __alpha__ #if defined(__alpha__) || defined (__ia64__)
#define __NR__llseek __NR_lseek #define __NR__llseek __NR_lseek
#endif #endif
...@@ -1163,7 +1163,11 @@ int do_fork(CPUX86State *env, unsigned int flags, unsigned long newsp) ...@@ -1163,7 +1163,11 @@ int do_fork(CPUX86State *env, unsigned int flags, unsigned long newsp)
new_env->regs[R_ESP] = newsp; new_env->regs[R_ESP] = newsp;
new_env->regs[R_EAX] = 0; new_env->regs[R_EAX] = 0;
new_env->opaque = ts; new_env->opaque = ts;
ret = clone(clone_func, new_stack + NEW_STACK_SIZE, flags, new_env); #ifdef __ia64__
ret = clone2(clone_func, new_stack + NEW_STACK_SIZE, flags, new_env);
#else
ret = clone(clone_func, new_stack + NEW_STACK_SIZE, flags, new_env);
#endif
} else { } else {
/* if no CLONE_VM, we consider it is a fork */ /* if no CLONE_VM, we consider it is a fork */
if ((flags & ~CSIGNAL) != 0) if ((flags & ~CSIGNAL) != 0)
...@@ -1419,7 +1423,7 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3, ...@@ -1419,7 +1423,7 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3,
struct target_flock *target_fl = (void *)arg3; struct target_flock *target_fl = (void *)arg3;
switch(arg2) { switch(arg2) {
case F_GETLK: case TARGET_F_GETLK:
ret = get_errno(fcntl(arg1, arg2, &fl)); ret = get_errno(fcntl(arg1, arg2, &fl));
if (ret == 0) { if (ret == 0) {
target_fl->l_type = tswap16(fl.l_type); target_fl->l_type = tswap16(fl.l_type);
...@@ -1430,8 +1434,8 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3, ...@@ -1430,8 +1434,8 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3,
} }
break; break;
case F_SETLK: case TARGET_F_SETLK:
case F_SETLKW: case TARGET_F_SETLKW:
fl.l_type = tswap16(target_fl->l_type); fl.l_type = tswap16(target_fl->l_type);
fl.l_whence = tswap16(target_fl->l_whence); fl.l_whence = tswap16(target_fl->l_whence);
fl.l_start = tswapl(target_fl->l_start); fl.l_start = tswapl(target_fl->l_start);
...@@ -1440,9 +1444,9 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3, ...@@ -1440,9 +1444,9 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3,
ret = get_errno(fcntl(arg1, arg2, &fl)); ret = get_errno(fcntl(arg1, arg2, &fl));
break; break;
case F_GETLK64: case TARGET_F_GETLK64:
case F_SETLK64: case TARGET_F_SETLK64:
case F_SETLKW64: case TARGET_F_SETLKW64:
goto unimplemented; goto unimplemented;
default: default:
ret = get_errno(fcntl(arg1, arg2, arg3)); ret = get_errno(fcntl(arg1, arg2, arg3));
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册