提交 0b6eb2df 编写于 作者: R Rich Felker

update syscalls with off_t arguments to handle argument alignment, if needed

the arm syscall abi requires 64-bit arguments to be aligned on an even
register boundary. these new macros facilitate meeting the abi
requirement without imposing significant ugliness on the code.
上级 d30c331d
#define __SYSCALL_LL(x) \ #define __SYSCALL_LL_E(x) \
((union { long long ll; long l[2]; }){ .ll = x }).l[0], \ ((union { long long ll; long l[2]; }){ .ll = x }).l[0], \
((union { long long ll; long l[2]; }){ .ll = x }).l[1] ((union { long long ll; long l[2]; }){ .ll = x }).l[1]
#define __SYSCALL_LL_O(x) 0, __SYSCALL_LL_E((x))
long (__syscall)(long, ...); long (__syscall)(long, ...);
......
#define __SYSCALL_LL(x) \ #define __SYSCALL_LL_E(x) \
((union { long long ll; long l[2]; }){ .ll = x }).l[0], \ ((union { long long ll; long l[2]; }){ .ll = x }).l[0], \
((union { long long ll; long l[2]; }){ .ll = x }).l[1] ((union { long long ll; long l[2]; }){ .ll = x }).l[1]
#define __SYSCALL_LL_O(x) __SYSCALL_LL_E((x))
static inline long __syscall0(long __n) static inline long __syscall0(long __n)
{ {
......
#define __SYSCALL_LL(x) (x) #define __SYSCALL_LL_E(x) (x)
#define __SYSCALL_LL_O(x) (x)
static inline long __syscall0(long __n) static inline long __syscall0(long __n)
{ {
......
...@@ -3,6 +3,6 @@ ...@@ -3,6 +3,6 @@
int posix_fadvise(int fd, off_t base, off_t len, int advice) int posix_fadvise(int fd, off_t base, off_t len, int advice)
{ {
return -__syscall(SYS_fadvise, fd, __SYSCALL_LL(base), return -(__syscall)(SYS_fadvise, fd, __SYSCALL_LL_O(base),
__SYSCALL_LL(len), advice); __SYSCALL_LL_E(len), advice);
} }
...@@ -3,6 +3,6 @@ ...@@ -3,6 +3,6 @@
int posix_fallocate(int fd, off_t base, off_t len) int posix_fallocate(int fd, off_t base, off_t len)
{ {
return -__syscall(SYS_fallocate, fd, __SYSCALL_LL(base), return -__syscall(SYS_fallocate, fd, __SYSCALL_LL_O(base),
__SYSCALL_LL(len)); __SYSCALL_LL_E(len));
} }
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
int ftruncate(int fd, off_t length) int ftruncate(int fd, off_t length)
{ {
return syscall(SYS_ftruncate, fd, __SYSCALL_LL(length)); return syscall(SYS_ftruncate, fd, __SYSCALL_LL_O(length));
} }
LFS64(ftruncate); LFS64(ftruncate);
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
ssize_t pread(int fd, void *buf, size_t size, off_t ofs) ssize_t pread(int fd, void *buf, size_t size, off_t ofs)
{ {
return syscall_cp(SYS_pread, fd, buf, size, __SYSCALL_LL(ofs)); return syscall_cp(SYS_pread, fd, buf, size, __SYSCALL_LL_O(ofs));
} }
LFS64(pread); LFS64(pread);
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
ssize_t pwrite(int fd, const void *buf, size_t size, off_t ofs) ssize_t pwrite(int fd, const void *buf, size_t size, off_t ofs)
{ {
return syscall_cp(SYS_pwrite, fd, buf, size, __SYSCALL_LL(ofs)); return syscall_cp(SYS_pwrite, fd, buf, size, __SYSCALL_LL_O(ofs));
} }
LFS64(pwrite); LFS64(pwrite);
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
int truncate(const char *path, off_t length) int truncate(const char *path, off_t length)
{ {
return syscall(SYS_truncate, path, __SYSCALL_LL(length)); return syscall(SYS_truncate, path, __SYSCALL_LL_O(length));
} }
LFS64(truncate); LFS64(truncate);
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册