Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3365123pxf; Mon, 15 Mar 2021 08:03:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxQrWbfQi9VR/smY1yI6rueDm8kdCnPwmNy5vNi8OBEBirsWfaoua9eY7dcZxf2TLjKqC7w X-Received: by 2002:a17:907:4cf:: with SMTP id vz15mr23739258ejb.113.1615820614791; Mon, 15 Mar 2021 08:03:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615820614; cv=none; d=google.com; s=arc-20160816; b=uTgObb3dTmRteT+X/n4m2lPFFlHVTUP0HMfiJ2rtJW1kCdLYHXg5qDfrxnXXYtO7+G CjQabAN4ehdqc0tayyvf7Qz9Pwrj6K2i8IGHmRbuZJlLGF5guy7vBlizCT/7e5Za7Ebz 5Th+wg9z0JJHZQCfAUrfU8A0SnmWXhH0JrLN+PT/c0ZzoX7g2F53XOs0wajH1Fwxoc0o 6x+LyEOqdN0kUCFnDDxwxNGVe60IK8Pi81VJlzfYksdFYXxW9NQ64mLpuUNQnXjAblJx 4FhbhgOGLJ4lPu7OuR3chw9NBblZcRta1KA4aVpIm8jzjS2wwmPT16764CyHGtYm7h8y 23aw== 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:date:subject:cc:to:from; bh=VWBioud2gVCfU3I/8SUbTG/jctADdN0cmvzS1nD0vvE=; b=qXuFJQIZ5E+RAhcbU9aF5iuj2TgzD1d76UAGqQskNR/GsEqlAJpBA/agLO1hy9KtnR Vp/Skug7a+91LgprztJmAoCMAcirWto19bY4ufSTiX76f4JWsF/DlyDP9XUEb2uAHSwc j4c7hMs7qBvpYsucFSQ97yjuYnf/Y+NbPqCGcT60q/7HJfHvCLGiSA8QRD3mymgAXxQJ Vq49UCULaxgT9NvgeliywbUNmvy3B/d1BRjarZ6mR6VTR5fTUcVqSK7lmUr8pBIkGZt3 NYf94O7t+S+hkmS1HmERVLqOIUY6W8/zjKvQ4IuJmQz65cxQ5irq6rze3Boq/1PUxcM2 PzOg== 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 h8si1069646ejj.598.2021.03.15.08.03.12; Mon, 15 Mar 2021 08:03:34 -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 S234013AbhCOPAB (ORCPT + 99 others); Mon, 15 Mar 2021 11:00:01 -0400 Received: from lizzard.sbs.de ([194.138.37.39]:53985 "EHLO lizzard.sbs.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232141AbhCOO7d (ORCPT ); Mon, 15 Mar 2021 10:59:33 -0400 Received: from mail1.sbs.de (mail1.sbs.de [192.129.41.35]) by lizzard.sbs.de (8.15.2/8.15.2) with ESMTPS id 12FEx1hG025125 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 15 Mar 2021 15:59:01 +0100 Received: from localhost.localdomain ([139.22.41.172]) by mail1.sbs.de (8.15.2/8.15.2) with ESMTP id 12FEx0KA028580; Mon, 15 Mar 2021 15:59:00 +0100 From: Henning Schild To: linux-kernel@vger.kernel.org, linux-leds@vger.kernel.org, platform-driver-x86@vger.kernel.org, linux-watchdog@vger.kernel.org Cc: Srikanth Krishnakar , Jan Kiszka , Henning Schild , Gerd Haeussler , Guenter Roeck , Wim Van Sebroeck , Mark Gross , Hans de Goede , Pavel Machek , Andy Shevchenko Subject: [PATCH] platform/x86: pmc_atom: use callback for all dmi quirk entries Date: Mon, 15 Mar 2021 15:58:55 +0100 Message-Id: <20210315145855.17174-1-henning.schild@siemens.com> X-Mailer: git-send-email 2.26.2 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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; + + 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); } } -- 2.26.2