mirror of https://github.com/xqemu/xqemu.git
virtio-blk: Correct bug in support for flexible descriptor layout
Without this correction, only a three descriptor layout is accepted, and requests with just two descriptors are not completed and no error message is displayed. Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Signed-off-by: Marc Marí <marc.mari.barcelo@gmail.com> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
parent
220c1a2fad
commit
a83ceea8ff
|
@ -404,19 +404,19 @@ void virtio_blk_handle_request(VirtIOBlockReq *req, MultiReqBuffer *mrb)
|
||||||
* NB: per existing s/n string convention the string is
|
* NB: per existing s/n string convention the string is
|
||||||
* terminated by '\0' only when shorter than buffer.
|
* terminated by '\0' only when shorter than buffer.
|
||||||
*/
|
*/
|
||||||
strncpy(req->elem.in_sg[0].iov_base,
|
const char *serial = s->blk.serial ? s->blk.serial : "";
|
||||||
s->blk.serial ? s->blk.serial : "",
|
size_t size = MIN(strlen(serial) + 1,
|
||||||
MIN(req->elem.in_sg[0].iov_len, VIRTIO_BLK_ID_BYTES));
|
MIN(iov_size(in_iov, in_num),
|
||||||
|
VIRTIO_BLK_ID_BYTES));
|
||||||
|
iov_from_buf(in_iov, in_num, 0, serial, size);
|
||||||
virtio_blk_req_complete(req, VIRTIO_BLK_S_OK);
|
virtio_blk_req_complete(req, VIRTIO_BLK_S_OK);
|
||||||
virtio_blk_free_request(req);
|
virtio_blk_free_request(req);
|
||||||
} else if (type & VIRTIO_BLK_T_OUT) {
|
} else if (type & VIRTIO_BLK_T_OUT) {
|
||||||
qemu_iovec_init_external(&req->qiov, &req->elem.out_sg[1],
|
qemu_iovec_init_external(&req->qiov, iov, out_num);
|
||||||
req->elem.out_num - 1);
|
|
||||||
virtio_blk_handle_write(req, mrb);
|
virtio_blk_handle_write(req, mrb);
|
||||||
} else if (type == VIRTIO_BLK_T_IN || type == VIRTIO_BLK_T_BARRIER) {
|
} else if (type == VIRTIO_BLK_T_IN || type == VIRTIO_BLK_T_BARRIER) {
|
||||||
/* VIRTIO_BLK_T_IN is 0, so we can't just & it. */
|
/* VIRTIO_BLK_T_IN is 0, so we can't just & it. */
|
||||||
qemu_iovec_init_external(&req->qiov, &req->elem.in_sg[0],
|
qemu_iovec_init_external(&req->qiov, in_iov, in_num);
|
||||||
req->elem.in_num - 1);
|
|
||||||
virtio_blk_handle_read(req);
|
virtio_blk_handle_read(req);
|
||||||
} else {
|
} else {
|
||||||
virtio_blk_req_complete(req, VIRTIO_BLK_S_UNSUPP);
|
virtio_blk_req_complete(req, VIRTIO_BLK_S_UNSUPP);
|
||||||
|
|
Loading…
Reference in New Issue