Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp7212158ybc; Thu, 28 Nov 2019 13:10:00 -0800 (PST) X-Google-Smtp-Source: APXvYqywe/kQMcsKf1BvyxTBanE3uKW6sBIy3Xn4s0n5m0zA0UBfP6t2VDYDdEMM0eviR2fcLPBL X-Received: by 2002:a17:906:12d3:: with SMTP id l19mr54690907ejb.165.1574975400748; Thu, 28 Nov 2019 13:10:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574975400; cv=none; d=google.com; s=arc-20160816; b=aEKK/jedyIKGssqxnPBIJNGcCDFfY2IZ6dJo2TS0GFLCTs7SGlnVrVLlIQpdpf7oij fZVRw6LLOR3x9rSuTWAJFrmxrDschd+j3+0RN5YW+2biPtio0VDM+420ar6xND9n61ef t77C9qSOUL8Ea4/7ZZRXlVQaS+PcJLMlSCog7KcYfPAUOZWn6IJHTgOMDiEx/8pPKaKY BTQrrfbXwcUiQOLyYLAZNz1pi9W/EyixAVWTtSH+oOagQVTcvLb9I9st4Xp++pg9Jl21 MJ3iWyQSXOnUel7RTuRIpGmDtGEGXnNH4Sm3kOO3+lUs1UwlUax6A6ui6fM77Gf+Ygrj uMwQ== 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=JIqdPvDq60NeSA4MmFOLLaYMW+f7MTJk0ci/m/ClifE=; b=AC6xfDoaApWl9zAHWAQtH/cqcoRAw96k8AYmOVQJexqvLo8314qLG+9cCjJAumIaz3 /w1OOOF3zldS+V/ohvjYEqP10RDti1yFgGveQ5qvkcyM4IUL4gjUtc69d8ADwRlexxiQ 3bfbx13ZqDhs/jHOi+RtxyRFyZCIZpuwoTir6859CGLwcE32PBx9KfwPAujqU6u8+Guq KSUKw3a6rjWGgPSq2WiYFm0UkMUejmyknprZsB28Hn9vFnlJIRllkLXQNjLsUHaOmpfR 9cduj3C6NSQwor+37o6l/atd81TmS6T3wAaQkaI3OxncLpAUS340LJLI0U4oWw4UOXNu vuXA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="p/0m4767"; 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 c6si13212765ejc.350.2019.11.28.13.09.36; Thu, 28 Nov 2019 13:10:00 -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="p/0m4767"; 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 S1726655AbfK1VFS (ORCPT + 99 others); Thu, 28 Nov 2019 16:05:18 -0500 Received: from mail-wm1-f65.google.com ([209.85.128.65]:53921 "EHLO mail-wm1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726558AbfK1VFS (ORCPT ); Thu, 28 Nov 2019 16:05:18 -0500 Received: by mail-wm1-f65.google.com with SMTP id u18so12187742wmc.3; Thu, 28 Nov 2019 13:05:17 -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=JIqdPvDq60NeSA4MmFOLLaYMW+f7MTJk0ci/m/ClifE=; b=p/0m47672Xp4nRbIVgDxszY6a3FoKsWwrHx71iDUbTUs34ac66g4CfS9III0nnP3TO s4s7qDpIZXDuBrgZ9x0DtHhVQG/HxrucWmipR5Ukeifsny0AgjkeLRQcRnpah0eQYWdR SMmShFLsnO2AeWhsC6l1yKd/ttYF18eUkBlYcHQ1Um78zHpN00bosDbgHqRQzsW9I/rn UfXrWWcMEYCRu7ughS/TBKoJkSMBmoCHZa1mF/3XvpaePosKKLTmQjZZh4QD1Gr0VfOt PR9cPqcnyjF9mPHK4LAZPsonQ8RDsakUgFUnNnCqEuWBa7Hxqi1WuZmINtsaJrZfgs9w vGEQ== 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=JIqdPvDq60NeSA4MmFOLLaYMW+f7MTJk0ci/m/ClifE=; b=LlxmP45nRCx5TXeYazF76TmTMECQD2mamufsyTIuzrPsoZU4K7Dlsk/HgSJOFUrbiH HPLRxZCiutpsbWFRXv5ly5Q7v3x6TtumjNHIfSbQ+u6jaRxxrL+NOv7q+0KMMyA/x8H9 rxzfxIfJqQnd4LpZuCUZ31SM/CFboS+7sGYYnnlvbh0Cp7qYGBWndFcvJvR0AOVyu+zV 0Z70U0ZU6VYlbOwMp1Tc0zQY8nEYyJZ2VoyVhZgAv+Ucjzag5qLSuq7LDJvdVWXCmJ5s hQK2jWgKqsZ46g//8ERAS66LJLAmYzIqSAg+FBX7QNHqQgN87HotTnsC45CAkxPthZTb 7iSg== X-Gm-Message-State: APjAAAVYrZkJMqYEU5utAiqVOIEP0wFvpXZ7CKd8dokSzd53mwbL1A2d r+tUUZITZOc02avVTrXdIR0= X-Received: by 2002:a7b:c84b:: with SMTP id c11mr10633418wml.158.1574975116327; Thu, 28 Nov 2019 13:05:16 -0800 (PST) Received: from localhost.localdomain ([109.126.143.74]) by smtp.gmail.com with ESMTPSA id y8sm11047038wmi.9.2019.11.28.13.05.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 28 Nov 2019 13:05:15 -0800 (PST) From: Pavel Begunkov To: Jens Axboe , Ming Lei , linux-block@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH] block: optimise bvec_iter_advance() Date: Fri, 29 Nov 2019 00:04:37 +0300 Message-Id: <06b1b796b8d9bcaa6d5b325668525b7a5663035b.1574974574.git.asml.silence@gmail.com> 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 --- include/linux/bvec.h | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/include/linux/bvec.h b/include/linux/bvec.h index a032f01e928c..7b2f05faae14 100644 --- a/include/linux/bvec.h +++ b/include/linux/bvec.h @@ -87,26 +87,31 @@ struct bvec_iter_all { static inline bool bvec_iter_advance(const struct bio_vec *bv, struct bvec_iter *iter, unsigned bytes) { + unsigned int done = iter->bi_bvec_done; + 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; } + iter->bi_size -= bytes; + 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); + const struct bio_vec *cur = bv + idx; + unsigned int len = min(bytes, cur->bv_len - done); bytes -= len; - iter->bi_size -= len; - iter->bi_bvec_done += len; - - if (iter->bi_bvec_done == cur->bv_len) { - iter->bi_bvec_done = 0; - iter->bi_idx++; + done += len; + if (done == cur->bv_len) { + idx++; + done = 0; } } + + iter->bi_idx = idx; + iter->bi_bvec_done = done; return true; } -- 2.24.0