diff options
author | Riku Voipio <riku.voipio@iki.fi> | 2011-06-20 16:24:39 +0300 |
---|---|---|
committer | Riku Voipio <riku.voipio@iki.fi> | 2011-06-21 20:30:10 +0300 |
commit | bfcedc572bb77f3d21cd3a297b4215389a2f7df4 (patch) | |
tree | 881c5f0a391bb77df1e3758ccb9d75aeed7286da /linux-user | |
parent | c7b016ba04aa0ba71e068deb24163fb8b4dcd421 (diff) | |
download | qemu-bfcedc572bb77f3d21cd3a297b4215389a2f7df4.zip qemu-bfcedc572bb77f3d21cd3a297b4215389a2f7df4.tar.gz qemu-bfcedc572bb77f3d21cd3a297b4215389a2f7df4.tar.bz2 |
linux-user: Fix sync_file_range on 32bit mips
As noticed while looking at "Bump do_syscall() up to 8 syscall arguments"
patch, sync_file_range uses a pad argument on 32bit mips. Deal with it
by reading the correct arguments when on mips.
Signed-off-by: Riku Voipio <riku.voipio@iki.fi>
Diffstat (limited to 'linux-user')
-rw-r--r-- | linux-user/syscall.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/linux-user/syscall.c b/linux-user/syscall.c index 9e14937..fed7a8f 100644 --- a/linux-user/syscall.c +++ b/linux-user/syscall.c @@ -7862,8 +7862,13 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1, #if defined(TARGET_NR_sync_file_range) case TARGET_NR_sync_file_range: #if TARGET_ABI_BITS == 32 +#if defined(TARGET_MIPS) + ret = get_errno(sync_file_range(arg1, target_offset64(arg3, arg4), + target_offset64(arg5, arg6), arg7)); +#else ret = get_errno(sync_file_range(arg1, target_offset64(arg2, arg3), target_offset64(arg4, arg5), arg6)); +#endif /* !TARGET_MIPS */ #else ret = get_errno(sync_file_range(arg1, arg2, arg3, arg4)); #endif |