xref: /linux/Documentation/arch/x86/amd_hsmp.rst (revision 4eca0ef49af9b2b0c52ef2b58e045ab34629796b)
1.. SPDX-License-Identifier: GPL-2.0
2
3============================================
4AMD HSMP interface
5============================================
6
7Newer Fam19h EPYC server line of processors from AMD support system
8management functionality via HSMP (Host System Management Port).
9
10The Host System Management Port (HSMP) is an interface to provide
11OS-level software with access to system management functions via a
12set of mailbox registers.
13
14More details on the interface can be found in chapter
15"7 Host System Management Port (HSMP)" of the family/model PPR
16Eg: https://www.amd.com/system/files/TechDocs/55898_B1_pub_0.50.zip
17
18HSMP interface is supported on EPYC server CPU models only.
19
20
21HSMP device
22============================================
23
24amd_hsmp driver under the drivers/platforms/x86/ creates miscdevice
25/dev/hsmp to let user space programs run hsmp mailbox commands.
26
27$ ls -al /dev/hsmp
28crw-r--r-- 1 root root 10, 123 Jan 21 21:41 /dev/hsmp
29
30Characteristics of the dev node:
31 * Write mode is used for running set/configure commands
32 * Read mode is used for running get/status monitor commands
33
34Access restrictions:
35 * Only root user is allowed to open the file in write mode.
36 * The file can be opened in read mode by all the users.
37
38In-kernel integration:
39 * Other subsystems in the kernel can use the exported transport
40   function hsmp_send_message().
41 * Locking across callers is taken care by the driver.
42
43
44HSMP sysfs interface
45====================
46
471. Metrics table binary sysfs
48
49AMD MI300A MCM provides GET_METRICS_TABLE message to retrieve
50most of the system management information from SMU in one go.
51
52The metrics table is made available as hexadecimal sysfs binary file
53under per socket sysfs directory created at
54/sys/devices/platform/amd_hsmp/socket%d/metrics_bin
55
56Note: lseek() is not supported as entire metrics table is read.
57
58Metrics table definitions will be documented as part of Public PPR.
59The same is defined in the amd_hsmp.h header.
60
61
62An example
63==========
64
65To access hsmp device from a C program.
66First, you need to include the headers::
67
68  #include <linux/amd_hsmp.h>
69
70Which defines the supported messages/message IDs.
71
72Next thing, open the device file, as follows::
73
74  int file;
75
76  file = open("/dev/hsmp", O_RDWR);
77  if (file < 0) {
78    /* ERROR HANDLING; you can check errno to see what went wrong */
79    exit(1);
80  }
81
82The following IOCTL is defined:
83
84``ioctl(file, HSMP_IOCTL_CMD, struct hsmp_message *msg)``
85  The argument is a pointer to a::
86
87    struct hsmp_message {
88    	__u32	msg_id;				/* Message ID */
89    	__u16	num_args;			/* Number of input argument words in message */
90    	__u16	response_sz;			/* Number of expected output/response words */
91    	__u32	args[HSMP_MAX_MSG_LEN];		/* argument/response buffer */
92    	__u16	sock_ind;			/* socket number */
93    };
94
95The ioctl would return a non-zero on failure; you can read errno to see
96what happened. The transaction returns 0 on success.
97
98More details on the interface and message definitions can be found in chapter
99"7 Host System Management Port (HSMP)" of the respective family/model PPR
100eg: https://www.amd.com/system/files/TechDocs/55898_B1_pub_0.50.zip
101
102User space C-APIs are made available by linking against the esmi library,
103which is provided by the E-SMS project https://developer.amd.com/e-sms/.
104See: https://github.com/amd/esmi_ib_library
105