mirror of https://github.com/xqemu/xqemu.git
migration: size_t'ify some of qemu-file
This is a start on using size_t more in qemu-file and friends; it fixes up QEMUFilePutBufferFunc and QEMUFileGetBufferFunc to take size_t lengths and return ssize_t return values (like read(2)) and fixes up all the different implementations of them. Note that I've not yet followed this deeply into bdrv_ implementations. Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com> Message-Id: <1439463094-5394-5-git-send-email-dgilbert@redhat.com> Reviewed-by: zhanghailiang <zhang.zhanghailiang@huawei.com> Reviewed-by: Amit Shah <amit.shah@redhat.com> Signed-off-by: Amit Shah <amit.shah@redhat.com>
This commit is contained in:
parent
c50766f5a9
commit
a202a4c001
|
@ -31,15 +31,15 @@
|
||||||
* The pos argument can be ignored if the file is only being used for
|
* The pos argument can be ignored if the file is only being used for
|
||||||
* streaming. The handler should try to write all of the data it can.
|
* streaming. The handler should try to write all of the data it can.
|
||||||
*/
|
*/
|
||||||
typedef int (QEMUFilePutBufferFunc)(void *opaque, const uint8_t *buf,
|
typedef ssize_t (QEMUFilePutBufferFunc)(void *opaque, const uint8_t *buf,
|
||||||
int64_t pos, int size);
|
int64_t pos, size_t size);
|
||||||
|
|
||||||
/* Read a chunk of data from a file at the given position. The pos argument
|
/* Read a chunk of data from a file at the given position. The pos argument
|
||||||
* can be ignored if the file is only be used for streaming. The number of
|
* can be ignored if the file is only be used for streaming. The number of
|
||||||
* bytes actually read should be returned.
|
* bytes actually read should be returned.
|
||||||
*/
|
*/
|
||||||
typedef int (QEMUFileGetBufferFunc)(void *opaque, uint8_t *buf,
|
typedef ssize_t (QEMUFileGetBufferFunc)(void *opaque, uint8_t *buf,
|
||||||
int64_t pos, int size);
|
int64_t pos, size_t size);
|
||||||
|
|
||||||
/* Close a file
|
/* Close a file
|
||||||
*
|
*
|
||||||
|
|
|
@ -372,7 +372,8 @@ typedef struct QEMUBuffer {
|
||||||
bool qsb_allocated;
|
bool qsb_allocated;
|
||||||
} QEMUBuffer;
|
} QEMUBuffer;
|
||||||
|
|
||||||
static int buf_get_buffer(void *opaque, uint8_t *buf, int64_t pos, int size)
|
static ssize_t buf_get_buffer(void *opaque, uint8_t *buf, int64_t pos,
|
||||||
|
size_t size)
|
||||||
{
|
{
|
||||||
QEMUBuffer *s = opaque;
|
QEMUBuffer *s = opaque;
|
||||||
ssize_t len = qsb_get_length(s->qsb) - pos;
|
ssize_t len = qsb_get_length(s->qsb) - pos;
|
||||||
|
@ -387,8 +388,8 @@ static int buf_get_buffer(void *opaque, uint8_t *buf, int64_t pos, int size)
|
||||||
return qsb_get_buffer(s->qsb, pos, len, buf);
|
return qsb_get_buffer(s->qsb, pos, len, buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int buf_put_buffer(void *opaque, const uint8_t *buf,
|
static ssize_t buf_put_buffer(void *opaque, const uint8_t *buf,
|
||||||
int64_t pos, int size)
|
int64_t pos, size_t size)
|
||||||
{
|
{
|
||||||
QEMUBuffer *s = opaque;
|
QEMUBuffer *s = opaque;
|
||||||
|
|
||||||
|
|
|
@ -37,11 +37,11 @@ static int stdio_get_fd(void *opaque)
|
||||||
return fileno(s->stdio_file);
|
return fileno(s->stdio_file);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int stdio_put_buffer(void *opaque, const uint8_t *buf, int64_t pos,
|
static ssize_t stdio_put_buffer(void *opaque, const uint8_t *buf, int64_t pos,
|
||||||
int size)
|
size_t size)
|
||||||
{
|
{
|
||||||
QEMUFileStdio *s = opaque;
|
QEMUFileStdio *s = opaque;
|
||||||
int res;
|
size_t res;
|
||||||
|
|
||||||
res = fwrite(buf, 1, size, s->stdio_file);
|
res = fwrite(buf, 1, size, s->stdio_file);
|
||||||
|
|
||||||
|
@ -51,11 +51,12 @@ static int stdio_put_buffer(void *opaque, const uint8_t *buf, int64_t pos,
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int stdio_get_buffer(void *opaque, uint8_t *buf, int64_t pos, int size)
|
static ssize_t stdio_get_buffer(void *opaque, uint8_t *buf, int64_t pos,
|
||||||
|
size_t size)
|
||||||
{
|
{
|
||||||
QEMUFileStdio *s = opaque;
|
QEMUFileStdio *s = opaque;
|
||||||
FILE *fp = s->stdio_file;
|
FILE *fp = s->stdio_file;
|
||||||
int bytes;
|
ssize_t bytes;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
clearerr(fp);
|
clearerr(fp);
|
||||||
|
|
|
@ -54,7 +54,8 @@ static int socket_get_fd(void *opaque)
|
||||||
return s->fd;
|
return s->fd;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int socket_get_buffer(void *opaque, uint8_t *buf, int64_t pos, int size)
|
static ssize_t socket_get_buffer(void *opaque, uint8_t *buf, int64_t pos,
|
||||||
|
size_t size)
|
||||||
{
|
{
|
||||||
QEMUFileSocket *s = opaque;
|
QEMUFileSocket *s = opaque;
|
||||||
ssize_t len;
|
ssize_t len;
|
||||||
|
@ -138,7 +139,8 @@ static ssize_t unix_writev_buffer(void *opaque, struct iovec *iov, int iovcnt,
|
||||||
return total;
|
return total;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int unix_get_buffer(void *opaque, uint8_t *buf, int64_t pos, int size)
|
static ssize_t unix_get_buffer(void *opaque, uint8_t *buf, int64_t pos,
|
||||||
|
size_t size)
|
||||||
{
|
{
|
||||||
QEMUFileSocket *s = opaque;
|
QEMUFileSocket *s = opaque;
|
||||||
ssize_t len;
|
ssize_t len;
|
||||||
|
|
|
@ -2519,8 +2519,8 @@ static void *qemu_rdma_data_init(const char *host_port, Error **errp)
|
||||||
* SEND messages for control only.
|
* SEND messages for control only.
|
||||||
* VM's ram is handled with regular RDMA messages.
|
* VM's ram is handled with regular RDMA messages.
|
||||||
*/
|
*/
|
||||||
static int qemu_rdma_put_buffer(void *opaque, const uint8_t *buf,
|
static ssize_t qemu_rdma_put_buffer(void *opaque, const uint8_t *buf,
|
||||||
int64_t pos, int size)
|
int64_t pos, size_t size)
|
||||||
{
|
{
|
||||||
QEMUFileRDMA *r = opaque;
|
QEMUFileRDMA *r = opaque;
|
||||||
QEMUFile *f = r->file;
|
QEMUFile *f = r->file;
|
||||||
|
@ -2547,7 +2547,8 @@ static int qemu_rdma_put_buffer(void *opaque, const uint8_t *buf,
|
||||||
r->len = MIN(remaining, RDMA_SEND_INCREMENT);
|
r->len = MIN(remaining, RDMA_SEND_INCREMENT);
|
||||||
remaining -= r->len;
|
remaining -= r->len;
|
||||||
|
|
||||||
head.len = r->len;
|
/* Guaranteed to fit due to RDMA_SEND_INCREMENT MIN above */
|
||||||
|
head.len = (uint32_t)r->len;
|
||||||
head.type = RDMA_CONTROL_QEMU_FILE;
|
head.type = RDMA_CONTROL_QEMU_FILE;
|
||||||
|
|
||||||
ret = qemu_rdma_exchange_send(rdma, &head, data, NULL, NULL, NULL);
|
ret = qemu_rdma_exchange_send(rdma, &head, data, NULL, NULL, NULL);
|
||||||
|
@ -2564,7 +2565,7 @@ static int qemu_rdma_put_buffer(void *opaque, const uint8_t *buf,
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t qemu_rdma_fill(RDMAContext *rdma, uint8_t *buf,
|
static size_t qemu_rdma_fill(RDMAContext *rdma, uint8_t *buf,
|
||||||
int size, int idx)
|
size_t size, int idx)
|
||||||
{
|
{
|
||||||
size_t len = 0;
|
size_t len = 0;
|
||||||
|
|
||||||
|
@ -2585,8 +2586,8 @@ static size_t qemu_rdma_fill(RDMAContext *rdma, uint8_t *buf,
|
||||||
* RDMA links don't use bytestreams, so we have to
|
* RDMA links don't use bytestreams, so we have to
|
||||||
* return bytes to QEMUFile opportunistically.
|
* return bytes to QEMUFile opportunistically.
|
||||||
*/
|
*/
|
||||||
static int qemu_rdma_get_buffer(void *opaque, uint8_t *buf,
|
static ssize_t qemu_rdma_get_buffer(void *opaque, uint8_t *buf,
|
||||||
int64_t pos, int size)
|
int64_t pos, size_t size)
|
||||||
{
|
{
|
||||||
QEMUFileRDMA *r = opaque;
|
QEMUFileRDMA *r = opaque;
|
||||||
RDMAContext *rdma = r->rdma;
|
RDMAContext *rdma = r->rdma;
|
||||||
|
|
|
@ -138,14 +138,15 @@ static ssize_t block_writev_buffer(void *opaque, struct iovec *iov, int iovcnt,
|
||||||
return qiov.size;
|
return qiov.size;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int block_put_buffer(void *opaque, const uint8_t *buf,
|
static ssize_t block_put_buffer(void *opaque, const uint8_t *buf,
|
||||||
int64_t pos, int size)
|
int64_t pos, size_t size)
|
||||||
{
|
{
|
||||||
bdrv_save_vmstate(opaque, buf, pos, size);
|
bdrv_save_vmstate(opaque, buf, pos, size);
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int block_get_buffer(void *opaque, uint8_t *buf, int64_t pos, int size)
|
static ssize_t block_get_buffer(void *opaque, uint8_t *buf, int64_t pos,
|
||||||
|
size_t size)
|
||||||
{
|
{
|
||||||
return bdrv_load_vmstate(opaque, buf, pos, size);
|
return bdrv_load_vmstate(opaque, buf, pos, size);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1442,7 +1442,7 @@ qemu_rdma_exchange_get_response_none(const char *desc, int type) "Surprise: got
|
||||||
qemu_rdma_exchange_send_issue_callback(void) ""
|
qemu_rdma_exchange_send_issue_callback(void) ""
|
||||||
qemu_rdma_exchange_send_waiting(const char *desc) "Waiting for response %s"
|
qemu_rdma_exchange_send_waiting(const char *desc) "Waiting for response %s"
|
||||||
qemu_rdma_exchange_send_received(const char *desc) "Response %s received."
|
qemu_rdma_exchange_send_received(const char *desc) "Response %s received."
|
||||||
qemu_rdma_fill(int64_t control_len, int size) "RDMA %" PRId64 " of %d bytes already in buffer"
|
qemu_rdma_fill(size_t control_len, size_t size) "RDMA %zd of %zd bytes already in buffer"
|
||||||
qemu_rdma_init_ram_blocks(int blocks) "Allocated %d local ram block structures"
|
qemu_rdma_init_ram_blocks(int blocks) "Allocated %d local ram block structures"
|
||||||
qemu_rdma_poll_recv(const char *compstr, int64_t comp, int64_t id, int sent) "completion %s #%" PRId64 " received (%" PRId64 ") left %d"
|
qemu_rdma_poll_recv(const char *compstr, int64_t comp, int64_t id, int sent) "completion %s #%" PRId64 " received (%" PRId64 ") left %d"
|
||||||
qemu_rdma_poll_write(const char *compstr, int64_t comp, int left, uint64_t block, uint64_t chunk, void *local, void *remote) "completions %s (%" PRId64 ") left %d, block %" PRIu64 ", chunk: %" PRIu64 " %p %p"
|
qemu_rdma_poll_write(const char *compstr, int64_t comp, int left, uint64_t block, uint64_t chunk, void *local, void *remote) "completions %s (%" PRId64 ") left %d, block %" PRIu64 ", chunk: %" PRIu64 " %p %p"
|
||||||
|
|
Loading…
Reference in New Issue