提交 505b0451 编写于 作者: M Michael S. Tsirkin 提交者: Rusty Russell

virtio_console: use virtqueue_xxx wrappers

Switch virtio_console to new virtqueue_xxx wrappers.
Signed-off-by: NMichael S. Tsirkin <mst@redhat.com>
Signed-off-by: NRusty Russell <rusty@rustcorp.com.au>
上级 946cfe0e
...@@ -328,7 +328,7 @@ static void *get_inbuf(struct port *port) ...@@ -328,7 +328,7 @@ static void *get_inbuf(struct port *port)
unsigned int len; unsigned int len;
vq = port->in_vq; vq = port->in_vq;
buf = vq->vq_ops->get_buf(vq, &len); buf = virtqueue_get_buf(vq, &len);
if (buf) { if (buf) {
buf->len = len; buf->len = len;
buf->offset = 0; buf->offset = 0;
...@@ -349,8 +349,8 @@ static int add_inbuf(struct virtqueue *vq, struct port_buffer *buf) ...@@ -349,8 +349,8 @@ static int add_inbuf(struct virtqueue *vq, struct port_buffer *buf)
sg_init_one(sg, buf->buf, buf->size); sg_init_one(sg, buf->buf, buf->size);
ret = vq->vq_ops->add_buf(vq, sg, 0, 1, buf); ret = virtqueue_add_buf(vq, sg, 0, 1, buf);
vq->vq_ops->kick(vq); virtqueue_kick(vq);
return ret; return ret;
} }
...@@ -366,7 +366,7 @@ static void discard_port_data(struct port *port) ...@@ -366,7 +366,7 @@ static void discard_port_data(struct port *port)
if (port->inbuf) if (port->inbuf)
buf = port->inbuf; buf = port->inbuf;
else else
buf = vq->vq_ops->get_buf(vq, &len); buf = virtqueue_get_buf(vq, &len);
ret = 0; ret = 0;
while (buf) { while (buf) {
...@@ -374,7 +374,7 @@ static void discard_port_data(struct port *port) ...@@ -374,7 +374,7 @@ static void discard_port_data(struct port *port)
ret++; ret++;
free_buf(buf); free_buf(buf);
} }
buf = vq->vq_ops->get_buf(vq, &len); buf = virtqueue_get_buf(vq, &len);
} }
port->inbuf = NULL; port->inbuf = NULL;
if (ret) if (ret)
...@@ -421,9 +421,9 @@ static ssize_t send_control_msg(struct port *port, unsigned int event, ...@@ -421,9 +421,9 @@ static ssize_t send_control_msg(struct port *port, unsigned int event,
vq = port->portdev->c_ovq; vq = port->portdev->c_ovq;
sg_init_one(sg, &cpkt, sizeof(cpkt)); sg_init_one(sg, &cpkt, sizeof(cpkt));
if (vq->vq_ops->add_buf(vq, sg, 1, 0, &cpkt) >= 0) { if (virtqueue_add_buf(vq, sg, 1, 0, &cpkt) >= 0) {
vq->vq_ops->kick(vq); virtqueue_kick(vq);
while (!vq->vq_ops->get_buf(vq, &len)) while (!virtqueue_get_buf(vq, &len))
cpu_relax(); cpu_relax();
} }
return 0; return 0;
...@@ -439,10 +439,10 @@ static ssize_t send_buf(struct port *port, void *in_buf, size_t in_count) ...@@ -439,10 +439,10 @@ static ssize_t send_buf(struct port *port, void *in_buf, size_t in_count)
out_vq = port->out_vq; out_vq = port->out_vq;
sg_init_one(sg, in_buf, in_count); sg_init_one(sg, in_buf, in_count);
ret = out_vq->vq_ops->add_buf(out_vq, sg, 1, 0, in_buf); ret = virtqueue_add_buf(out_vq, sg, 1, 0, in_buf);
/* Tell Host to go! */ /* Tell Host to go! */
out_vq->vq_ops->kick(out_vq); virtqueue_kick(out_vq);
if (ret < 0) { if (ret < 0) {
in_count = 0; in_count = 0;
...@@ -450,7 +450,7 @@ static ssize_t send_buf(struct port *port, void *in_buf, size_t in_count) ...@@ -450,7 +450,7 @@ static ssize_t send_buf(struct port *port, void *in_buf, size_t in_count)
} }
/* Wait till the host acknowledges it pushed out the data we sent. */ /* Wait till the host acknowledges it pushed out the data we sent. */
while (!out_vq->vq_ops->get_buf(out_vq, &len)) while (!virtqueue_get_buf(out_vq, &len))
cpu_relax(); cpu_relax();
fail: fail:
/* We're expected to return the amount of data we wrote */ /* We're expected to return the amount of data we wrote */
...@@ -901,7 +901,7 @@ static int remove_port(struct port *port) ...@@ -901,7 +901,7 @@ static int remove_port(struct port *port)
discard_port_data(port); discard_port_data(port);
/* Remove buffers we queued up for the Host to send us data in. */ /* Remove buffers we queued up for the Host to send us data in. */
while ((buf = port->in_vq->vq_ops->detach_unused_buf(port->in_vq))) while ((buf = virtqueue_detach_unused_buf(port->in_vq)))
free_buf(buf); free_buf(buf);
kfree(port->name); kfree(port->name);
...@@ -1030,7 +1030,7 @@ static void control_work_handler(struct work_struct *work) ...@@ -1030,7 +1030,7 @@ static void control_work_handler(struct work_struct *work)
vq = portdev->c_ivq; vq = portdev->c_ivq;
spin_lock(&portdev->cvq_lock); spin_lock(&portdev->cvq_lock);
while ((buf = vq->vq_ops->get_buf(vq, &len))) { while ((buf = virtqueue_get_buf(vq, &len))) {
spin_unlock(&portdev->cvq_lock); spin_unlock(&portdev->cvq_lock);
buf->len = len; buf->len = len;
...@@ -1224,7 +1224,7 @@ static int add_port(struct ports_device *portdev, u32 id) ...@@ -1224,7 +1224,7 @@ static int add_port(struct ports_device *portdev, u32 id)
return 0; return 0;
free_inbufs: free_inbufs:
while ((buf = port->in_vq->vq_ops->detach_unused_buf(port->in_vq))) while ((buf = virtqueue_detach_unused_buf(port->in_vq)))
free_buf(buf); free_buf(buf);
free_device: free_device:
device_destroy(pdrvdata.class, port->dev->devt); device_destroy(pdrvdata.class, port->dev->devt);
...@@ -1536,10 +1536,10 @@ static void virtcons_remove(struct virtio_device *vdev) ...@@ -1536,10 +1536,10 @@ static void virtcons_remove(struct virtio_device *vdev)
unregister_chrdev(portdev->chr_major, "virtio-portsdev"); unregister_chrdev(portdev->chr_major, "virtio-portsdev");
while ((buf = portdev->c_ivq->vq_ops->get_buf(portdev->c_ivq, &len))) while ((buf = virtqueue_get_buf(portdev->c_ivq, &len)))
free_buf(buf); free_buf(buf);
while ((buf = portdev->c_ivq->vq_ops->detach_unused_buf(portdev->c_ivq))) while ((buf = virtqueue_detach_unused_buf(portdev->c_ivq)))
free_buf(buf); free_buf(buf);
vdev->config->del_vqs(vdev); vdev->config->del_vqs(vdev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册