Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3419631yba; Tue, 23 Apr 2019 03:33:32 -0700 (PDT) X-Google-Smtp-Source: APXvYqwGly639IsQPK+PJHHegg9vYGtgSULHchttDZD+MVqfOKKrVmiXcw5jUwebmwYKuXokZkM3 X-Received: by 2002:a17:902:e287:: with SMTP id cf7mr25510650plb.217.1556015612623; Tue, 23 Apr 2019 03:33:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556015612; cv=none; d=google.com; s=arc-20160816; b=iLqzp3MwVbnCdkILcIZXxO2ntIbbBLYgPxxC06BOLzp1Z3Lj6nhuvgtyQJn3WZHwAj sYzVEFIp3+V2sHbTMYusMk6wzTj7uDHLo4LS1vLlKyUzC4aZ3oOa66lH9JsVrpr1qESP +HV3nSIK4aODLh1PBv/wTA30lkYXvBjp2SSjMk6cMOFRXwpCTK+3UT/TqYq503tgNnoM I9gdu9FlA70kF2IDlw498SUtuDGn0HvPm25pI50J+8I7uOtKQi9QQ8dY8+Ipsk651bIG G9z+p+Fsq3L8l2sYyY6C9s3KxdZM6ieeybG3zlBoeM2OnuMiKO92zD7NxQQ9eqEp9ole tqTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=RkYx4VVXuM+AQksPd61bD8N8/jg5mPWg3jCHNvjS0zg=; b=Ns00+7+ukTlm5G0SPEFIe68NldU5i/kSU17iwvSFRGDNcY+v0zdMCGewVGWcFke43q IfAMWCXX0eKq4Dcm7JjQ+TTY7Wr7Yd9vV7Xc5daAPHaSiQ44w9/0FZPd9Hw92PPuBYwi vTBOs/nbp86sKeDPVmmnPJG9YjtCtHPXfMAYizbT836Ky9bBdvTkXX/KCRfXEIWN4DgQ H+0K7mNU0yKepc2Xav+UZxIHDQChVE/kzPjVnQ8EIhd5QluxgZJ0y/dqMiSh43BCjP8v 59GFDaNwqeoArclwuTgIDhlCM8r2g7ttON0S6b5VtEw3wWBJ4rofvkq19uaTdT3TdJmZ 5N/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=JbOJ36g5; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f96si15744151plb.267.2019.04.23.03.33.17; Tue, 23 Apr 2019 03:33:32 -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; dkim=fail header.i=@gmail.com header.s=20161025 header.b=JbOJ36g5; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727272AbfDWKak (ORCPT + 99 others); Tue, 23 Apr 2019 06:30:40 -0400 Received: from mail-wr1-f66.google.com ([209.85.221.66]:41737 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725990AbfDWKaj (ORCPT ); Tue, 23 Apr 2019 06:30:39 -0400 Received: by mail-wr1-f66.google.com with SMTP id c12so13344002wrt.8 for ; Tue, 23 Apr 2019 03:30:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=RkYx4VVXuM+AQksPd61bD8N8/jg5mPWg3jCHNvjS0zg=; b=JbOJ36g5HrEYz1hpICE1KVLKHclv3MCpr8FHTQilDMksA7XYQBfIoQkS/yarKhGK0F ShOJbv6Bv74yOCvyDng+iMVJqf/lrroHfBAvXRAcic+PW8tGmugeowAt5llXdRsBRx0Y IAr0ZCRiAxl4mHE3tI/xooMJqz/ggJseIRRh+gzzjufA3zESJIpPsAymAs5G6IcJq9lz L4DaGQTSJZcTLpPp+DT8Z7r33OrNOQ89q+v597A+AwmmDIMcSGAJ6eGF7k/s4VJQGp7h eCKin8lXPXwtFQ8/JUQ/WY3qVh2cE2x7FpKemmvbJHNvT6yFHWSp/1S0vIpGw3J/SbF5 EKZg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :references:mime-version:content-disposition:in-reply-to:user-agent; bh=RkYx4VVXuM+AQksPd61bD8N8/jg5mPWg3jCHNvjS0zg=; b=Cml/E6d0E15FnixgDYrLYko0FNmAIJ1R7hp3pmTbjWB9OCoNIvYTZy4CVlY/QIE1oj 5u1OyUuTr9ihKH1/0X0f2o1/C52biQCVSCCXNz3VS1hn0DDTLG9a4A4H5ZXNjBa/H0fI L/ygBACLNOth6oPvRFZzflBxRATYSSAsB3+Za/9SzWZFEWDzhaezK06IbJZ3qC9Yq/35 EItnl0xJFnyNo+9+lzs6CcWPhnWgIlh+58h9DjRCp6tS0Q1YOcFc3UzwadlRrXhfgKBr 5Semuc7YSRmr/d9tbo688cQBb9bdWq7qICHcEHZiWG0IwgLhuIyRz4HylgXNqZyLTJwo ZeeA== X-Gm-Message-State: APjAAAVpAsoXX0JI0BhZLCl0sMkm3Ygc/JL+6oDbpUly8YMf/Lpp+NGC Ku+tzjUJoxilLYWJpO3xFdM= X-Received: by 2002:adf:ebd0:: with SMTP id v16mr7041309wrn.175.1556015438048; Tue, 23 Apr 2019 03:30:38 -0700 (PDT) Received: from gmail.com (2E8B0CD5.catv.pool.telekom.hu. [46.139.12.213]) by smtp.gmail.com with ESMTPSA id l1sm4272943wrh.58.2019.04.23.03.30.36 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 23 Apr 2019 03:30:37 -0700 (PDT) Date: Tue, 23 Apr 2019 12:30:34 +0200 From: Ingo Molnar To: Daniel Drake Cc: Thomas Gleixner , Ingo Molnar , Borislav Petkov , hpa@zytor.com, x86@kernel.org, Linux Kernel , Len Brown , "Wysocki, Rafael J" , Linux Upstreaming Team Subject: Re: [PATCH 2/2] x86/tsc: set LAPIC timer frequency to crystal clock frequency Message-ID: <20190423103034.GA8216@gmail.com> References: <20190422101526.28415-1-drake@endlessm.com> <20190422101526.28415-2-drake@endlessm.com> <20190422120451.GA9499@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Daniel Drake wrote: > On Mon, Apr 22, 2019 at 8:04 PM Ingo Molnar wrote: > > Minor style nit: the parentheses are unnecessary, integer expressions > > like this are evaluated left to right and multiplication and division has > > the same precedence. > > Fair point, although the same could be said for cpu_khz_from_msr(). Yes, this standardization on mhz, if it makes sense, might have to be propagated a bit to function names and any other variables. Another naming quirk: what unit is 'lapic_timer_frequency' in? AFAICS it's a "period" unit (number of clock cycles per jiffy), not a frequency (which is number of cycles per second) - so the better name might be lapic_timer_period? > > But it might also make sense to actually store crystal_mhz instead of > > crystal_khz, because both CPUID 15H and 16H provides MHz values. > > > > That way the above expression would simplify to: > > > > lapic_timer_frequency = crystal_mhz / HZ; > > Wouldn't it be > lapic_timer_frequency = crystal_mhz * 1000000 / HZ; > ? Sorry, what I wanted to suggest is crystal_hz, not crystal_mhz. I.e. store the raw unit that comes out of the CPUID, which appears to be HZ, right? That would change the calculation to: lapic_timer_period = crystal_hz / HZ; Note how clearly it's visible in that calculation that what we calculate there is a 'period', not a frequency. Thanks, Ingo