mirror of
https://review.haiku-os.org/haiku
synced 2025-01-18 20:48:48 +01:00
fc03b45a71
The standardized version of readv() and writev() take an int as the third parameter. Arguably a size_t makes more sense, but the standardization bodies decided otherwise. The non-standard functions of readv_pos() and writev_pos() have been updated for consistency. The corresponding _kern_readv() and _kern_writev() internal functions continue to take the size_t parameter. The ABI will not change, even though on 64 bit machines the size of the count parameter will change from 8 to 4 bytes. The actual use will be slightly different. Like with the size_t argument type, it will not be possible to give a count lower than 0. If the value is less than 0, then the B_BAD_VALUE/EINVAL error will be set. Change-Id: I949c8ed67dbc0b4e209768cbdee554c929fc242e Reviewed-on: https://review.haiku-os.org/c/haiku/+/3770 Reviewed-by: Jérôme Duval <jerome.duval@gmail.com>
36 lines
737 B
C
36 lines
737 B
C
/*
|
|
* Copyright 2002-2007, Haiku Inc. All Rights Reserved.
|
|
* Distributed under the terms of the MIT License.
|
|
*/
|
|
#ifndef _FSSH_SYS_UIO_H
|
|
#define _FSSH_SYS_UIO_H
|
|
|
|
|
|
#include "fssh_types.h"
|
|
|
|
|
|
typedef struct fssh_iovec {
|
|
void *iov_base;
|
|
fssh_size_t iov_len;
|
|
} fssh_iovec;
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
fssh_ssize_t fssh_readv(int fd, const struct fssh_iovec *vector,
|
|
int count);
|
|
fssh_ssize_t fssh_readv_pos(int fd, fssh_off_t pos, const struct
|
|
fssh_iovec *vec, int count);
|
|
fssh_ssize_t fssh_writev(int fd, const struct fssh_iovec *vector,
|
|
int count);
|
|
fssh_ssize_t fssh_writev_pos(int fd, fssh_off_t pos,
|
|
const struct fssh_iovec *vec, int count);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* _FSSH_SYS_UIO_H */
|