External email: Use caution opening links or attachments
Avihai Horon <avihaih@nvidia.com> wrote:
Add new function qemu_file_get_to_fd() that allows reading data from
QEMUFile and writing it straight into a given fd.
This will be used later in VFIO migration code.
Signed-off-by: Avihai Horon <avihaih@nvidia.com>
---
migration/qemu-file.c | 34 ++++++++++++++++++++++++++++++++++
migration/qemu-file.h | 1 +
2 files changed, 35 insertions(+)
diff --git a/migration/qemu-file.c b/migration/qemu-file.c
index 1479cddad9..cad3d32eb3 100644
--- a/migration/qemu-file.c
+++ b/migration/qemu-file.c
@@ -867,3 +867,37 @@ QIOChannel *qemu_file_get_ioc(QEMUFile *file)
{
return file->has_ioc ? QIO_CHANNEL(file->opaque) : NULL;
}
+
+/*
+ * Read size bytes from QEMUFile f and write them to fd.
+ */
+int qemu_file_get_to_fd(QEMUFile *f, int fd, size_t size)
+{
+ while (size) {
+ size_t pending = f->buf_size - f->buf_index;
+ ssize_t rc;
+
+ if (!pending) {
+ rc = qemu_fill_buffer(f);
+ if (rc < 0) {
+ return rc;
+ }
+ if (rc == 0) {
+ return -1;
+ }
+ continue;
+ }
+
+ rc = write(fd, f->buf + f->buf_index, MIN(pending, size));
+ if (rc < 0) {
+ return rc;
+ }
+ if (rc == 0) {
+ return -1;
+ }
+ f->buf_index += rc;
+ size -= rc;
+ }
+
+ return 0;
+}
Is there a really performance difference to just use:
uint8_t buffer[size];
qemu_get_buffer(f, buffer, size);
write(fd, buffer, size);
Or telling it otherwise, what sizes are we talking here?