aboutsummaryrefslogtreecommitdiff
path: root/lib/std/os/linux.zig
diff options
context:
space:
mode:
authorLemonBoy <thatlemon@gmail.com>2020-03-11 20:03:36 +0100
committerLemonBoy <thatlemon@gmail.com>2020-03-12 09:43:45 +0100
commit89d7fc773d66609a8d93106f9a6d84d479771690 (patch)
tree01712f4e68706426ac27d107f8d9227122d0ff35 /lib/std/os/linux.zig
parentf58705b4a623b39ad10fe25a9a41507fdfc0b089 (diff)
downloadzig-89d7fc773d66609a8d93106f9a6d84d479771690.tar.gz
zig-89d7fc773d66609a8d93106f9a6d84d479771690.zip
std: Fix pwrite invocation on 32bit architectures
Diffstat (limited to 'lib/std/os/linux.zig')
-rw-r--r--lib/std/os/linux.zig39
1 files changed, 37 insertions, 2 deletions
diff --git a/lib/std/os/linux.zig b/lib/std/os/linux.zig
index 719e541846..79f9ba9c95 100644
--- a/lib/std/os/linux.zig
+++ b/lib/std/os/linux.zig
@@ -350,7 +350,13 @@ pub fn pread(fd: i32, buf: [*]u8, count: usize, offset: u64) usize {
);
}
} else {
- return syscall4(SYS_pread, @bitCast(usize, @as(isize, fd)), @ptrToInt(buf), count, offset);
+ return syscall4(
+ SYS_pread,
+ @bitCast(usize, @as(isize, fd)),
+ @ptrToInt(buf),
+ count,
+ offset,
+ );
}
}
@@ -385,7 +391,36 @@ pub fn write(fd: i32, buf: [*]const u8, count: usize) usize {
}
pub fn pwrite(fd: i32, buf: [*]const u8, count: usize, offset: usize) usize {
- return syscall4(SYS_pwrite, @bitCast(usize, @as(isize, fd)), @ptrToInt(buf), count, offset);
+ if (@hasDecl(@This(), "SYS_pwrite64")) {
+ if (require_aligned_register_pair) {
+ return syscall6(
+ SYS_pwrite64,
+ @bitCast(usize, @as(isize, fd)),
+ @ptrToInt(buf),
+ count,
+ 0,
+ @truncate(usize, offset),
+ @truncate(usize, offset >> 32),
+ );
+ } else {
+ return syscall5(
+ SYS_pwrite64,
+ @bitCast(usize, @as(isize, fd)),
+ @ptrToInt(buf),
+ count,
+ @truncate(usize, offset),
+ @truncate(usize, offset >> 32),
+ );
+ }
+ } else {
+ return syscall4(
+ SYS_pwrite,
+ @bitCast(usize, @as(isize, fd)),
+ @ptrToInt(buf),
+ count,
+ offset,
+ );
+ }
}
pub fn rename(old: [*:0]const u8, new: [*:0]const u8) usize {