Received: by 2002:a25:b794:0:0:0:0:0 with SMTP id n20csp7804081ybh; Thu, 8 Aug 2019 23:51:07 -0700 (PDT) X-Google-Smtp-Source: APXvYqy1MGkuiKgTm7Tmy6CO4PCf3IubRgLJDvxrnQZcTHUPS0FPM9KoIKwRBCaKQeyCqUM3S/cu X-Received: by 2002:a63:1749:: with SMTP id 9mr16485102pgx.0.1565333467168; Thu, 08 Aug 2019 23:51:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565333467; cv=none; d=google.com; s=arc-20160816; b=aYFUcFKsiYDaRx+DdAOqu9UulPTaRWl+GWC/A4I216w61x3+wOZoVCl2dclQqnnzKB yT3jLBt7/oq78GwcgV9QVCopNR8mT4OdhHvb/B3bM/Ujm4AM30XZYjXJ4PpmSeB8WnkP EN/PCuJ2xXeIEmWolLWC4yJegSIP+mNlQB0wqIdWRmzfZAOJ7Q1mdkkDSXoWeafbwHLc p/H4FKTKqzgdNDCvWSnFVLfnu+4pjzon0XS7RTgUXye657xWG9uPK/bQF3b+MpqSN9XT 9+FDgvtOKDUkbSJESHhnZt7eu7JilEUECCPI8Wu2glmJtpHNqi6seK2kS/kvm80U4Vao 691w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=NkDbgle7tHiXHvwLpMj2r0eULzhOfrlyRxGeoxF82E0=; b=yUynlKgGjHlBwjSOzghQoyfWDbyAjyHS6cgdQgQtqJr9AXnfbfheRaiySTJwcolFZS grU5YiYQfMcuZjeQ7Zl5Y03XRLWD0FGYYbOX15khtNmAW0iqKzBU6S+kxgKNpr46RVnB mVHrPDe7SImEaWOlnQ4TSvqPfiFgEVQH6q0MKSQCCj0yRErHtMJzuzg9PgkoTDliMUcT ZMyEPB9TJWxXor0l30wD92pK1OCVq57QNna3KzI5CZQGIkooAF/yd+3mvHydFROsSvUI ot9saK+s2Q+QNZhTdWQ5MVdiWpm0v1VOCeMfIDnKRggnUW+xUt7+HMa84CsCvRc96zWi 9xSw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k65si52576417pge.422.2019.08.08.23.50.51; Thu, 08 Aug 2019 23:51:07 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2405644AbfHIGtH (ORCPT + 99 others); Fri, 9 Aug 2019 02:49:07 -0400 Received: from mx1.redhat.com ([209.132.183.28]:39386 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2405239AbfHIGtH (ORCPT ); Fri, 9 Aug 2019 02:49:07 -0400 Received: from smtp.corp.redhat.com (int-mx07.intmail.prod.int.phx2.redhat.com [10.5.11.22]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 493D7C074111; Fri, 9 Aug 2019 06:49:07 +0000 (UTC) Received: from dhcp201-121.englab.pnq.redhat.com (unknown [10.65.16.3]) by smtp.corp.redhat.com (Postfix) with ESMTP id 7870C1001925; Fri, 9 Aug 2019 06:48:59 +0000 (UTC) From: Pankaj Gupta To: amit@kernel.org, mst@redhat.com Cc: arnd@arndb.de, gregkh@linuxfoundation.org, virtualization@lists.linux-foundation.org, jasowang@redhat.com, linux-kernel@vger.kernel.org, pagupta@redhat.com, xiaohli@redhat.com Subject: [PATCH v3 2/2] virtio: decrement avail idx with buffer detach for packed ring Date: Fri, 9 Aug 2019 12:18:47 +0530 Message-Id: <20190809064847.28918-3-pagupta@redhat.com> In-Reply-To: <20190809064847.28918-1-pagupta@redhat.com> References: <20190809064847.28918-1-pagupta@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.84 on 10.5.11.22 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.31]); Fri, 09 Aug 2019 06:49:07 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch decrements 'next_avail_idx' count when detaching a buffer from vq for packed ring code. Split ring code already does this in virtqueue_detach_unused_buf_split function. This updates the 'next_avail_idx' to the previous correct index after an unused buffer is detatched from the vq. Signed-off-by: Pankaj Gupta --- drivers/virtio/virtio_ring.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/drivers/virtio/virtio_ring.c b/drivers/virtio/virtio_ring.c index c8be1c4f5b55..7c69181113e2 100644 --- a/drivers/virtio/virtio_ring.c +++ b/drivers/virtio/virtio_ring.c @@ -1537,6 +1537,12 @@ static void *virtqueue_detach_unused_buf_packed(struct virtqueue *_vq) /* detach_buf clears data, so grab it now. */ buf = vq->packed.desc_state[i].data; detach_buf_packed(vq, i, NULL); + vq->packed.next_avail_idx--; + if (vq->packed.next_avail_idx < 0) { + vq->packed.next_avail_idx = vq->packed.vring.num - 1; + vq->packed.avail_wrap_counter ^= 1; + } + END_USE(vq); return buf; } -- 2.20.1