mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-18 15:42:09 -06:00
Fix Sparc64 stat system call
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3053 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
17d996e1f1
commit
1b8dd648bd
2 changed files with 59 additions and 1 deletions
|
@ -3535,7 +3535,7 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3,
|
|||
struct target_stat *target_st;
|
||||
|
||||
lock_user_struct(target_st, arg2, 0);
|
||||
#if defined(TARGET_MIPS)
|
||||
#if defined(TARGET_MIPS) || defined(TARGET_SPARC64)
|
||||
target_st->st_dev = tswap32(st.st_dev);
|
||||
#else
|
||||
target_st->st_dev = tswap16(st.st_dev);
|
||||
|
@ -3545,6 +3545,10 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3,
|
|||
target_st->st_mode = tswapl(st.st_mode); /* XXX: check this */
|
||||
target_st->st_uid = tswap32(st.st_uid);
|
||||
target_st->st_gid = tswap32(st.st_gid);
|
||||
#elif defined(TARGET_SPARC64)
|
||||
target_st->st_mode = tswap32(st.st_mode);
|
||||
target_st->st_uid = tswap32(st.st_uid);
|
||||
target_st->st_gid = tswap32(st.st_gid);
|
||||
#else
|
||||
target_st->st_mode = tswap16(st.st_mode);
|
||||
target_st->st_uid = tswap16(st.st_uid);
|
||||
|
@ -3554,6 +3558,9 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3,
|
|||
/* If this is the same on PPC, then just merge w/ the above ifdef */
|
||||
target_st->st_nlink = tswapl(st.st_nlink);
|
||||
target_st->st_rdev = tswapl(st.st_rdev);
|
||||
#elif defined(TARGET_SPARC64)
|
||||
target_st->st_nlink = tswap32(st.st_nlink);
|
||||
target_st->st_rdev = tswap32(st.st_rdev);
|
||||
#else
|
||||
target_st->st_nlink = tswap16(st.st_nlink);
|
||||
target_st->st_rdev = tswap16(st.st_rdev);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue