Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp612410pxb; Thu, 19 Nov 2020 09:18:25 -0800 (PST) X-Google-Smtp-Source: ABdhPJwJDeJfSXlN0dQxBo4SvX8BfMskR4de9V9YI6fby6UXX+5g/4ixRI1nP3S2cQmg4IqoaO+g X-Received: by 2002:a17:906:adcd:: with SMTP id lb13mr27900897ejb.362.1605806304918; Thu, 19 Nov 2020 09:18:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605806304; cv=none; d=google.com; s=arc-20160816; b=ELPMMRXrBkZz4Xg7rULo34AWpO5ks2V+99BZ7r4zBFI3jJk1ik/RhUoki9R86fDz/Y u/xHTJZS1K8XPDnBSm8mMm/86Aq3fjR5p+hWTL76tipgv4SOv1j9iJVcafCcYSioqqqW rzQTjLeUbN2i9h5B5ALz6oq7aArYrVQ38rwEAe7yxqlQZGZHXedP+uO5OD6NYLbendJx DYIrgEzREweLxK5D6k/hBz0zjcUVKvUfP3J38+epOLQ5vzRkEsvxG/1g/XRWtK/iVrFx Ria8Qe83FdE4IqHIyolhkSnet1qG5VaakAAX8LAQY3x1IhmlMpyM51gH8tWQsnluAWny /A5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:subject :autocrypt:from:references:cc:to:dkim-signature; bh=NTlQpRFAgXi7+2j38CXpVzx++h7WQhzOl2JIZlqcQMo=; b=pFytzePeKUzjAzBAYK4WWwTMZ5iORPGubydjKmoBr19ilF8lcQ3dpnDAZLCSUtCBE0 VDy55RXty94PrSxbuX8W0S26mGoqJpDy6n+3nnm8BB7W+78b+nFIcABaVgKGkc+9IKO2 8RSyTEyyBMsI+HIgwmT/V+ULWF4cRMXeO40WhhQWb8PGr9Uecle8P2PgL/7hvx4qHHgk TM4PXpx97M7hcvv43qE3zjqi+5o1glap/m5XvExnAZcLAS6HxV3N7kHp8QahqdzGiYht TeKWSQIFytPqQYzXYf/UxxCT7Lh0bpK9Ou5L1Pz1ao3h+1xlS9iRP26ocuCU/HH6LJC9 uxUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=bB+5+IQF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id i27si185067ejo.285.2020.11.19.09.17.59; Thu, 19 Nov 2020 09:18:24 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=bB+5+IQF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1728262AbgKSRPz (ORCPT + 99 others); Thu, 19 Nov 2020 12:15:55 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33318 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726474AbgKSRPy (ORCPT ); Thu, 19 Nov 2020 12:15:54 -0500 Received: from mail-wr1-x441.google.com (mail-wr1-x441.google.com [IPv6:2a00:1450:4864:20::441]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 63CF1C0613CF; Thu, 19 Nov 2020 09:15:54 -0800 (PST) Received: by mail-wr1-x441.google.com with SMTP id 23so7233120wrc.8; Thu, 19 Nov 2020 09:15:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=to:cc:references:from:autocrypt:subject:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=NTlQpRFAgXi7+2j38CXpVzx++h7WQhzOl2JIZlqcQMo=; b=bB+5+IQFMAn7TruC2V9EDh7t4Q/nD+Zw6xMmK+C3lUwYamWSYNjj59OD5FZFKQozaF tFDzWSjTmkY+Fyupab8JlLci8FVScj+kaBXgFK1+Muw3Ode2ybxVEBXvZpt8b63+oXqL PPNNGK0xFjl0xwA+WQln/vUbFKhxV3G5QYS5q5Q34G1ysVlLF4g800wE3B0l6epgfo4m SIiz0SF1nBJT1zfJzbshoikiztLDcJ1RbuXbjWuUeFrQ6t6oMfDhzH6y3k5YYdh0UR7P 99k0y36x46+zAkWmrSOYMSE8L6e4zbHaRg8Pyl4TfDBjdBVJm6a95JLcQWsifU/NFZ+9 KUgQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:to:cc:references:from:autocrypt:subject :message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=NTlQpRFAgXi7+2j38CXpVzx++h7WQhzOl2JIZlqcQMo=; b=RCVnMIhNiAF21t5kWioZW1N54K59R7RBOeMo3SxkkQcJIBciTlwnNdgvAvc1MAYHcQ 0zW1yk3ymegukO51Qr5caxBlrj6IFEg0plV3PF7HDjmyAhcJ6FKsvmZRBMdte51ATY8E ZvBwoQ7omDZsrT1H+gHsB+46IABS7f6Bp6CgBsxGf46CL15zWvSzN8+QcCQ316ABvLE3 Psdy/gKFVn/O/OsHrc9g+3GM73v/weiVjAPNezN0garmiNloHwl9Ek5V/vIGstNOKpJi +hopX2KG066fbj/cIZsCJ40typkLh6fS/UYzlk7BeUXCtsV3yLxECdocFrM6wP8gNdhc J9rA== X-Gm-Message-State: AOAM530cGuRadnokwME5i96y4nc0ks+C1g1PV1fgDaRMjekNB+6jp/Ub bO3KovX0gzK6PTWirY9/Zy52cDkKS6MGgg== X-Received: by 2002:a5d:4acf:: with SMTP id y15mr4178161wrs.333.1605806152898; Thu, 19 Nov 2020 09:15:52 -0800 (PST) Received: from [192.168.1.23] (host109-152-100-189.range109-152.btcentralplus.com. [109.152.100.189]) by smtp.gmail.com with ESMTPSA id h15sm684772wrw.15.2020.11.19.09.15.51 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 19 Nov 2020 09:15:52 -0800 (PST) To: Christoph Hellwig Cc: Jens Axboe , linux-block@vger.kernel.org, Alexander Viro , linux-kernel@vger.kernel.org References: <9bc27cb3ef6ab49b6b2ccee3db6613838aee17af.1605799583.git.asml.silence@gmail.com> <20201119170340.GA6179@infradead.org> From: Pavel Begunkov Autocrypt: addr=asml.silence@gmail.com; prefer-encrypt=mutual; keydata= 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 bA== Subject: Re: [PATCH 2/2] iov_iter: optimise iter type checking Message-ID: Date: Thu, 19 Nov 2020 17:12:44 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.3.0 MIME-Version: 1.0 In-Reply-To: <20201119170340.GA6179@infradead.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 19/11/2020 17:03, Christoph Hellwig wrote: > On Thu, Nov 19, 2020 at 03:29:43PM +0000, Pavel Begunkov wrote: >> The problem here is that iov_iter_is_*() helpers check types for >> equality, but all iterate_* helpers do bitwise ands. This confuses >> a compiler, so even if some cases were handled separately with >> iov_iter_is_*(), it can't eliminate and skip unreachable branches in >> following iterate*(). > > I think we need to kill the iov_iter_is_* helpers, renumber to not do > the pointless bitmask and just check for equality (might turn into a > bunch of nice switch statements actually). There are uses like below though, and that would also add some overhead on iov_iter_type(), so it's not apparent to me which version would be cleaner/faster in the end. But yeah, we can experiment after landing this patch. if (type & (ITER_BVEC|ITER_KVEC)) -- Pavel Begunkov