if (req && req->unread_bytes) {
SMB_ASSERT(req->unread_bytes == N);
- req->unread_bytes = 0;
- return SMB_VFS_RECVFILE(smbd_server_fd(),
+ ret = SMB_VFS_RECVFILE(smbd_server_fd(),
fsp,
fsp->fh->fd,
(SMB_OFF_T)-1,
N);
+ if (ret != -1) {
+ req->unread_bytes = 0;
+ }
+ return ret;
}
while (total < N) {
if (req && req->unread_bytes) {
SMB_ASSERT(req->unread_bytes == N);
- req->unread_bytes = 0;
- return SMB_VFS_RECVFILE(smbd_server_fd(),
+ ret = SMB_VFS_RECVFILE(smbd_server_fd(),
fsp,
fsp->fh->fd,
offset,
N);
+ if (ret != -1) {
+ req->unread_bytes = 0;
+ }
+ return ret;
}
while (total < N) {