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 <henning.sch...@siemens.com>
---
 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

Reply via email to