Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp1825070pxb; Fri, 20 Aug 2021 15:14:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxoDO17hV1owHYqxGaBR+4WLLtNxx/04NOnaS9ybKTPTnaOi8KvlxIR8XTHiMfRNynSGRmQ X-Received: by 2002:a17:906:d20a:: with SMTP id w10mr24711963ejz.426.1629497682699; Fri, 20 Aug 2021 15:14:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629497682; cv=none; d=google.com; s=arc-20160816; b=no5YIRnetn0R2KfWWRnzdIadWxnm6oxc0D+uPWxjF+elKsnTGiAnOHdMuM3Tihhl7r /jZo3PK6LnYlWQ1OC1AwUXpqZOMl2hYWl9R4WfUK+KLPX4fiaTJCyN5Uvx7TKz1GHwxN jLFZ5dsYznAnIMaNqzEekhbxmi+r9U6YDxP1d+z3tTPHj8tDV7zkS9dNk0XtghEzVp8h jTxNyO0PMG8N07HIMpa+IYMT9Jkyhcv9ipnIRJvfGx0cwfgBdDFoUu91WrJe/jU+hSeJ FjJ98RQvw1pKfiPrjKsAdv4inq4hXJH4t9jBG/SZJZ+4Gl6J0nrEJ1TjOQwhU8XQnieq Tb+w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :message-id:subject:cc:to:from:date:dkim-signature; bh=/TBS71Ne6pgi2zI76nHlvmY23yKlcIceNY0sgQMUWZM=; b=gj6ksuCrXEJ+g5yTo21oSLwgqJ357AgJGJMLZZORIB+oqFcTZNt7SB0lXdzETmL6Zp QE6moscbhqmXvRAR3WTdvL5jFIuaqcYfvXf9X0ep6iyQyrOa+kOzGL+6GI2amPNPYqxe kAz0BKYOZlwzxuavkETQKtUsvlDp/Ff2jS0gzS18sjRkaYwBx78NJGImU/rpyQn2Dh4Q aQg2ZAxbhAgVNct95cLhXg66QApn1sEAzX++dg6JH8W/rlwbTnmmAHK7QULaiUy6R8qQ 5i0zt/1gTppQ4dsT2R59yK2JxqDCjrCp4c4DIUA+8YhMVPn2ZtwdJocwraYZMWc6VX/y acwQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=RufoxdMH; 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=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g23si2702650edp.82.2021.08.20.15.14.15; Fri, 20 Aug 2021 15:14:42 -0700 (PDT) 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=@kernel.org header.s=k20201202 header.b=RufoxdMH; 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=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233354AbhHTWMh (ORCPT + 99 others); Fri, 20 Aug 2021 18:12:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:37202 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231511AbhHTWMh (ORCPT ); Fri, 20 Aug 2021 18:12:37 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 89D3F61184; Fri, 20 Aug 2021 22:11:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1629497518; bh=HyNEEVCd9o7mWaLSVvoy4swYAPMRE2PXQmUBHU6S68M=; h=Date:From:To:Cc:Subject:In-Reply-To:From; b=RufoxdMHaGxZpQ0WxtWc5xXS8c3rB1DQKj+IC4Ck3jwWfCMQpXbxFz19pk3Dxam9L lKT4937n0VGw2EhSMwGmZhol6Mt0EqykSpaRtzNH2wq3J0LoepJLKx6qoEpvG2LqMW WYBBjEzi7fZN0SZw1ylcN3vhpNmhK4Mdnw9+sK3ghNQ96OK2h6QMfZWnHBWSB1Fpjj s6mNNuwJUeV1Qmw8b88m340FMu/tWjgvVVeA1GwIOpIvhJIP2BsTER/RXbkjqT8vBA 5IvOD2s/ERMz6YNY/E+qopU3ERMUKGXdeenWgEOPRuokA+0ribv1XFKJkng+wrtiqJ 1WbgjxkPd3p+g== Date: Fri, 20 Aug 2021 17:11:57 -0500 From: Bjorn Helgaas To: Zhen Lei Cc: Bjorn Helgaas , linux-pci , linux-kernel Subject: Re: [PATCH 1/1] PCI: Optimize pci_resource_len() to reduce the binary size of kernel Message-ID: <20210820221157.GA3365579@bjorn-Precision-5520> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210713072236.3043-1-thunder.leizhen@huawei.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jul 13, 2021 at 03:22:36PM +0800, Zhen Lei wrote: > pci_resource_end() can be 0 only when pci_resource_start() is 0. > Otherwise, it is definitely an error. In this case, pci_resource_len() > should be regarded as 0. Therefore, determining whether > pci_resource_start() and pci_resource_end() are both 0 can be reduced to > determining only whether pci_resource_end() is 0. > > Although only one condition judgment is reduced, the macro function > pci_resource_len() is widely referenced in the kernel. I used defconfig to > compile the latest kernel on X86, and its binary code size was reduced by > about 3KB. > > Before: > [ 2] .rela.text RELA 0000000000000000 093bfcb0 > 0000000001a67168 0000000000000018 I 68 1 8 > > After: > [ 2] .rela.text RELA 0000000000000000 093bfcb0 > 0000000001a66598 0000000000000018 I 68 1 8 > > Signed-off-by: Zhen Lei Applied to pci/resource for v5.15, thanks! > --- > include/linux/pci.h | 4 +--- > 1 file changed, 1 insertion(+), 3 deletions(-) > > diff --git a/include/linux/pci.h b/include/linux/pci.h > index 540b377ca8f6..23ef1a15eb5d 100644 > --- a/include/linux/pci.h > +++ b/include/linux/pci.h > @@ -1881,9 +1881,7 @@ int pci_iobar_pfn(struct pci_dev *pdev, int bar, struct vm_area_struct *vma); > #define pci_resource_end(dev, bar) ((dev)->resource[(bar)].end) > #define pci_resource_flags(dev, bar) ((dev)->resource[(bar)].flags) > #define pci_resource_len(dev,bar) \ > - ((pci_resource_start((dev), (bar)) == 0 && \ > - pci_resource_end((dev), (bar)) == \ > - pci_resource_start((dev), (bar))) ? 0 : \ > + ((pci_resource_end((dev), (bar)) == 0) ? 0 : \ > \ > (pci_resource_end((dev), (bar)) - \ > pci_resource_start((dev), (bar)) + 1)) > -- > 2.25.1 >