Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3460956pxf; Mon, 15 Mar 2021 10:02:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxg07BgagdQHWLlEzFjImk769lgi2tpo32Exn1pykt/4bV5HptWNZPyibfwipFW6l0cLTY1 X-Received: by 2002:a17:906:c402:: with SMTP id u2mr24656280ejz.546.1615827748347; Mon, 15 Mar 2021 10:02:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615827748; cv=none; d=google.com; s=arc-20160816; b=YhJAMWWT0IcJdqU87uNsZC4OQJEuG/Y8clsPChTDDU59fluMZtgaGflxp5NPBlj/4o tlcbHAz1j1qh3GmESv/WaSrFjjQ/+C01WKLuI1aqOEv6coysQ08CwUH8DSWDCj+kdt3/ oBCxNFDW7kUAdbVZI9DojrBQbEKea5NGdEmoBYb9CAxBisLhdmETFmv+fav8WwXk0zJv 8RKYLkKP1x3B6sypPkK4I20gO0EvEiuQha6VaOcHehAb+RBZr/EwNbP4e1nZ5bSdyt1r FjlxOnrTwHLcW8+hEZM3HpVuxLn912DkBz9q1U3Hy00YqeNMbMf4K0nQiOwaJxlEDUVX 1snA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=rXV0Zvx9toKblxNqdHqC9RSsM7+khnTxs7y1XIjRKTw=; b=qA6HHPFNPaeEOugaZOHWum/i8N/Wsya/0TKugYDZmkDjgiPDY7bQ9LUXco2VLfNbwL FAbRzKX/rwjWijyn15c1wNbVO2QQEFiR+TBzz+7V/RyyWYW9T2B0hsZsbcOesxelJTzi cUX4MAoD2AQQD5gKiK+EXYpgggOAesHrzFH4SzWZSSxs8kSTXdEJehrwGHDdPxwrXUnu 0CvImze3crnPveSaQjhhhZqLZmfXtFS5DqUH/B1SfZSUqGoH6kXrvVgA6AUVZZoptu4+ dr3cdcsL4QwzRBGMHU9FKo7q99+tyfOGHsrl8nfHz6OkGa0U+cH8KlOZIsQh0md7X42T LZ4w== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=siemens.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 26si11209071ejy.13.2021.03.15.10.02.05; Mon, 15 Mar 2021 10:02:28 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=siemens.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234140AbhCORAu (ORCPT + 99 others); Mon, 15 Mar 2021 13:00:50 -0400 Received: from lizzard.sbs.de ([194.138.37.39]:43061 "EHLO lizzard.sbs.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235783AbhCORAl (ORCPT ); Mon, 15 Mar 2021 13:00:41 -0400 Received: from mail2.sbs.de (mail2.sbs.de [192.129.41.66]) by lizzard.sbs.de (8.15.2/8.15.2) with ESMTPS id 12FH0Elx009549 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 15 Mar 2021 18:00:14 +0100 Received: from md1za8fc.ad001.siemens.net ([139.22.41.172]) by mail2.sbs.de (8.15.2/8.15.2) with ESMTP id 12FH0DGA001450; Mon, 15 Mar 2021 18:00:13 +0100 Date: Mon, 15 Mar 2021 18:00:11 +0100 From: Henning Schild To: Hans de Goede Cc: linux-kernel@vger.kernel.org, linux-leds@vger.kernel.org, platform-driver-x86@vger.kernel.org, linux-watchdog@vger.kernel.org, Srikanth Krishnakar , Jan Kiszka , Gerd Haeussler , Guenter Roeck , Wim Van Sebroeck , Mark Gross , Pavel Machek , Andy Shevchenko Subject: Re: [PATCH] platform/x86: pmc_atom: use callback for all dmi quirk entries Message-ID: <20210315180011.6a3f60b0@md1za8fc.ad001.siemens.net> In-Reply-To: <8577f3a8-c5e4-3752-1bc1-5937ee164217@redhat.com> References: <20210315145855.17174-1-henning.schild@siemens.com> <8577f3a8-c5e4-3752-1bc1-5937ee164217@redhat.com> X-Mailer: Claws Mail 3.17.8 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am Mon, 15 Mar 2021 17:31:49 +0100 schrieb Hans de Goede : > Hi, > > On 3/15/21 3:58 PM, Henning Schild wrote: > > Introduce a global variable to remember the matching entry for later > > printing. Also having a callback allows to stop matching after the > > first hit. > > > > Signed-off-by: Henning Schild > > --- > > drivers/platform/x86/pmc_atom.c | 26 ++++++++++++++++++++------ > > 1 file changed, 20 insertions(+), 6 deletions(-) > > > > diff --git a/drivers/platform/x86/pmc_atom.c > > b/drivers/platform/x86/pmc_atom.c index 38542d547f29..d0f74856cd8b > > 100644 --- a/drivers/platform/x86/pmc_atom.c > > +++ b/drivers/platform/x86/pmc_atom.c > > @@ -364,8 +364,16 @@ static void pmc_dbgfs_register(struct pmc_dev > > *pmc) #endif /* CONFIG_DEBUG_FS */ > > > > static bool pmc_clk_is_critical = true; > > +static const struct dmi_system_id *dmi_critical; > > > > -static int siemens_clk_is_critical(const struct dmi_system_id *d) > > +static int dmi_callback(const struct dmi_system_id *d) > > +{ > > + dmi_critical = d; > > Don't introduce a global variable for this please. Instead just > directly print the ident of the matching dmi_system_id here. Sorry, missed that part. Result looks nice and clean, thanks. I think i will squash it into 4/4 in v3 and not follow up here for now. Henning > Regards, > > Hans > > > > + > > + return 1; > > +} > > + > > +static int dmi_callback_siemens(const struct dmi_system_id *d) > > { > > u32 st_id; > > > > @@ -373,7 +381,7 @@ static int siemens_clk_is_critical(const struct > > dmi_system_id *d) goto out; > > > > if (st_id == SIMATIC_IPC_IPC227E || st_id == > > SIMATIC_IPC_IPC277E) > > - return 1; > > + return dmi_callback(d); > > > > out: > > pmc_clk_is_critical = false; > > @@ -388,6 +396,7 @@ static const struct dmi_system_id > > critclk_systems[] = { { > > /* pmc_plt_clk0 is used for an external HSIC USB > > HUB */ .ident = "MPL CEC1x", > > + .callback = dmi_callback, > > .matches = { > > DMI_MATCH(DMI_SYS_VENDOR, "MPL AG"), > > DMI_MATCH(DMI_PRODUCT_NAME, "CEC10 > > Family"), @@ -396,6 +405,7 @@ static const struct dmi_system_id > > critclk_systems[] = { { > > /* pmc_plt_clk0 - 3 are used for the 4 ethernet > > controllers */ .ident = "Lex 3I380D", > > + .callback = dmi_callback, > > .matches = { > > DMI_MATCH(DMI_SYS_VENDOR, "Lex BayTrail"), > > DMI_MATCH(DMI_PRODUCT_NAME, "3I380D"), > > @@ -404,6 +414,7 @@ static const struct dmi_system_id > > critclk_systems[] = { { > > /* pmc_plt_clk* - are used for ethernet > > controllers */ .ident = "Lex 2I385SW", > > + .callback = dmi_callback, > > .matches = { > > DMI_MATCH(DMI_SYS_VENDOR, "Lex BayTrail"), > > DMI_MATCH(DMI_PRODUCT_NAME, "2I385SW"), > > @@ -412,6 +423,7 @@ static const struct dmi_system_id > > critclk_systems[] = { { > > /* pmc_plt_clk* - are used for ethernet > > controllers */ .ident = "Beckhoff CB3163", > > + .callback = dmi_callback, > > .matches = { > > DMI_MATCH(DMI_SYS_VENDOR, "Beckhoff > > Automation"), DMI_MATCH(DMI_BOARD_NAME, "CB3163"), > > @@ -420,6 +432,7 @@ static const struct dmi_system_id > > critclk_systems[] = { { > > /* pmc_plt_clk* - are used for ethernet > > controllers */ .ident = "Beckhoff CB4063", > > + .callback = dmi_callback, > > .matches = { > > DMI_MATCH(DMI_SYS_VENDOR, "Beckhoff > > Automation"), DMI_MATCH(DMI_BOARD_NAME, "CB4063"), > > @@ -428,6 +441,7 @@ static const struct dmi_system_id > > critclk_systems[] = { { > > /* pmc_plt_clk* - are used for ethernet > > controllers */ .ident = "Beckhoff CB6263", > > + .callback = dmi_callback, > > .matches = { > > DMI_MATCH(DMI_SYS_VENDOR, "Beckhoff > > Automation"), DMI_MATCH(DMI_BOARD_NAME, "CB6263"), > > @@ -436,13 +450,14 @@ static const struct dmi_system_id > > critclk_systems[] = { { > > /* pmc_plt_clk* - are used for ethernet > > controllers */ .ident = "Beckhoff CB6363", > > + .callback = dmi_callback, > > .matches = { > > DMI_MATCH(DMI_SYS_VENDOR, "Beckhoff > > Automation"), DMI_MATCH(DMI_BOARD_NAME, "CB6363"), > > }, > > }, > > { > > - .callback = siemens_clk_is_critical, > > + .callback = dmi_callback_siemens, > > .ident = "SIEMENS AG", > > .matches = { > > DMI_MATCH(DMI_SYS_VENDOR, "SIEMENS AG"), > > @@ -457,7 +472,6 @@ static int pmc_setup_clks(struct pci_dev *pdev, > > void __iomem *pmc_regmap, { > > struct platform_device *clkdev; > > struct pmc_clk_data *clk_data; > > - const struct dmi_system_id *d; > > > > clk_data = kzalloc(sizeof(*clk_data), GFP_KERNEL); > > if (!clk_data) > > @@ -468,8 +482,8 @@ static int pmc_setup_clks(struct pci_dev *pdev, > > void __iomem *pmc_regmap, if (dmi_check_system(critclk_systems)) { > > clk_data->critical = pmc_clk_is_critical; > > if (clk_data->critical) { > > - d = dmi_first_match(critclk_systems); > > - pr_info("%s critclks quirk enabled\n", > > d->ident); > > + pr_info("%s critclks quirk enabled\n", > > + dmi_critical->ident); > > } > > } > > > > >