Thread (10 messages) 10 messages, 2 authors, 2018-07-11

Re: [virtio-dev] Re: [PATCH net-next v1 4/5] virtio_ring: add event idx support in packed ring

From: Tiwei Bie <hidden>
Date: 2018-07-11 01:09:23
Also in: lkml

On Tue, Jul 10, 2018 at 01:50:03PM +0800, Jason Wang wrote:
On 2018年07月09日 15:22, Tiwei Bie wrote:
quoted
@@ -1059,9 +1059,19 @@ static bool virtqueue_kick_prepare_packed(struct virtqueue *_vq)
  	 * suppressions. */
  	virtio_mb(vq->weak_barriers);
+	old = vq->next_avail_idx - vq->num_added;
+	new = vq->next_avail_idx;
+	vq->num_added = 0;
+
  	snapshot = *(u32 *)vq->vring_packed.device;
I think we should use READ_ONCE() to prevent compiler from re-reading.
I'll do it. Thanks!

Best regards,
Tiwei Bie
quoted
+	off_wrap = virtio16_to_cpu(_vq->vdev, (__virtio16)(snapshot & 0xffff));
  	flags = virtio16_to_cpu(_vq->vdev, (__virtio16)(snapshot >> 16)) & 0x3;
+	wrap_counter = off_wrap >> 15;
+	event_idx = off_wrap & ~(1 << 15);
+	if (wrap_counter != vq->avail_wrap_counter)
+		event_idx -= vq->vring_packed.num;
Thanks
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help