Received: by 10.223.164.202 with SMTP id h10csp245827wrb; Tue, 14 Nov 2017 00:21:53 -0800 (PST) X-Google-Smtp-Source: AGs4zMaoVX3EUsAWxGmHPmrclQlprOpxQUFsGkJFA/wLfihoezfvyf1d9MVgHm9/UneaOVXMSmaI X-Received: by 10.99.108.70 with SMTP id h67mr5308545pgc.218.1510647713326; Tue, 14 Nov 2017 00:21:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510647713; cv=none; d=google.com; s=arc-20160816; b=LCarJFlDJaEWSPZYAehjR2PPhMTGkBck73NC+Uetf6+rnERcy8asahqWA6gMQAfPUV vt3H+Ai7on/ZUZpyzKcgfJNcfK7XkStns3iq2lLHhHUEkJ4sA+kF1Rtd9hAWXcP6cbQ6 9hptiIm7bl+Nsg9tw51oYRdlhFLHYp73hrvuL4h07lIc2dxteL0+pj0N6lggnTBRMJyY Q2wJi34XE398fmILK85dLmQ+AL+TxXJe+jpIBnOj5IkWqnzyDkjqFSCBFFYs3eVF9yCy XjRRIkB8WRxoIHvwI3/Cl7+wZjFBzdSXqI8xngOFpUz8VfeasHfcAS951XhbKCVgCOlJ NyUw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=tjeJrnekXWFM4qlEN6g87Q6mUGKMo4grmC7VRsEsbcQ=; b=DgpyKiDVFahw+zpGu1VkJ9FrTyvC2kx0usd8rOUsRdeobyaAHWaRHU0iwLlek9uxMN Dc6FWazBErKs5Ffad6Y6C3/tp20oL4ABd8yNTtycC15hiavG/gOKuX82+CbuMIorRaan DyeBHwoC5ghwT/MJiYsFBVfTUu4qdEKP4orQ+6Xtb5xO50K/PkTZDHNh5HWsVWWb7oPt gVQlBc3aSBHV7s07CwKtAqIzmj7SeyWDdbGW7Fwt06ErogCYdXJyvagQiv6ibrwyLp1d Y3CG8qYDij9m1+MdiwlnwFxZBt8T9KCqer8HGnWyWtc4quph4sAam9OJSTt26TGhoPpx mqWQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=ARduckZh; 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=NONE 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 y1si14936702pgy.675.2017.11.14.00.21.40; Tue, 14 Nov 2017 00:21:53 -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=ARduckZh; 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=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753243AbdKNG5r (ORCPT + 89 others); Tue, 14 Nov 2017 01:57:47 -0500 Received: from mail-pf0-f196.google.com ([209.85.192.196]:43778 "EHLO mail-pf0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752210AbdKNG5n (ORCPT ); Tue, 14 Nov 2017 01:57:43 -0500 Received: by mail-pf0-f196.google.com with SMTP id a84so8841447pfl.0 for ; Mon, 13 Nov 2017 22:57:43 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=tjeJrnekXWFM4qlEN6g87Q6mUGKMo4grmC7VRsEsbcQ=; b=ARduckZhezgLjI7sdtgeCnykNdqZHWd4zJS/Ijvtx5B7ZfVRpqjJ4LLrjxGGQHTZYo Azx8mxQsNRNBveYtliM9wbEjPWfqRTV6SxM31Ukih1XCY/+Z9w7ff53gR/cxtn+oR1j7 MSZSjVhgbh9O5lZyk6H8JAPEhVfemAxRQ5rGtJSBHIb4Y3aWbef/okmcfbu5ePlU6p/1 /jq+XRiBOtfrFjJcy1rkOvrsCMTu3x3HbRW4Ew9ipbZIEroJoFUAfu26y67bWQrWFlsG upvSB8iIyz0itrRNX7/vJnPqxSeXq4MbhGQBivX60Rt47bh3WXCu31IDwt0BJXqKzLU5 8Apw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=tjeJrnekXWFM4qlEN6g87Q6mUGKMo4grmC7VRsEsbcQ=; b=EX08zZrBPP0tkoQsk5HhSgPBZe8+hx9TfZ0REN823FgjkMFIGZbt8GguvhbhNp4jfk cgt019cKZQnCAEymXOKyOV/msDUvIRQbMLKpkIuAYMoNi4kl0P1ZeaswRU+/UeLStUTm GtrSIJgL2INw1KgR4Zz0pJNBhtrmH08nI/iRcnNmOu5rwCMaV3prOICojgO13HFAlAn8 LoLG3OKAapgpi/vDQAe/7E5iKFGhLDTImP8ERV5/X0lBVLbSPXg1nEBD1jdBj0BT53wy /1nMlWIC5/eNM7zfnwz2IB3WyFJiRyVtamGMx8F93H6AaurAy2SLP/xGfVU2TzJI3AIx YlXQ== X-Gm-Message-State: AJaThX6fLmT50E6fLZd56gSlHyhjLbUW/pP/dXNNHnnLA96QEmUsWIt3 A1EBlRvC6HbCvvThvuZ0ZO3OWdLe X-Received: by 10.99.113.83 with SMTP id b19mr11058021pgn.41.1510642662697; Mon, 13 Nov 2017 22:57:42 -0800 (PST) Received: from localhost.localdomain ([103.76.155.2]) by smtp.gmail.com with ESMTPSA id t4sm15528947pfj.56.2017.11.13.22.57.39 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 13 Nov 2017 22:57:41 -0800 (PST) From: Rakib Mullick To: linux-kernel@vger.kernel.org Cc: Andrew Morton , Rasmus Villemoes , Matthew Wilcox , Yury Norov , Mauro Carvalho Chehab Subject: [PATCH] lib: Avoid redundant sizeof checking in __bitmap_weight() calculation. Date: Tue, 14 Nov 2017 12:57:31 +0600 Message-Id: <20171114065731.3602-1-rakib.mullick@gmail.com> X-Mailer: git-send-email 2.9.3 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently, during __bitmap_weight() calculation hweight_long() is used. Inside a hweight_long() a check has been made to figure out whether a hweight32() or hweight64() version to use. However, it's unnecessary to do it in case of __bitmap_weight() calculation inside the loop. We can detect whether to use hweight32() or hweight64() upfront and call respective function directly. It also reduces the vmlinux size. Before the patch: text data bss dec hex filename 12901332 7798930 14541816 35242078 219c05e vmlinux After the patch: text data bss dec hex filename 12901331 7798930 14541816 35242077 219c05d vmlinux Signed-off-by: Rakib Mullick Cc: Andrew Morton Cc: Rasmus Villemoes Cc: Matthew Wilcox Cc: Yury Norov Cc: Mauro Carvalho Chehab --- Patch was created against torvald's tree (commit 43ff2f4db9d0f764). lib/bitmap.c | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/lib/bitmap.c b/lib/bitmap.c index d8f0c09..552096f 100644 --- a/lib/bitmap.c +++ b/lib/bitmap.c @@ -241,10 +241,15 @@ EXPORT_SYMBOL(__bitmap_subset); int __bitmap_weight(const unsigned long *bitmap, unsigned int bits) { unsigned int k, lim = bits/BITS_PER_LONG; - int w = 0; - - for (k = 0; k < lim; k++) - w += hweight_long(bitmap[k]); + int w = 0, is32 = sizeof(bitmap[0]) ? 1 : 0; + + if (is32) { + for (k = 0; k < lim; k++) + w += hweight32(bitmap[k]); + } else { + for (k = 0; k < lim; k++) + w += hweight64(bitmap[k]); + } if (bits % BITS_PER_LONG) w += hweight_long(bitmap[k] & BITMAP_LAST_WORD_MASK(bits)); -- 2.9.3 From 1584025450919787077@xxx Tue Nov 14 07:26:29 +0000 2017 X-GM-THRID: 1584025450919787077 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread