diff options
| author | Yazen Ghannam <yazen.ghannam@amd.com> | 2025-01-30 19:48:55 +0000 | 
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2025-03-19 11:18:05 +0100 | 
| commit | 8a3dc0f7c4ccf13098dba804be06799b4bd46c7a (patch) | |
| tree | 77c1abcc07c499ccc3da13f9be42378a1ab27d1e /drivers/platform/x86/amd/hsmp/plat.c | |
| parent | ad5a3a8f41aaa511b2150859ef5b1d76fff34fc9 (diff) | |
x86/amd_node, platform/x86/amd/hsmp: Have HSMP use SMN through AMD_NODE
The HSMP interface is just an SMN interface with different offsets.
Define an HSMP wrapper in the SMN code and have the HSMP platform driver
use that rather than a local solution.
Also, remove the "root" member from AMD_NB, since there are no more
users of it.
Signed-off-by: Yazen Ghannam <yazen.ghannam@amd.com>
Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Reviewed-by: Carlos Bilbao <carlos.bilbao@kernel.org>
Acked-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Link: https://lore.kernel.org/r/20250130-wip-x86-amd-nb-cleanup-v4-1-b5cc997e471b@amd.com
Diffstat (limited to 'drivers/platform/x86/amd/hsmp/plat.c')
| -rw-r--r-- | drivers/platform/x86/amd/hsmp/plat.c | 36 | 
1 files changed, 12 insertions, 24 deletions
| diff --git a/drivers/platform/x86/amd/hsmp/plat.c b/drivers/platform/x86/amd/hsmp/plat.c index 02ca85762b68..b9782a078dbd 100644 --- a/drivers/platform/x86/amd/hsmp/plat.c +++ b/drivers/platform/x86/amd/hsmp/plat.c @@ -10,14 +10,16 @@  #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt  #include <asm/amd_hsmp.h> -#include <asm/amd_nb.h> +#include <linux/build_bug.h>  #include <linux/device.h>  #include <linux/module.h>  #include <linux/pci.h>  #include <linux/platform_device.h>  #include <linux/sysfs.h> +#include <asm/amd_node.h> +  #include "hsmp.h"  #define DRIVER_NAME		"amd_hsmp" @@ -34,28 +36,12 @@  #define SMN_HSMP_MSG_RESP	0x0010980  #define SMN_HSMP_MSG_DATA	0x00109E0 -#define HSMP_INDEX_REG		0xc4 -#define HSMP_DATA_REG		0xc8 -  static struct hsmp_plat_device *hsmp_pdev;  static int amd_hsmp_pci_rdwr(struct hsmp_socket *sock, u32 offset,  			     u32 *value, bool write)  { -	int ret; - -	if (!sock->root) -		return -ENODEV; - -	ret = pci_write_config_dword(sock->root, HSMP_INDEX_REG, -				     sock->mbinfo.base_addr + offset); -	if (ret) -		return ret; - -	ret = (write ? pci_write_config_dword(sock->root, HSMP_DATA_REG, *value) -		     : pci_read_config_dword(sock->root, HSMP_DATA_REG, value)); - -	return ret; +	return amd_smn_hsmp_rdwr(sock->sock_ind, sock->mbinfo.base_addr + offset, value, write);  }  static ssize_t hsmp_metric_tbl_plat_read(struct file *filp, struct kobject *kobj, @@ -95,7 +81,12 @@ static umode_t hsmp_is_sock_attr_visible(struct kobject *kobj,   * Static array of 8 + 1(for NULL) elements is created below   * to create sysfs groups for sockets.   * is_bin_visible function is used to show / hide the necessary groups. + * + * Validate the maximum number against MAX_AMD_NUM_NODES. If this changes, + * then the attributes and groups below must be adjusted.   */ +static_assert(MAX_AMD_NUM_NODES == 8); +  #define HSMP_BIN_ATTR(index, _list)					\  static const struct bin_attribute attr##index = {			\  	.attr = { .name = HSMP_METRICS_TABLE_NAME, .mode = 0444},	\ @@ -159,10 +150,7 @@ static int init_platform_device(struct device *dev)  	int ret, i;  	for (i = 0; i < hsmp_pdev->num_sockets; i++) { -		if (!node_to_amd_nb(i)) -			return -ENODEV;  		sock = &hsmp_pdev->sock[i]; -		sock->root			= node_to_amd_nb(i)->root;  		sock->sock_ind			= i;  		sock->dev			= dev;  		sock->mbinfo.base_addr		= SMN_HSMP_BASE; @@ -305,11 +293,11 @@ static int __init hsmp_plt_init(void)  		return -ENOMEM;  	/* -	 * amd_nb_num() returns number of SMN/DF interfaces present in the system +	 * amd_num_nodes() returns number of SMN/DF interfaces present in the system  	 * if we have N SMN/DF interfaces that ideally means N sockets  	 */ -	hsmp_pdev->num_sockets = amd_nb_num(); -	if (hsmp_pdev->num_sockets == 0 || hsmp_pdev->num_sockets > MAX_AMD_SOCKETS) +	hsmp_pdev->num_sockets = amd_num_nodes(); +	if (hsmp_pdev->num_sockets == 0 || hsmp_pdev->num_sockets > MAX_AMD_NUM_NODES)  		return ret;  	ret = platform_driver_register(&amd_hsmp_driver); | 
