Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp6796897ybi; Mon, 8 Jul 2019 08:50:46 -0700 (PDT) X-Google-Smtp-Source: APXvYqzL1Kp8idHQ15JbfdFxAhF1IkJ0y+ybJP7gykos8M5J3gU4RCv8y04A3Dv1wTdtx6/9xwz7 X-Received: by 2002:a17:902:4aa3:: with SMTP id x32mr24934361pld.119.1562601046480; Mon, 08 Jul 2019 08:50:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562601046; cv=none; d=google.com; s=arc-20160816; b=jL/NRIEGxcrYOB7XZZK73DtnOmlShNRQd5xSw3GonQoBhc9qFf7GCyLWTZ0nVdGIQn wEicQoVt62JoolO055hnk1i2m3sOl3S6qP1rReyaMIfru8qWJUZ8WFyK+ECYlhn2dy0G y2ZSTsGTCHbieHWiP9WNsweH64AwkOkeMMRK6OYt4P3r7M2RRfYywLwgR7Oc8arEUXkE CzY4RdeU9S+49+OK7AazRDH4RKJtUY01e2BOvTKKnlvrQRy+FJby3njr2EMV+5qwAU2K FuYN7J09bLnwNV1tA2xma6MeX+LIBpPbvdFC6rd6yrA3PUSYTWZjvcJpE3vB55MiP2ol 2r4g== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=L+zrUiEF4j7FePcvOZvJxP+6JX+7fViqsIcR1HNQbNA=; b=M5YhPhzNxN+oswPee0hTnr1QxmM5CkaLaNxKK6i0hEbitYlRrfQebYopv/gbArpl2n +dcPOo8rZn21sDVuWujR2ELWL2YqhENCBzA07xHcaiW217zKz+NyVxjO+aXyCaDPjOxu CCSjh0q3ZfrkbzL1uvat5oTj61cWsfMxtw5TciboIzMd4/H6aFVYx09DM8HIiCXWyePb 5/3fZM42GWxH8NHVTY3zLcC1FDtBeeYwaQiuiyXEW6evbHoDlWiOrwrNgmO5qDY/eguB SwBj0P9g2ngk3gMhZfRWSa761xjGTkbmGttZo0bgGwkLnE9FT65GCHmMPzndKSkr/EZC Qcgg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=blIFaZNs; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g64si18680493pgc.188.2019.07.08.08.50.31; Mon, 08 Jul 2019 08:50:46 -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; dkim=pass header.i=@kernel.org header.s=default header.b=blIFaZNs; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391078AbfGHPmY (ORCPT + 99 others); Mon, 8 Jul 2019 11:42:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:52782 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388463AbfGHPZV (ORCPT ); Mon, 8 Jul 2019 11:25:21 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 4B5912175B; Mon, 8 Jul 2019 15:25:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1562599519; bh=74s/ak+xYCNQRD4ASQeLJMVTesMNwD4EkM9dt6eeMFM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=blIFaZNsaoKgc1GWV5QWdjF779Yl/hHrUWDJx59tmFkh4ugyXTWk8nwFOqGb5WZh4 LwpPpdQZirP8/pljhNUaBxak8h/98YVuMaXcocjFFvgsMjhS5asvMZRKVCEgFEw93w Qwy0Dt9iH9LvY+GFwehKdI5HKLrIggj62f8clIDg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Paolo Abeni , Jason Wang , "David S. Miller" , Balbir Singh Subject: [PATCH 4.14 42/56] vhost_net: use packet weight for rx handler, too Date: Mon, 8 Jul 2019 17:13:34 +0200 Message-Id: <20190708150523.661539406@linuxfoundation.org> X-Mailer: git-send-email 2.22.0 In-Reply-To: <20190708150514.376317156@linuxfoundation.org> References: <20190708150514.376317156@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Paolo Abeni commit db688c24eada63b1efe6d0d7d835e5c3bdd71fd3 upstream. Similar to commit a2ac99905f1e ("vhost-net: set packet weight of tx polling to 2 * vq size"), we need a packet-based limit for handler_rx, too - elsewhere, under rx flood with small packets, tx can be delayed for a very long time, even without busypolling. The pkt limit applied to handle_rx must be the same applied by handle_tx, or we will get unfair scheduling between rx and tx. Tying such limit to the queue length makes it less effective for large queue length values and can introduce large process scheduler latencies, so a constant valued is used - likewise the existing bytes limit. The selected limit has been validated with PVP[1] performance test with different queue sizes: queue size 256 512 1024 baseline 366 354 362 weight 128 715 723 670 weight 256 740 745 733 weight 512 600 460 583 weight 1024 423 427 418 A packet weight of 256 gives peek performances in under all the tested scenarios. No measurable regression in unidirectional performance tests has been detected. [1] https://developers.redhat.com/blog/2017/06/05/measuring-and-comparing-open-vswitch-performance/ Signed-off-by: Paolo Abeni Acked-by: Jason Wang Signed-off-by: David S. Miller Signed-off-by: Balbir Singh Signed-off-by: Greg Kroah-Hartman --- drivers/vhost/net.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) --- a/drivers/vhost/net.c +++ b/drivers/vhost/net.c @@ -45,8 +45,10 @@ MODULE_PARM_DESC(experimental_zcopytx, " #define VHOST_NET_WEIGHT 0x80000 /* Max number of packets transferred before requeueing the job. - * Using this limit prevents one virtqueue from starving rx. */ -#define VHOST_NET_PKT_WEIGHT(vq) ((vq)->num * 2) + * Using this limit prevents one virtqueue from starving others with small + * pkts. + */ +#define VHOST_NET_PKT_WEIGHT 256 /* MAX number of TX used buffers for outstanding zerocopy */ #define VHOST_MAX_PEND 128 @@ -578,7 +580,7 @@ static void handle_tx(struct vhost_net * vhost_zerocopy_signal_used(net, vq); vhost_net_tx_packet(net); if (unlikely(total_len >= VHOST_NET_WEIGHT) || - unlikely(++sent_pkts >= VHOST_NET_PKT_WEIGHT(vq))) { + unlikely(++sent_pkts >= VHOST_NET_PKT_WEIGHT)) { vhost_poll_queue(&vq->poll); break; } @@ -760,6 +762,7 @@ static void handle_rx(struct vhost_net * struct socket *sock; struct iov_iter fixup; __virtio16 num_buffers; + int recv_pkts = 0; mutex_lock_nested(&vq->mutex, 0); sock = vq->private_data; @@ -860,7 +863,8 @@ static void handle_rx(struct vhost_net * vhost_log_write(vq, vq_log, log, vhost_len, vq->iov, in); total_len += vhost_len; - if (unlikely(total_len >= VHOST_NET_WEIGHT)) { + if (unlikely(total_len >= VHOST_NET_WEIGHT) || + unlikely(++recv_pkts >= VHOST_NET_PKT_WEIGHT)) { vhost_poll_queue(&vq->poll); goto out; }