Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp7000506ybi; Mon, 8 Jul 2019 12:25:53 -0700 (PDT) X-Google-Smtp-Source: APXvYqxTMCfKMl2IWGC7a4GyMvW56zgKrPv42uSkTywMQpxCioC5RNcsC4OTU1Q8hXIWetCdRiwY X-Received: by 2002:a17:90a:26e4:: with SMTP id m91mr27978730pje.93.1562613953390; Mon, 08 Jul 2019 12:25:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562613953; cv=none; d=google.com; s=arc-20160816; b=fIMmCxZzxU8bCL3qewATbSEMToiOIfHL5QeLAv+zHj1IMfqm+FfB+LfrcY91NIZ26r TxLwcltkeMJ2lV3yKjtHKWGu765Iw7NaMrhkVow5tBYDCA03n20OaUgdNUqVXvapTiId 0hwSLukhgc8xobwH4ica1CiYoZZFY9zBGjjGXd2lab7pBm93Ls0AIR0hatMpHN9KLQRM 5ATvmBRB5dPziPOzqLqaRhtPNNqqykcd4IFCO/MW9NHK4RaPtkgdKGwvaPCUlCjK0Jhz k01zM1UvZrw7/IfnFrbxBh5NS2XPi+AH1H4IuZFE+Mg2PMPznXIHjKzFyARTmM+Jwh5E 29lQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date; bh=YKOTJiKykFlSwRbVUP6A/EtwRMx7RLxFE4DdO7UmYo4=; b=j6jwB8prjp9f61C8UYjtpkwzZaB7yRvNa5r5YzXlJscKFSxZKZ7O3HDSR/S6swryX6 CoBpycuCQ3SCK0+GQRZ0m4dMUcFmdj1yCaElFWs1wXH3EgKty5350p8eB0Nzo68KUTkP G/vgRBZtUlcIWSq6YIrLjuoVtWS4bwqq3d7Nycd1P2caH01hzNdy8V6/6PiiUVtE+C6t 9+SYhXJ0RN6Nv2sQEFQJ82SZFG1ivs0Xt3A36TFqTGHSTUddKAtOHD6aoOtum4OI1yYb 3o8wCVZvepOl/pdWT0WaZ0t7M3VGIO3UcjfPU3ifSK6pLiOTWIt6AHu2AZoUnigdCKR3 X+Jg== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a2si19798710pgb.166.2019.07.08.12.25.38; Mon, 08 Jul 2019 12:25:53 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730068AbfGHOPA (ORCPT + 99 others); Mon, 8 Jul 2019 10:15:00 -0400 Received: from Galois.linutronix.de ([193.142.43.55]:39489 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728596AbfGHOO7 (ORCPT ); Mon, 8 Jul 2019 10:14:59 -0400 Received: from [5.158.153.52] (helo=nanos.tec.linutronix.de) by Galois.linutronix.de with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA256:256) (Exim 4.80) (envelope-from ) id 1hkUPi-0001Ht-7E; Mon, 08 Jul 2019 16:14:42 +0200 Date: Mon, 8 Jul 2019 16:14:41 +0200 (CEST) From: Thomas Gleixner To: Zhiqiang Liu cc: corbet@lwn.net, mcgrof@kernel.org, Kees Cook , akpm@linux-foundation.org, manfred@colorfullife.com, jwilk@jwilk.net, dvyukov@google.com, feng.tang@intel.com, sunilmut@microsoft.com, quentin.perret@arm.com, linux@leemhuis.info, alex.popov@linux.com, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, "wangxiaogang (F)" , "Zhoukang (A)" , Mingfangsen , tedheadster@gmail.com, Eric Dumazet Subject: Re: [PATCH next] softirq: enable MAX_SOFTIRQ_TIME tuning with sysctl max_softirq_time_usecs In-Reply-To: Message-ID: References: <0099726a-ead3-bdbe-4c66-c8adc9a4f11b@huawei.com> User-Agent: Alpine 2.21 (DEB 202 2017-01-01) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Zhiqiang, On Tue, 25 Jun 2019, Zhiqiang Liu wrote: > I have a doubt about _msecs_to_jiffies funcs, especially when input m is > equal to 0. > > For different HZ setttings, different _msecs_to_jiffies funcs will be > chosen for msecs_to_jiffies func. However, the performance of different > _msecs_to_jiffies is inconsistent with input m is equal to 0. > > If HZ satisfies the condition: HZ <= MSEC_PER_SEC && !(MSEC_PER_SEC % > HZ), the return value of _msecs_to_jiffies func with m=0 is different > with different HZ setting. > ------------------------------------ > | HZ | MSEC_PER_SEC / HZ | return | > ------------------------------------ > |1000| 1 | 0 | > |500 | 2 | 1 | > |200 | 5 | 1 | > |100 | 10 | 1 | > ------------------------------------ > > Why only the return value of HZ=1000 is equal to 0 with m=0 ? I don't know how you tested that, but obviously all four HZ values use this variant: > #if HZ <= MSEC_PER_SEC && !(MSEC_PER_SEC % HZ) > static inline unsigned long _msecs_to_jiffies(const unsigned int m) > { > return (m + (MSEC_PER_SEC / HZ) - 1) / (MSEC_PER_SEC / HZ); > } and for all four HZ values the result is 0. Why? For m = 0 the calculation reduces to: ((MSEC_PER_SEC / HZ) - 1) / (MSEC_PER_SEC / HZ) i.e. (x - 1) / x where x = [1, 2, 5, 10] which is guaranteed to be 0 for integer math. If not, you have a compiler problem. Thanks, tglx