Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp5344794yba; Wed, 10 Apr 2019 17:38:38 -0700 (PDT) X-Google-Smtp-Source: APXvYqzxixJjrnj28MajjvPuDwWC/TFP5xjTpv7klgWEOJsg66FPhasDeNqCc7mMDKRz8ImEHtle X-Received: by 2002:a17:902:a98b:: with SMTP id bh11mr47578701plb.63.1554943118233; Wed, 10 Apr 2019 17:38:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554943118; cv=none; d=google.com; s=arc-20160816; b=fI0U/TptpZ15641euJiU9ulTyl6t1ySZp8Xb72rAuv+prmfUhYCvJLiQvpfnl9/PHr iV9WO//KpzjVf2tfPUOZpiNCpzar5VaouTbdlXNHjXtA/EaP/iy7V9kiy8ucQFVXj41T dhvUVGmEz41Xca1X1eWmxQ4z9HrrQ9Rd/LyEK/m5+0Dlh7HTpXpftywo4Jwxz3k2S7X7 ciNDYB3nJHBbBHjtn7AjnluICwAGA5OPvzxIcJbn0li6H2MVdDVSGtjHwk2L5KQGEpXg 2rt7X/kh5y7GCFPIHTTGasclg9EOOD/BwbBn8WD1vObMPNSgEw7hiEJo1w6HeCKz807V kDbA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:references :mime-version:message-id:in-reply-to:date:dkim-signature; bh=WuCLO1xjYGpgkgYX+R5A6aWXWpQcgwwbzIbNqQedb3g=; b=soGLsThZPPtuJtx2tK59DHUziFFurdDf74ay57ejXbUQy/LkmwFpaPoc+Cr5k3llHa bZdzzt+BegPrn20IQPq8Qy2BUY0yhhF0hSRYH4SrLwTfWoxMizpChYW2m4f0ZtB0HY+A KGXHhVFQVX8cwjMiEHqCv9i6oPRqyqd+qWU1ScBV7hHTrKwuHyPG8cRZ9SgH9k7TtomI c4xAwgT21GkHUVw3TCzAJghZmXxrAC6s7hivqCYjCRZduVhOetHa3BrPZ1ISeM/fDju6 fVu4e6VS4GKu52E2HbvdNyZ0MEXoC6AvOhiJMiz91FEuojnQhTUZDgnqkcSWsVsVaT5J 6JOg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=IcJskFP5; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o6si34592794plh.186.2019.04.10.17.38.21; Wed, 10 Apr 2019 17:38:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=IcJskFP5; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726773AbfDKAhs (ORCPT + 99 others); Wed, 10 Apr 2019 20:37:48 -0400 Received: from mail-pl1-f201.google.com ([209.85.214.201]:37072 "EHLO mail-pl1-f201.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725982AbfDKAhs (ORCPT ); Wed, 10 Apr 2019 20:37:48 -0400 Received: by mail-pl1-f201.google.com with SMTP id v5so2889596plo.4 for ; Wed, 10 Apr 2019 17:37:48 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=WuCLO1xjYGpgkgYX+R5A6aWXWpQcgwwbzIbNqQedb3g=; b=IcJskFP59nqQ5mMXNq/5o//icwqeVqId2wqPiIY3EhJX2irh1kELAK854GGCOjV/bZ 6HBSJZJF0IYJtNS0SuFmbIf/NTXRo72PCy8hrI65ij3MND33zs969MAU7QFpeaxRzDmJ npgDP39/zC8UvwE/68CJRJ/Y+TCSqBBiyJn95MuznFkAeLBQSKJBOR3KZKKdMAJlaqnl XC06ww6anU8YSYlDonGUu/g1RS/N5b7Zs1IKqheSZRuBObzsFAefwSheZgFVD2Q5Ks6T /aG99s/Z/qQ6ki9llMl4P+mv6G4n82wvrx3ISYjmvFvWbEw3J0/o4UYBb3WBXJWqGHph Yd5A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=WuCLO1xjYGpgkgYX+R5A6aWXWpQcgwwbzIbNqQedb3g=; b=Gg/gwkTtyNuMjmEY9jJoRe7aqm/FLnJKX51hAoasefM9CIc0h+t2NnoWFcn+HAPmNe O/L7X2s0McgQNVdR1fpe2PJeeo4TdQludwv+4lDcWtFkg8xsDGu8949ngGWT7mjDjSUz JtT64GwLzfq9sMqZeZQhz6al7oW61wQXHvinQNvi2XaD8gBCyAgzPqFNqUEIULEX8gDT u5D45Fdd/J+Wp+ADp6LFGmUFbmh2R+9EUzcdCr+s0YcRCPtzTELOTy8cBwNmYQAlTT1I k4BXfgT9neSWHimGK8nQuAKaGAGrBMw2QpltiuHY4Nte/cUhxZ/Lp6Z+UU1lPxQaOqp7 I+RA== X-Gm-Message-State: APjAAAUYXsWNcmHUK4qKRmZ0lr7GccMab8fSJSGoQefejmNAMzul6oyj nO6rnXfN5dRWZFqLsqf7or08fwhl4gE+ X-Received: by 2002:a17:902:8f90:: with SMTP id z16mr1946536plo.6.1554943067362; Wed, 10 Apr 2019 17:37:47 -0700 (PDT) Date: Wed, 10 Apr 2019 17:37:36 -0700 In-Reply-To: <20190313222124.229371-1-rajatja@google.com> Message-Id: <20190411003738.55073-1-rajatja@google.com> Mime-Version: 1.0 References: <20190313222124.229371-1-rajatja@google.com> X-Mailer: git-send-email 2.21.0.392.gf8f6787159e-goog Subject: [PATCH v5 1/3] platform/x86: intel_pmc_core: Convert to a platform_driver From: Rajat Jain To: Rajneesh Bhardwaj , Vishwanath Somayaji , Darren Hart , Andy Shevchenko , platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org, Rafael J Wysocki , Srinivas Pandruvada Cc: Rajat Jain , furquan@google.com, evgreen@google.com, rajatxjain@gmail.com Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Convert the intel_pmc_core driver to a platform driver, and attach using the ACPI enumeration method (via the ACPI device "INT33A1"). Signed-off-by: Rajat Jain --- v5: Remove the gerrit ID from commit log v4: put back the x86_match_cpu() method. v3: Don't instantiate the platform_device. Use ACPI enumeration. v2: Rephrase the commit log. No code changes. drivers/platform/x86/intel_pmc_core.c | 42 ++++++++++++++++++++++----- 1 file changed, 34 insertions(+), 8 deletions(-) diff --git a/drivers/platform/x86/intel_pmc_core.c b/drivers/platform/x86/intel_pmc_core.c index 9908d233305e..8da886e17681 100644 --- a/drivers/platform/x86/intel_pmc_core.c +++ b/drivers/platform/x86/intel_pmc_core.c @@ -19,6 +19,7 @@ #include #include #include +#include #include #include @@ -854,13 +855,17 @@ static const struct dmi_system_id pmc_core_dmi_table[] = { {} }; -static int __init pmc_core_probe(void) +static int pmc_core_probe(struct platform_device *pdev) { + static bool device_initialized; struct pmc_dev *pmcdev = &pmc; const struct x86_cpu_id *cpu_id; u64 slp_s0_addr; int err; + if (device_initialized) + return -ENODEV; + cpu_id = x86_match_cpu(intel_pmc_core_ids); if (!cpu_id) return -ENODEV; @@ -888,28 +893,49 @@ static int __init pmc_core_probe(void) mutex_init(&pmcdev->lock); pmcdev->pmc_xram_read_bit = pmc_core_check_read_lock_bit(); + dmi_check_system(pmc_core_dmi_table); + platform_set_drvdata(pdev, pmcdev); + err = pmc_core_dbgfs_register(pmcdev); if (err < 0) { - pr_warn(" debugfs register failed.\n"); + dev_warn(&pdev->dev, "debugfs register failed.\n"); iounmap(pmcdev->regbase); return err; } - dmi_check_system(pmc_core_dmi_table); - pr_info(" initialized\n"); + dev_info(&pdev->dev, " initialized\n"); + device_initialized = true; + return 0; } -module_init(pmc_core_probe) -static void __exit pmc_core_remove(void) +static int pmc_core_remove(struct platform_device *pdev) { - struct pmc_dev *pmcdev = &pmc; + struct pmc_dev *pmcdev = platform_get_drvdata(pdev); + platform_set_drvdata(pdev, NULL); pmc_core_dbgfs_unregister(pmcdev); mutex_destroy(&pmcdev->lock); iounmap(pmcdev->regbase); + return 0; } -module_exit(pmc_core_remove) + +static const struct acpi_device_id pmc_core_acpi_ids[] = { + {"INT33A1", 0}, /* _HID for Intel Power Engine, _CID PNP0D80*/ + { } +}; +MODULE_DEVICE_TABLE(acpi, pmc_core_acpi_ids); + +static struct platform_driver pmc_core_driver = { + .driver = { + .name = "pmc_core", + .acpi_match_table = ACPI_PTR(pmc_core_acpi_ids), + }, + .probe = pmc_core_probe, + .remove = pmc_core_remove, +}; + +module_platform_driver(pmc_core_driver); MODULE_LICENSE("GPL v2"); MODULE_DESCRIPTION("Intel PMC Core Driver"); -- 2.21.0.392.gf8f6787159e-goog