mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 03:12:44 +00:00 
			
		
		
		
	 286984750e
			
		
	
	
		286984750e
		
	
	
	
	
		
			
			Now that support for 32-bit x86 has been removed, we don't have to worry about the top half of `off_t`/`u64` values being chopped off when we try to pass them in registers. Therefore, we no longer need the workaround of pointers to stack-allocated values to syscalls. Note that this changes the system call ABI, so statically linked programs will have to be re-linked.
		
			
				
	
	
		
			34 lines
		
	
	
	
		
			739 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			34 lines
		
	
	
	
		
			739 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <bits/pthread_cancel.h>
 | |
| #include <errno.h>
 | |
| #include <sys/uio.h>
 | |
| #include <syscall.h>
 | |
| 
 | |
| extern "C" {
 | |
| 
 | |
| ssize_t writev(int fd, const struct iovec* iov, int iov_count)
 | |
| {
 | |
|     return pwritev(fd, iov, iov_count, -1);
 | |
| }
 | |
| 
 | |
| ssize_t readv(int fd, const struct iovec* iov, int iov_count)
 | |
| {
 | |
|     __pthread_maybe_cancel();
 | |
| 
 | |
|     int rc = syscall(SC_readv, fd, iov, iov_count);
 | |
|     __RETURN_WITH_ERRNO(rc, rc, -1);
 | |
| }
 | |
| 
 | |
| ssize_t pwritev(int fd, struct iovec const* iov, int iov_count, off_t offset)
 | |
| {
 | |
|     __pthread_maybe_cancel();
 | |
| 
 | |
|     int rc = syscall(SC_pwritev, fd, iov, iov_count, offset);
 | |
|     __RETURN_WITH_ERRNO(rc, rc, -1);
 | |
| }
 | |
| }
 |