Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp9699013ybc; Sat, 30 Nov 2019 12:28:36 -0800 (PST) X-Google-Smtp-Source: APXvYqxs7TxSss1m78eSuSL0uFnCNi+CkffujUc5waooxKYHGTDmZLgiOqPF2shjJzZ6SduCz6nc X-Received: by 2002:a17:906:d71:: with SMTP id s17mr68239048ejh.312.1575145716087; Sat, 30 Nov 2019 12:28:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575145716; cv=none; d=google.com; s=arc-20160816; b=lCUwYPSTcPm5/wBlfs6VGzRFcLteLz6cPAmKLtHIKW+RlqV16hA1BLAQfmSbLpk2jk mB+Fo6Wo4byZfQRKRuI3cbdVt6N3NopwrkAA91269guTXd/zpw4IVnTT9xHGmuhQURQD fxnkJbf+xYCtT0nRcB7UMlD5SJv+FEpLUXbt4hSZNs3i/D1KmaS4oQDvGycvJ5DWk7x3 Bdd7DDteIUYDvLn5wmm37uzGRq7Gvb4dMJz3zJNgNTUwzbbMp+/dD/c0vvnHUDN2GW9J 3rpk16jZqAx4uoogWZLBW24AskPOEfGRRirR0f7Ubvhsw1FhBJf9ceQT0pgq8LbV7DZm Fd3A== 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:to:from :dkim-signature; bh=gm798JVdHtTJhBTTcijtCtbLjelhqSHRBfY12Cw0a4c=; b=pNgGH+yfZgA0r/GR/hKqJV24GLWNdBotYQmGZERoK+5fSl2TmvR8MeP/Y7Uays8IXI b9zjY4nOXJhKq1GVdh2AokCIzuYtVGr3etnnUs7VpMkPk8bbFBncwb0HdQDmaHUfPdc9 +LkTNb1qmZyeJusCGMrr2J8BLejI9aaZ1XoZpxtp8HFqvwY4hw1PksoV5y29dDW1reXl EVcbHoamIDrG/EHJNeRkZ/AyjCR1+6KnXcp2eGTmq0kuEbKnAs4IoT39ZrHgfkAWQIVE 5foRCx7WX8e6Aw33B3qE10trZhxpIHayb8o1i70504Oqum7WtLOiPnqXQ4mlWsSvwcjr jvCg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=lIH+oOWd; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c3si19943521edx.315.2019.11.30.12.28.12; Sat, 30 Nov 2019 12:28:36 -0800 (PST) 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=@gmail.com header.s=20161025 header.b=lIH+oOWd; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727358AbfK3UYa (ORCPT + 99 others); Sat, 30 Nov 2019 15:24:30 -0500 Received: from mail-wr1-f66.google.com ([209.85.221.66]:42469 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727320AbfK3UY3 (ORCPT ); Sat, 30 Nov 2019 15:24:29 -0500 Received: by mail-wr1-f66.google.com with SMTP id a15so39119910wrf.9; Sat, 30 Nov 2019 12:24:28 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:subject:date:message-id:in-reply-to:references:mime-version :content-transfer-encoding; bh=gm798JVdHtTJhBTTcijtCtbLjelhqSHRBfY12Cw0a4c=; b=lIH+oOWdTRBDIjYMuQgQyhAWsykfAJ53WLQ8ig7qoZRh4GygPVxyIL0d6ueYT18u1B ilnOQIc+DEdGFuYiiuvCA29eyCdkvWuzaSNSyMItuKzDbjC3XvTxIamhnFjPSVLPGHzt atu7McfWIHwGtIrmTyo6kCjbNNETUWkfJoEQF76HrAZo4/NXbtJVt3zOv/g8i0vdOBwo RlCS7xesHmx7RG2x5PSMvpXX3HlRJes5r77UgtsSM9fOpw/ed75Il+DgsX2KJ7QxiQXG 3N+0UX43I7pdOklF2DpTx7wYIkYJ4CKVGLo8lo5huEKnWq5J4Y8mpQjLuaKhjCQJ8E1Z WK+g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=gm798JVdHtTJhBTTcijtCtbLjelhqSHRBfY12Cw0a4c=; b=rLKit8arOJxt78PVMgBO/qKKR/4iQnZDNf8rl12PQNNf1IBVtym71eqEMLkqJn7NbR JEZeHS/gnn+BmqMm2mpXyEknGZB7Ps6xen+ZW4hb1mh9r8Y9OIE6uC74OPotIMKvNvWX WNL/MBSeiYLrPJHlTEZGn1C+W9kHskA736/3caSZ8mLG7NRo1pnFG9mYYEq0YPu5VxNG Kuf64bMtC/KhDFuVONZQgMq5Nchus89q5YPXM5TFDTDgySgiUUjqVppOuvLrbxEHVNrh atk+gld7CMnEHvryTpYapKqIgqkJM9eKEyI2amDXLqaP6MW7HgNZ9nk55eIJuWjJrDj4 mX2g== X-Gm-Message-State: APjAAAVlfznwMVGxjTHrml4bNIX7WsKMqciRwljzDPabhO5FLSTHBWff ivHedKoorzKlbJdFuw/GW1NExRIK X-Received: by 2002:adf:ea8a:: with SMTP id s10mr51324721wrm.278.1575145467511; Sat, 30 Nov 2019 12:24:27 -0800 (PST) Received: from localhost.localdomain ([109.126.143.74]) by smtp.gmail.com with ESMTPSA id y15sm30929308wrh.94.2019.11.30.12.24.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 30 Nov 2019 12:24:27 -0800 (PST) From: Pavel Begunkov To: Jens Axboe , nivedita@alum.mit.edu, linux-block@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2] block: optimise bvec_iter_advance() Date: Sat, 30 Nov 2019 23:23:52 +0300 Message-Id: X-Mailer: git-send-email 2.24.0 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org bvec_iter_advance() is quite popular, but compilers fail to do proper alias analysis and optimise it good enough. The assembly is checked for gcc 9.2, x86-64. - remove @iter->bi_size from min(...), as it's always less than @bytes. Modify at the beginning and forget about it. - the compiler isn't able to collapse memory dependencies and remove writes in the loop. Help it by explicitely using local vars. Signed-off-by: Pavel Begunkov --- v2: simplify code (Arvind Sankar) include/linux/bvec.h | 22 ++++++++++------------ 1 file changed, 10 insertions(+), 12 deletions(-) diff --git a/include/linux/bvec.h b/include/linux/bvec.h index a032f01e928c..679a42253170 100644 --- a/include/linux/bvec.h +++ b/include/linux/bvec.h @@ -87,26 +87,24 @@ struct bvec_iter_all { static inline bool bvec_iter_advance(const struct bio_vec *bv, struct bvec_iter *iter, unsigned bytes) { + unsigned int idx = iter->bi_idx; + if (WARN_ONCE(bytes > iter->bi_size, "Attempted to advance past end of bvec iter\n")) { iter->bi_size = 0; return false; } - while (bytes) { - const struct bio_vec *cur = bv + iter->bi_idx; - unsigned len = min3(bytes, iter->bi_size, - cur->bv_len - iter->bi_bvec_done); - - bytes -= len; - iter->bi_size -= len; - iter->bi_bvec_done += len; + iter->bi_size -= bytes; + bytes += iter->bi_bvec_done; - if (iter->bi_bvec_done == cur->bv_len) { - iter->bi_bvec_done = 0; - iter->bi_idx++; - } + while (bytes && bytes >= bv[idx].bv_len) { + bytes -= bv[idx].bv_len; + idx++; } + + iter->bi_idx = idx; + iter->bi_bvec_done = bytes; return true; } -- 2.24.0