kernel/fs: fix previous commit logic
fix #16598 Change-Id: Ie34c1563bd34dbe9c6cda92e41a2d5a96d20c3b1 Reviewed-on: https://review.haiku-os.org/c/haiku/+/3383 Reviewed-by: Jacob Secunda <secundaja@gmail.com> Reviewed-by: Jérôme Duval <jerome.duval@gmail.com>
This commit is contained in:
parent
2a849a6457
commit
21ba652bab
@ -748,7 +748,7 @@ common_user_io(int fd, off_t pos, void* buffer, size_t length, bool write)
|
||||
}
|
||||
|
||||
bool movePosition = false;
|
||||
if (pos == -1 && (!write || (descriptor->open_mode & O_APPEND) == 0)) {
|
||||
if (pos == -1) {
|
||||
pos = descriptor->pos;
|
||||
movePosition = true;
|
||||
}
|
||||
@ -768,10 +768,10 @@ common_user_io(int fd, off_t pos, void* buffer, size_t length, bool write)
|
||||
if (status != B_OK)
|
||||
return status;
|
||||
|
||||
if (movePosition)
|
||||
descriptor->pos = pos + length;
|
||||
else if (pos == -1)
|
||||
descriptor->pos = descriptor->ops->fd_seek(descriptor, 0, SEEK_END);
|
||||
if (movePosition) {
|
||||
descriptor->pos = write && (descriptor->open_mode & O_APPEND) != 0
|
||||
? descriptor->ops->fd_seek(descriptor, 0, SEEK_END) : pos + length;
|
||||
}
|
||||
|
||||
return length <= SSIZE_MAX ? (ssize_t)length : SSIZE_MAX;
|
||||
}
|
||||
@ -810,7 +810,7 @@ common_user_vector_io(int fd, off_t pos, const iovec* userVecs, size_t count,
|
||||
return B_BAD_ADDRESS;
|
||||
|
||||
bool movePosition = false;
|
||||
if (pos == -1 && (!write || (descriptor->open_mode & O_APPEND) == 0)) {
|
||||
if (pos == -1) {
|
||||
pos = descriptor->pos;
|
||||
movePosition = true;
|
||||
}
|
||||
@ -854,17 +854,16 @@ common_user_vector_io(int fd, off_t pos, const iovec* userVecs, size_t count,
|
||||
else
|
||||
bytesTransferred += (ssize_t)length;
|
||||
|
||||
if (pos > -1)
|
||||
pos += length;
|
||||
pos += length;
|
||||
|
||||
if (length < vecs[i].iov_len)
|
||||
break;
|
||||
}
|
||||
|
||||
if (movePosition)
|
||||
descriptor->pos = pos;
|
||||
else if (pos == -1)
|
||||
descriptor->pos = descriptor->ops->fd_seek(descriptor, 0, SEEK_END);
|
||||
if (movePosition) {
|
||||
descriptor->pos = write && (descriptor->open_mode & O_APPEND) != 0
|
||||
? descriptor->ops->fd_seek(descriptor, 0, SEEK_END) : pos;
|
||||
}
|
||||
|
||||
return bytesTransferred;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user