Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp12002697rwd; Thu, 22 Jun 2023 23:24:08 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7+E70XFVHVviea6n64e+vFgqXsOpYo7dzIjR3aIgaJWOe6u3w6JJLmnCPiUK23FxA2qBVA X-Received: by 2002:a05:6a20:4328:b0:125:377c:831d with SMTP id h40-20020a056a20432800b00125377c831dmr3883599pzk.3.1687501448227; Thu, 22 Jun 2023 23:24:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1687501448; cv=none; d=google.com; s=arc-20160816; b=ZXLnA4Mmk1NNZ6rLShEpHkT2KtSXIw4Rv+tut6lx+nlLPNH/xEfG9H0tp+5LvUcray KsflNxpWgpbFLzRgKvCDOXLjgVDbYhyNj0Fgs1+CzbKOCW9oEyMJro47j5r23M4O5ofN K5lNIug/IfEBLwO3kxKUaWCRJ98aYp155WP0ujji0Xc5vyjnRMBseP0PdXJ7bTRDSWBl dFhr0xlD6/EbfGmZwKZEZCdO0wsZdaKkuywLjifFtEBZXeHo0YtPUJyoVxeFIc4nazad X6AH7iJoBZfViAAYAix08nEY++rdwtZ67AoFjxliYLDNO2E+5jidMcAe0iUshu2ukyk9 wu3g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=T0td1VNIR47ns2jDgOfrorlEct/hsA0FZsXrAibJObA=; b=J78x48+zz3lbzdKf0lve8DkblWmROTEqjOtKJNiSNkucDKFWLSnLDRTsNBEJmM7AMD z7Do2QjPxExU3kIttbFx7NUcgVXuLVgxmyRm7y9hrMHB7mGT8mRtnvKrzleBxAc5bbIr XulS6QGNDqKPy+nNNs6ZPMcigBrv6h7/1OL/XIhW1Gk2LEU/GAAoln/Y3pN17z+WPAYz 06kbDNvu0wzC7ov1T1YrqUqspZsQdsavuAbDVjw0ReXP3pFZHP93EDUxIGg9RR+N+GW4 lpiIr4B6PCvzr6x/XmMf/aXmVmsq+MFylBDKLp0NR/c4L20kv1gs3W6OyIT3NHdLPS6f wm4Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=gQxIxpn1; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y12-20020aa793cc000000b0064d533abfd4si8169091pff.189.2023.06.22.23.23.55; Thu, 22 Jun 2023 23:24:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=gQxIxpn1; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231557AbjFWFyE (ORCPT + 99 others); Fri, 23 Jun 2023 01:54:04 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37198 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229907AbjFWFyC (ORCPT ); Fri, 23 Jun 2023 01:54:02 -0400 Received: from mga11.intel.com (mga11.intel.com [192.55.52.93]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C38749D; Thu, 22 Jun 2023 22:54:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1687499640; x=1719035640; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=uHQJYeajFvE8JFNhEyypndPSDOUZp70wzrPA18ySxHk=; b=gQxIxpn1O6QuYIGZE310HFoqLU8P8OEiUJZKoBEjvvpU/WnjhUf3048G iLQbKmUgmTzj0jv/t7yI7926Eom/l0RXO7CsHS3ddhDzfqnRKxcV4knZ2 iokvf2tAhmmMo/5J3nlkb18A9S02offlDq6ktC92C7uwR1g+IqEIN2/Ns rnrxzN1XNYm4ZGqzGwKI5s93RSUproccGyiz6+UnY7FYP8Z3UERBODNmy L9mKxSeYq5tThr4ebPsl9bdfbzxZrOedFtupcy7RuQd/jd7Cj79s4t2g8 fuqd1QAze71aP1+IJnmWuaFWVRGRABXS8yOx3hLECdPDPq+AlaQuN1/qN w==; X-IronPort-AV: E=McAfee;i="6600,9927,10749"; a="358186323" X-IronPort-AV: E=Sophos;i="6.01,151,1684825200"; d="scan'208";a="358186323" Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Jun 2023 22:53:51 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10749"; a="961853690" X-IronPort-AV: E=Sophos;i="6.01,151,1684825200"; d="scan'208";a="961853690" Received: from choongyo-mobl.gar.corp.intel.com (HELO [10.215.253.116]) ([10.215.253.116]) by fmsmga006-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Jun 2023 22:53:39 -0700 Message-ID: <1599dd7a-f297-577b-7f5c-295a660c0c9c@linux.intel.com> Date: Fri, 23 Jun 2023 13:52:49 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.12.0 Subject: Re: [PATCH net-next 1/6] platform/x86: intel_pmc_core: Add IPC mailbox accessor function and add SoC register access Content-Language: en-US To: Hans de Goede , Rajneesh Bhardwaj , David E Box , Mark Gross , Jose Abreu , Andrew Lunn , Heiner Kallweit , Russell King , "David S . Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , =?UTF-8?Q?Marek_Beh=c3=ban?= , Jean Delvare , Guenter Roeck , Giuseppe Cavallaro , Alexandre Torgue , Jose Abreu , Maxime Coquelin , Richard Cochran , Philipp Zabel , Alexei Starovoitov , Daniel Borkmann , Jesper Dangaard Brouer , John Fastabend , Wong Vee Khee , Jon Hunter , Jesse Brandeburg , Revanth Kumar Uppala , Shenwei Wang , Andrey Konovalov , Jochen Henneberg Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-stm32@st-md-mailman.stormreply.com, linux-arm-kernel@lists.infradead.org, platform-driver-x86@vger.kernel.org, linux-hwmon@vger.kernel.org, bpf@vger.kernel.org, Voon Wei Feng , Tee Min , Michael Sit Wei Hong , Lai Peter Jun Ann References: <20230622041905.629430-1-yong.liang.choong@linux.intel.com> <20230622041905.629430-2-yong.liang.choong@linux.intel.com> <0652c9c8-27ee-0af9-9aa8-a2909142d405@redhat.com> From: Choong Yong Liang In-Reply-To: <0652c9c8-27ee-0af9-9aa8-a2909142d405@redhat.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Hans, I will discuss it with David but currently he is on vacation. It might take some time to get the final output. Thank you. On 22/6/2023 4:18 pm, Hans de Goede wrote: > Hi, > > On 6/22/23 06:19, Choong Yong Liang wrote: >> From: "David E. Box" >> >> - Exports intel_pmc_core_ipc() for host access to the PMC IPC mailbox >> - Add support to use IPC command allows host to access SoC registers >> through PMC firmware that are otherwise inaccessible to the host due to >> security policies. >> >> Signed-off-by: David E. Box >> Signed-off-by: Chao Qin >> Signed-off-by: Choong Yong Liang > > This seem to be 2 patches in 1: > > 1. Move core.h to include/linux/intel_pmc_core.h > 2. The actual adding of IPC mailbox accessor function and add SoC register access > > I wonder if you really need to move the entire core.h ? > > IMHO it would be better to just add a new header with just the bits > which you actually need to export the desired functionality. > > If you do believe that you really need to move core.h please split > this into 2 separate patches and please place the header in a x86 > specific place, e.g. : include/linux/platform_data/x86/ > > > > Also note that a somewhat big refactor, to add support for > multiple PMCs for Meteor Lake is on its way to linux-next. > > Currently this is available in my review-hans branch: > > https://git.kernel.org/pub/scm/linux/kernel/git/pdx86/platform-drivers-x86.git/log/?h=review-hans > > Please base a next version of this on this. > > There also is the question of how to merge this. Assuming this is > ready for merging once 6.5-rc1 is out then I can merge this intel_pmc_core > change into an immutable branch and send a pull-req to the net folks > for this. > > Regards, > > Hans > > > > > > >> --- >> MAINTAINERS | 1 + >> drivers/platform/x86/intel/pmc/adl.c | 2 +- >> drivers/platform/x86/intel/pmc/cnp.c | 2 +- >> drivers/platform/x86/intel/pmc/core.c | 63 ++++++++++++++++++- >> drivers/platform/x86/intel/pmc/icl.c | 2 +- >> drivers/platform/x86/intel/pmc/mtl.c | 2 +- >> drivers/platform/x86/intel/pmc/spt.c | 2 +- >> drivers/platform/x86/intel/pmc/tgl.c | 2 +- >> .../core.h => include/linux/intel_pmc_core.h | 27 +++++++- >> 9 files changed, 95 insertions(+), 8 deletions(-) >> rename drivers/platform/x86/intel/pmc/core.h => include/linux/intel_pmc_core.h (95%) >> >> diff --git a/MAINTAINERS b/MAINTAINERS >> index cb14589d14ab..bdb08a79a5f8 100644 >> --- a/MAINTAINERS >> +++ b/MAINTAINERS >> @@ -10581,6 +10581,7 @@ L: platform-driver-x86@vger.kernel.org >> S: Maintained >> F: Documentation/ABI/testing/sysfs-platform-intel-pmc >> F: drivers/platform/x86/intel/pmc/ >> +F: include/linux/intel_pmc_core* >> >> INTEL PMIC GPIO DRIVERS >> M: Andy Shevchenko >> diff --git a/drivers/platform/x86/intel/pmc/adl.c b/drivers/platform/x86/intel/pmc/adl.c >> index 5cbd40979f2a..b6a376c536c0 100644 >> --- a/drivers/platform/x86/intel/pmc/adl.c >> +++ b/drivers/platform/x86/intel/pmc/adl.c >> @@ -8,7 +8,7 @@ >> * >> */ >> >> -#include "core.h" >> +#include >> >> /* Alder Lake: PGD PFET Enable Ack Status Register(s) bitmap */ >> const struct pmc_bit_map adl_pfear_map[] = { >> diff --git a/drivers/platform/x86/intel/pmc/cnp.c b/drivers/platform/x86/intel/pmc/cnp.c >> index 7fb38815c4eb..504034cc5ec3 100644 >> --- a/drivers/platform/x86/intel/pmc/cnp.c >> +++ b/drivers/platform/x86/intel/pmc/cnp.c >> @@ -8,7 +8,7 @@ >> * >> */ >> >> -#include "core.h" >> +#include >> >> /* Cannon Lake: PGD PFET Enable Ack Status Register(s) bitmap */ >> const struct pmc_bit_map cnp_pfear_map[] = { >> diff --git a/drivers/platform/x86/intel/pmc/core.c b/drivers/platform/x86/intel/pmc/core.c >> index da6e7206d38b..0d60763c5144 100644 >> --- a/drivers/platform/x86/intel/pmc/core.c >> +++ b/drivers/platform/x86/intel/pmc/core.c >> @@ -16,6 +16,7 @@ >> #include >> #include >> #include >> +#include >> #include >> #include >> #include >> @@ -26,7 +27,9 @@ >> #include >> #include >> >> -#include "core.h" >> +#define PMC_IPCS_PARAM_COUNT 7 >> + >> +static const struct x86_cpu_id *pmc_cpu_id; >> >> /* Maximum number of modes supported by platfoms that has low power mode capability */ >> const char *pmc_lpm_modes[] = { >> @@ -53,6 +56,63 @@ const struct pmc_bit_map msr_map[] = { >> {} >> }; >> >> +int intel_pmc_core_ipc(struct pmc_ipc_cmd *ipc_cmd, u32 *rbuf) >> +{ >> + struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL }; >> + union acpi_object params[PMC_IPCS_PARAM_COUNT] = { >> + {.type = ACPI_TYPE_INTEGER,}, >> + {.type = ACPI_TYPE_INTEGER,}, >> + {.type = ACPI_TYPE_INTEGER,}, >> + {.type = ACPI_TYPE_INTEGER,}, >> + {.type = ACPI_TYPE_INTEGER,}, >> + {.type = ACPI_TYPE_INTEGER,}, >> + {.type = ACPI_TYPE_INTEGER,}, >> + }; >> + struct acpi_object_list arg_list = { PMC_IPCS_PARAM_COUNT, params }; >> + union acpi_object *obj; >> + int status; >> + >> + if (!pmc_cpu_id || !ipc_cmd || !rbuf) >> + return -EINVAL; >> + >> + /* >> + * 0: IPC Command >> + * 1: IPC Sub Command >> + * 2: Size >> + * 3-6: Write Buffer for offset >> + */ >> + params[0].integer.value = ipc_cmd->cmd; >> + params[1].integer.value = ipc_cmd->sub_cmd; >> + params[2].integer.value = ipc_cmd->size; >> + params[3].integer.value = ipc_cmd->wbuf[0]; >> + params[4].integer.value = ipc_cmd->wbuf[1]; >> + params[5].integer.value = ipc_cmd->wbuf[2]; >> + params[6].integer.value = ipc_cmd->wbuf[3]; >> + >> + status = acpi_evaluate_object(NULL, "\\IPCS", &arg_list, &buffer); >> + if (ACPI_FAILURE(status)) >> + return -ENODEV; >> + >> + obj = buffer.pointer; >> + /* Check if the number of elements in package is 5 */ >> + if (obj && obj->type == ACPI_TYPE_PACKAGE && obj->package.count == 5) { >> + const union acpi_object *objs = obj->package.elements; >> + >> + if ((u8)objs[0].integer.value != 0) >> + return -EINVAL; >> + >> + rbuf[0] = objs[1].integer.value; >> + rbuf[1] = objs[2].integer.value; >> + rbuf[2] = objs[3].integer.value; >> + rbuf[3] = objs[4].integer.value; >> + } else { >> + return -EINVAL; >> + } >> + >> + return 0; >> +} >> +EXPORT_SYMBOL(intel_pmc_core_ipc); >> + >> static inline u32 pmc_core_reg_read(struct pmc_dev *pmcdev, int reg_offset) >> { >> return readl(pmcdev->regbase + reg_offset); >> @@ -1130,6 +1190,7 @@ static int pmc_core_probe(struct platform_device *pdev) >> mutex_init(&pmcdev->lock); >> core_init(pmcdev); >> >> + pmc_cpu_id = cpu_id; >> >> if (lpit_read_residency_count_address(&slp_s0_addr)) { >> pmcdev->base_addr = PMC_BASE_ADDR_DEFAULT; >> diff --git a/drivers/platform/x86/intel/pmc/icl.c b/drivers/platform/x86/intel/pmc/icl.c >> index 2f11b1a6daeb..f18048ff9382 100644 >> --- a/drivers/platform/x86/intel/pmc/icl.c >> +++ b/drivers/platform/x86/intel/pmc/icl.c >> @@ -8,7 +8,7 @@ >> * >> */ >> >> -#include "core.h" >> +#include >> >> const struct pmc_bit_map icl_pfear_map[] = { >> {"RES_65", BIT(0)}, >> diff --git a/drivers/platform/x86/intel/pmc/mtl.c b/drivers/platform/x86/intel/pmc/mtl.c >> index e8cc156412ce..7897f5fe9881 100644 >> --- a/drivers/platform/x86/intel/pmc/mtl.c >> +++ b/drivers/platform/x86/intel/pmc/mtl.c >> @@ -9,7 +9,7 @@ >> */ >> >> #include >> -#include "core.h" >> +#include >> >> const struct pmc_reg_map mtl_reg_map = { >> .pfear_sts = ext_tgl_pfear_map, >> diff --git a/drivers/platform/x86/intel/pmc/spt.c b/drivers/platform/x86/intel/pmc/spt.c >> index e16982236778..95ce490cf5d6 100644 >> --- a/drivers/platform/x86/intel/pmc/spt.c >> +++ b/drivers/platform/x86/intel/pmc/spt.c >> @@ -8,7 +8,7 @@ >> * >> */ >> >> -#include "core.h" >> +#include >> >> const struct pmc_bit_map spt_pll_map[] = { >> {"MIPI PLL", SPT_PMC_BIT_MPHY_CMN_LANE0}, >> diff --git a/drivers/platform/x86/intel/pmc/tgl.c b/drivers/platform/x86/intel/pmc/tgl.c >> index c245ada849d0..a1719d809497 100644 >> --- a/drivers/platform/x86/intel/pmc/tgl.c >> +++ b/drivers/platform/x86/intel/pmc/tgl.c >> @@ -8,7 +8,7 @@ >> * >> */ >> >> -#include "core.h" >> +#include >> >> #define ACPI_S0IX_DSM_UUID "57a6512e-3979-4e9d-9708-ff13b2508972" >> #define ACPI_GET_LOW_MODE_REGISTERS 1 >> diff --git a/drivers/platform/x86/intel/pmc/core.h b/include/linux/intel_pmc_core.h >> similarity index 95% >> rename from drivers/platform/x86/intel/pmc/core.h >> rename to include/linux/intel_pmc_core.h >> index 9ca9b9746719..82810e8b92a2 100644 >> --- a/drivers/platform/x86/intel/pmc/core.h >> +++ b/include/linux/intel_pmc_core.h >> @@ -250,7 +250,16 @@ enum ppfear_regs { >> #define MTL_LPM_STATUS_OFFSET 0x1700 >> #define MTL_LPM_LIVE_STATUS_OFFSET 0x175C >> >> -extern const char *pmc_lpm_modes[]; >> +#define IPC_SOC_REGISTER_ACCESS 0xAA >> +#define IPC_SOC_SUB_CMD_READ 0x00 >> +#define IPC_SOC_SUB_CMD_WRITE 0x01 >> + >> +struct pmc_ipc_cmd { >> + u32 cmd; >> + u32 sub_cmd; >> + u32 size; >> + u32 wbuf[4]; >> +}; >> >> struct pmc_bit_map { >> const char *name; >> @@ -427,4 +436,20 @@ static const struct file_operations __name ## _fops = { \ >> .release = single_release, \ >> } >> >> +#if IS_ENABLED(CONFIG_INTEL_PMC_CORE) >> +/** >> + * intel_pmc_core_ipc() - PMC IPC Mailbox accessor >> + * @ipc_cmd: struct pmc_ipc_cmd prepared with input to send >> + * @rbuf: Allocated u32[4] array for returned IPC data >> + * >> + * Return: 0 on success. Non-zero on mailbox error >> + */ >> +int intel_pmc_core_ipc(struct pmc_ipc_cmd *ipc_cmd, u32 *rbuf); >> +#else >> +static inline int intel_pmc_core_ipc(struct pmc_ipc_cmd *ipc_cmd, u32 *rbuf) >> +{ >> + return -ENODEV; >> +} >> +#endif /* CONFIG_INTEL_PMC_CORE */ >> + >> #endif /* PMC_CORE_H */ >