From patchwork Fri Oct 11 13:45:54 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Michael S. Tsirkin" X-Patchwork-Id: 11185519 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 2DCA714DB for ; Fri, 11 Oct 2019 13:46:07 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 189932064A for ; Fri, 11 Oct 2019 13:46:07 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728750AbfJKNqB (ORCPT ); Fri, 11 Oct 2019 09:46:01 -0400 Received: from mx1.redhat.com ([209.132.183.28]:48242 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728270AbfJKNqB (ORCPT ); Fri, 11 Oct 2019 09:46:01 -0400 Received: from mail-qt1-f197.google.com (mail-qt1-f197.google.com [209.85.160.197]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id D44D97575F for ; Fri, 11 Oct 2019 13:46:00 +0000 (UTC) Received: by mail-qt1-f197.google.com with SMTP id r15so9434116qtn.12 for ; Fri, 11 Oct 2019 06:46:00 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:mime-version :content-disposition; bh=o/nkRYTONx73WsD7MC8B77Hivj8w35ee4nLVJzmSYdg=; b=RHkRygy3KIYPlFH3O4IY5dnGFCvgrxtp96awOz7nGK6Ne32KOw0LK38T0oqtrWY80S qnOty6NWdvQmEg8z1Gvz1g2dyV96svvOrMhXN2qrhDSV0t2T7kXW2tYHz3fEi+ZOL+Ga 6fr+OWDIE85tVbAJ86EHRKvVDGy9flHUxjFk5Ouobud5HBYbkohofDXxJdGqHUYiVy+9 vdH13lrI5XX8quF5MiWFD71mUcDNmFPKa7w9liHdJBYyIdL88XI+XV7f/+QTs276VQqq YQ+bMZpu7oHysBwYUMFx0lpmMs14Z33AiVWPRhYCq0j8OE/WUJwv9o0IUbbKpINnOuyQ oUiQ== X-Gm-Message-State: APjAAAXQsqXlYW3dar7+u+uvpCN2Wutx6eHbfd5BkqOQSkRPyqjYwi1u LwKjipb4Tt9sVT6arR283QNLKFfNcZXEUgX6g8Zrp8MJJDcLzfuQh1tjExlhmiJQTOGzqet1GHm aKSjaSyDBRHA9 X-Received: by 2002:ac8:2e10:: with SMTP id r16mr17460365qta.62.1570801560086; Fri, 11 Oct 2019 06:46:00 -0700 (PDT) X-Google-Smtp-Source: APXvYqyNkV+IdP+Wd7WKMbrFt0Q607s9maou4ckQQ4vu7F/qkVJUOjLTGMKOgQL8yhEDf1yVy213sQ== X-Received: by 2002:ac8:2e10:: with SMTP id r16mr17460293qta.62.1570801559470; Fri, 11 Oct 2019 06:45:59 -0700 (PDT) Received: from redhat.com (bzq-79-176-10-77.red.bezeqint.net. [79.176.10.77]) by smtp.gmail.com with ESMTPSA id w6sm3944120qkj.136.2019.10.11.06.45.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 11 Oct 2019 06:45:58 -0700 (PDT) Date: Fri, 11 Oct 2019 09:45:54 -0400 From: "Michael S. Tsirkin" To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org, virtualization@lists.linux-foundation.org, netdev@vger.kernel.org Cc: Jason Wang Subject: [PATCH RFC v1 0/2] vhost: ring format independence Message-ID: <20191011134358.16912-1-mst@redhat.com> MIME-Version: 1.0 Content-Disposition: inline X-Mailer: git-send-email 2.22.0.678.g13338e74b8 X-Mutt-Fcc: =sent Sender: kvm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org So the idea is as follows: we convert descriptors to an independent format first, and process that converting to iov later. The point is that we have a tight loop that fetches descriptors, which is good for cache utilization. This will also allow all kind of batching tricks - e.g. it seems possible to keep SMAP disabled while we are fetching multiple descriptors. And perhaps more importantly, this is a very good fit for the packed ring layout, where we get and put descriptors in order. This patchset seems to already perform exactly the same as the original code already based on a microbenchmark. More testing would be very much appreciated. Biggest TODO before this first step is ready to go in is to batch indirect descriptors as well. Integrating into vhost-net is basically s/vhost_get_vq_desc/vhost_get_vq_desc_batch/ - or add a module parameter like I did in the test module. Michael S. Tsirkin (2): vhost: option to fetch descriptors through an independent struct vhost: batching fetches drivers/vhost/test.c | 19 ++- drivers/vhost/vhost.c | 333 +++++++++++++++++++++++++++++++++++++++++- drivers/vhost/vhost.h | 20 ++- 3 files changed, 365 insertions(+), 7 deletions(-)