Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3687340pxf; Mon, 15 Mar 2021 16:11:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxiui9hUAB9/VgXYfktvi2MWKoSNoUN/h8Sb0Qg4IhNRZeHkPnVhERVQW/Jq7tF/owwNlpY X-Received: by 2002:a05:6402:518d:: with SMTP id q13mr32784031edd.313.1615849862865; Mon, 15 Mar 2021 16:11:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615849862; cv=none; d=google.com; s=arc-20160816; b=B39/ID2FKUydQiG/dE3N/wzOPK3Rny/ohJDtiaR/w2m29j/Cz7xIDc0CgUNNRNqTOQ CSYCg9hWpUdn6ejY/ZTLX+NdQgmhattaCCZLPxb2v1RcH1eDMxGhJ8XsPJGib6sEYZi1 P53ec3P6vEvyptaGJD3dg9INlaeJpYHSK8TYI2l2IVHuCC0ys9a94z5SN6xROF/AzD1f GbV58Z2c4I8gZAcTHmvhYD4gjxeKT/Xzfd//mcCUqbPnf4oI2hnLLEGxCd2LtLlvQIsx 8p2y5QhtEIy6WImiqDWZpa8ixdpj0ZCNyvtxtDMNStrHbpCtkM2rvso05SBXXNjeKngM R7Zw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=rO4WnttqKTSClNqzHyruAvqwrBD8yA+dJKnk+r72YSw=; b=Dn8QLNanwracv1UjowNGpq+jETbAvHSshRP8lsLXImRgS/hLaHHKhIVw5rpqWF+IK9 JlvHK9WwmD52Yxhhe8oLwRpFdOWDgxUgfXgHJpYKkD6E5/VNkUk/EldxU7cuJ/JA5+IE 2pkFBSXvBStDRK32ew5zIhQXvGfcrgl1B8RkO7AST4crYGUTH6moR2d4OUVvFP80PXxQ SH+QEewmz37UVpJVeWm+7OdIM3f/nZf5RYKqjYQphh6OrtylBkimPz3FcynbfNwlXusQ ZJvK21igifs/k+fLjOuMROTS94QXYoRDmq9u3VqSj1+wiM1Gsoct3DYQasNIXOuQt2mM 9EmQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=Xw6p1wtv; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b24si11267286edr.415.2021.03.15.16.10.39; Mon, 15 Mar 2021 16:11:02 -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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=Xw6p1wtv; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232918AbhCOSB1 (ORCPT + 99 others); Mon, 15 Mar 2021 14:01:27 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:35558 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230046AbhCOSBS (ORCPT ); Mon, 15 Mar 2021 14:01:18 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1615831277; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=rO4WnttqKTSClNqzHyruAvqwrBD8yA+dJKnk+r72YSw=; b=Xw6p1wtv0lndn8D8/T0KXPq2McIUgeZX6Mj4OF896MUY5g1zNwXG6j8w4T5cUcTnuc0QRm n4ErfEVsIOq5ITskz3dA6p/fTLxy/kRGu1tASuSYahEV83BCRUANg2mc2j4qpdS9W37+xB NESWXxBA6dCxw8wpu2L8htowMCfrvjQ= Received: from mail-ej1-f69.google.com (mail-ej1-f69.google.com [209.85.218.69]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-54-J-OdUT8qPHOsIEWrVTByOA-1; Mon, 15 Mar 2021 14:01:16 -0400 X-MC-Unique: J-OdUT8qPHOsIEWrVTByOA-1 Received: by mail-ej1-f69.google.com with SMTP id mj6so12436260ejb.11 for ; Mon, 15 Mar 2021 11:01:16 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=rO4WnttqKTSClNqzHyruAvqwrBD8yA+dJKnk+r72YSw=; b=Nt/HWb7Gybv4D6KOoioFISmHMUNO+VciAAn7ImY8Tewn7r9KUgh0IKVueMM2AQz07m npQB79xs4WzDwqxv7XPq3mdUxG+yYEU9QcSwUJYb8ecSBjaELIpSU67nnuj5Ng6JZoll hgW+masonSzc/o1KXKuJGfQJMCoS2Hs3j89KNeNEj2OCCyFcy4bzwECzcG0s6hn46F5n y0KvE8QgI3dq4JfCdqxpTbODmV9jJ5b74uSBgL8+n58hVHFJ4WvZ1bqG26m4hMkrBvCt 2x2VvhdMsGPU5qxYEj68mg1HHA5ycN0pliRLp8HlffhJsrwpm8UH15T5Ww2ffJKUCXen fx3g== X-Gm-Message-State: AOAM532r/0A9Y8c9JuGBC4mSVYMWOlHJ0Zxp9MPw1E+Q2t5WnXYs/goG R8GMBYxAocnvaeml3laW0W9meKnFFoUaZDigUf4Kp0S2HIlZvP582ccv+HyUVChXpB43VlBs4Bf baHKwX7m/NWxBp5/nukfCr83W X-Received: by 2002:a17:906:3952:: with SMTP id g18mr9307097eje.104.1615831275140; Mon, 15 Mar 2021 11:01:15 -0700 (PDT) X-Received: by 2002:a17:906:3952:: with SMTP id g18mr9307057eje.104.1615831274884; Mon, 15 Mar 2021 11:01:14 -0700 (PDT) Received: from x1.localdomain (2001-1c00-0c1e-bf00-1054-9d19-e0f0-8214.cable.dynamic.v6.ziggo.nl. [2001:1c00:c1e:bf00:1054:9d19:e0f0:8214]) by smtp.gmail.com with ESMTPSA id q26sm7883367eja.45.2021.03.15.11.01.13 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 15 Mar 2021 11:01:14 -0700 (PDT) Subject: Re: [PATCH] platform/x86: pmc_atom: use callback for all dmi quirk entries To: Henning Schild 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 References: <20210315145855.17174-1-henning.schild@siemens.com> <8577f3a8-c5e4-3752-1bc1-5937ee164217@redhat.com> <20210315180011.6a3f60b0@md1za8fc.ad001.siemens.net> From: Hans de Goede Message-ID: <43841119-4839-09d2-b606-7dd40cad4b89@redhat.com> Date: Mon, 15 Mar 2021 19:01:13 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.7.0 MIME-Version: 1.0 In-Reply-To: <20210315180011.6a3f60b0@md1za8fc.ad001.siemens.net> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 3/15/21 6:00 PM, Henning Schild wrote: > 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. Ack, that sounds good to me. 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); >>> } >>> } >>> >>> >> >