mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-07 17:53:56 -06:00
error handling: Use RETRY_ON_EINTR() macro where applicable
There is a defined RETRY_ON_EINTR() macro in qemu/osdep.h which handles the same while loop. Resolves: https://gitlab.com/qemu-project/qemu/-/issues/415 Signed-off-by: Nikita Ivanov <nivanov@cloudlinux.com> Message-Id: <20221023090422.242617-3-nivanov@cloudlinux.com> Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com> [thuth: Dropped the hunk that changed socket_accept() in libqtest.c] Signed-off-by: Thomas Huth <thuth@redhat.com>
This commit is contained in:
parent
8b6aa69365
commit
37b0b24e93
13 changed files with 45 additions and 81 deletions
|
@ -64,9 +64,7 @@ static void sigfd_handler(void *opaque)
|
|||
ssize_t len;
|
||||
|
||||
while (1) {
|
||||
do {
|
||||
len = read(fd, &info, sizeof(info));
|
||||
} while (len == -1 && errno == EINTR);
|
||||
len = RETRY_ON_EINTR(read(fd, &info, sizeof(info)));
|
||||
|
||||
if (len == -1 && errno == EAGAIN) {
|
||||
break;
|
||||
|
|
|
@ -244,9 +244,7 @@ static int qemu_lock_fcntl(int fd, int64_t start, int64_t len, int fl_type)
|
|||
.l_type = fl_type,
|
||||
};
|
||||
qemu_probe_lock_ops();
|
||||
do {
|
||||
ret = fcntl(fd, fcntl_op_setlk, &fl);
|
||||
} while (ret == -1 && errno == EINTR);
|
||||
ret = RETRY_ON_EINTR(fcntl(fd, fcntl_op_setlk, &fl));
|
||||
return ret == -1 ? -errno : 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -240,9 +240,9 @@ static int qemu_vfio_pci_read_config(QEMUVFIOState *s, void *buf,
|
|||
s->config_region_info.offset,
|
||||
s->config_region_info.size);
|
||||
assert(QEMU_IS_ALIGNED(s->config_region_info.offset + ofs, size));
|
||||
do {
|
||||
ret = pread(s->device, buf, size, s->config_region_info.offset + ofs);
|
||||
} while (ret == -1 && errno == EINTR);
|
||||
ret = RETRY_ON_EINTR(
|
||||
pread(s->device, buf, size, s->config_region_info.offset + ofs)
|
||||
);
|
||||
return ret == size ? 0 : -errno;
|
||||
}
|
||||
|
||||
|
@ -254,9 +254,9 @@ static int qemu_vfio_pci_write_config(QEMUVFIOState *s, void *buf, int size, int
|
|||
s->config_region_info.offset,
|
||||
s->config_region_info.size);
|
||||
assert(QEMU_IS_ALIGNED(s->config_region_info.offset + ofs, size));
|
||||
do {
|
||||
ret = pwrite(s->device, buf, size, s->config_region_info.offset + ofs);
|
||||
} while (ret == -1 && errno == EINTR);
|
||||
ret = RETRY_ON_EINTR(
|
||||
pwrite(s->device, buf, size, s->config_region_info.offset + ofs)
|
||||
);
|
||||
return ret == size ? 0 : -errno;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue