Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id DA75EC433FE for ; Sun, 21 Nov 2021 18:28:02 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238713AbhKUSbG (ORCPT ); Sun, 21 Nov 2021 13:31:06 -0500 Received: from mo4-p01-ob.smtp.rzone.de ([85.215.255.50]:26382 "EHLO mo4-p01-ob.smtp.rzone.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237990AbhKUSbF (ORCPT ); Sun, 21 Nov 2021 13:31:05 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; t=1637519274; s=strato-dkim-0002; d=hartkopp.net; h=In-Reply-To:Date:Message-ID:From:References:Cc:To:Subject:Cc:Date: From:Subject:Sender; bh=HDLQePCss32+izVjtARSwnNLX22dM+LKVoLBVr7VLwg=; b=R3XMgEOsSkFL2uueOAFUXcwC3yBdxX7UOAmDSN5vlYbQ/2W5Z76kFVsvVQtdRuAw5/ 6yUiSTMgSkXiVup6V/HGErzBbdJZrkCOmgBgWxpdC4dSJqKv4tS8QrvAkaAzrmcafand kBY+fboXySA5sVBISuic4FBgHX9xxrHCaTLCNm3RQ/PPn0PRIfhaHMTkCfDszjh6hoYa mLuL6zNTgS8Ak7NOYTU+rY5/q9R+KJRg8y3u6ehedhSXGJo8pNc3DfbI9vvyUndGy0kz JN9QUmUZMBr5x5BMcbpNBLsluASbM04lYoI/vFFLwMFKWLktyrPbwfbxFj1tacfgr1KC PiAg== Authentication-Results: strato.com; dkim=none X-RZG-AUTH: ":P2MHfkW8eP4Mre39l357AZT/I7AY/7nT2yrDxb8mjG14FZxedJy6qgO1qCHSa1GLptZHusx3hdd0DIgVuBOfXW6v7w==" X-RZG-CLASS-ID: mo00 Received: from [IPv6:2a00:6020:1cfa:f900::b82] by smtp.strato.de (RZmta 47.34.5 AUTH) with ESMTPSA id 40acd5xALIRrdH6 (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256 bits)) (Client did not present a certificate); Sun, 21 Nov 2021 19:27:53 +0100 (CET) Subject: Re: [PATCH] can: bittiming: replace CAN units with the SI metric To: Vincent Mailhol , Marc Kleine-Budde , linux-can@vger.kernel.org Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Jimmy Assarsson References: <20211119161850.202094-1-mailhol.vincent@wanadoo.fr> From: Oliver Hartkopp Message-ID: <38544770-9e5f-1b1b-1f0a-a7ff1719327d@hartkopp.net> Date: Sun, 21 Nov 2021 19:27:47 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.14.0 MIME-Version: 1.0 In-Reply-To: <20211119161850.202094-1-mailhol.vincent@wanadoo.fr> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 19.11.21 17:18, Vincent Mailhol wrote: > In [1], we introduced a set of units in linux/can/bittiming.h. Since > then, generic SI prefix were added to linux/units.h in [2]. Those new > prefix can perfectly replace the CAN specific units. > > This patch replaces all occurrences of the CAN units with their > corresponding prefix according to below table. > > CAN units SI metric prefix > ------------------------------- > CAN_KBPS KILO > CAN_MBPS MEGA > CAM_MHZ MEGA > > The macro declarations are then removed from linux/can/bittiming.h > > [1] commit 1d7750760b70 ("can: bittiming: add CAN_KBPS, CAN_MBPS and > CAN_MHZ macros") > > [2] commit 26471d4a6cf8 ("units: Add SI metric prefix definitions") > > Suggested-by: Jimmy Assarsson > Signed-off-by: Vincent Mailhol > --- > drivers/net/can/dev/bittiming.c | 5 +++-- > drivers/net/can/usb/etas_es58x/es581_4.c | 5 +++-- > drivers/net/can/usb/etas_es58x/es58x_fd.c | 5 +++-- > include/linux/can/bittiming.h | 7 ------- > 4 files changed, 9 insertions(+), 13 deletions(-) > > diff --git a/drivers/net/can/dev/bittiming.c b/drivers/net/can/dev/bittiming.c > index 0509625c3082..a5c9f973802a 100644 > --- a/drivers/net/can/dev/bittiming.c > +++ b/drivers/net/can/dev/bittiming.c > @@ -4,6 +4,7 @@ > * Copyright (C) 2008-2009 Wolfgang Grandegger > */ > > +#include > #include > > #ifdef CONFIG_CAN_CALC_BITTIMING > @@ -81,9 +82,9 @@ int can_calc_bittiming(struct net_device *dev, struct can_bittiming *bt, > if (bt->sample_point) { > sample_point_nominal = bt->sample_point; > } else { > - if (bt->bitrate > 800 * CAN_KBPS) > + if (bt->bitrate > 800 * KILO) > sample_point_nominal = 750; > - else if (bt->bitrate > 500 * CAN_KBPS) > + else if (bt->bitrate > 500 * KILO) > sample_point_nominal = 800; > else > sample_point_nominal = 875; > diff --git a/drivers/net/can/usb/etas_es58x/es581_4.c b/drivers/net/can/usb/etas_es58x/es581_4.c > index 14e360c9f2c9..ed340141c712 100644 > --- a/drivers/net/can/usb/etas_es58x/es581_4.c > +++ b/drivers/net/can/usb/etas_es58x/es581_4.c > @@ -10,6 +10,7 @@ > */ > > #include > +#include > #include > > #include "es58x_core.h" > @@ -469,8 +470,8 @@ const struct es58x_parameters es581_4_param = { > .bittiming_const = &es581_4_bittiming_const, > .data_bittiming_const = NULL, > .tdc_const = NULL, > - .bitrate_max = 1 * CAN_MBPS, > - .clock = {.freq = 50 * CAN_MHZ}, > + .bitrate_max = 1 * MEGA, > + .clock = {.freq = 50 * MEGA}, IMO we are losing information here. It feels you suggest to replace MHz with M. So where is the Hz information then? > .ctrlmode_supported = CAN_CTRLMODE_CC_LEN8_DLC, > .tx_start_of_frame = 0xAFAF, > .rx_start_of_frame = 0xFAFA, > diff --git a/drivers/net/can/usb/etas_es58x/es58x_fd.c b/drivers/net/can/usb/etas_es58x/es58x_fd.c > index 4f0cae29f4d8..aec299bed6dc 100644 > --- a/drivers/net/can/usb/etas_es58x/es58x_fd.c > +++ b/drivers/net/can/usb/etas_es58x/es58x_fd.c > @@ -12,6 +12,7 @@ > */ > > #include > +#include > #include > > #include "es58x_core.h" > @@ -522,8 +523,8 @@ const struct es58x_parameters es58x_fd_param = { > * Mbps work in an optimal environment but are not recommended > * for production environment. > */ > - .bitrate_max = 8 * CAN_MBPS, > - .clock = {.freq = 80 * CAN_MHZ}, > + .bitrate_max = 8 * MEGA, > + .clock = {.freq = 80 * MEGA}, > .ctrlmode_supported = CAN_CTRLMODE_LOOPBACK | CAN_CTRLMODE_LISTENONLY | > CAN_CTRLMODE_3_SAMPLES | CAN_CTRLMODE_FD | CAN_CTRLMODE_FD_NON_ISO | > CAN_CTRLMODE_CC_LEN8_DLC | CAN_CTRLMODE_TDC_AUTO, > diff --git a/include/linux/can/bittiming.h b/include/linux/can/bittiming.h > index 20b50baf3a02..a81652d1c6f3 100644 > --- a/include/linux/can/bittiming.h > +++ b/include/linux/can/bittiming.h > @@ -12,13 +12,6 @@ > #define CAN_SYNC_SEG 1 > > > -/* Kilobits and Megabits per second */ > -#define CAN_KBPS 1000UL > -#define CAN_MBPS 1000000UL > - > -/* Megahertz */ > -#define CAN_MHZ 1000000UL So what about #define CAN_KBPS KILO /* kilo bits per second */ #define CAN_MBPS MEGA /* mega bits per second */ #define CAN_MHZ MEGA /* mega hertz */ ?? Regards, Oliver > - > #define CAN_CTRLMODE_TDC_MASK \ > (CAN_CTRLMODE_TDC_AUTO | CAN_CTRLMODE_TDC_MANUAL) > >