coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
ipmi_kcs.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 #ifndef __IPMI_KCS_H
4 #define __IPMI_KCS_H
5 
6 #define IPMI_NETFN_CHASSIS 0x00
7 #define IPMI_NETFN_BRIDGE 0x02
8 #define IPMI_NETFN_SENSOREVENT 0x04
9 #define IPMI_NETFN_APPLICATION 0x06
10 #define IPMI_BMC_GET_DEVICE_ID 0x01
11 #define IPMI_IPMI_VERSION_MINOR(x) ((x) >> 4)
12 #define IPMI_IPMI_VERSION_MAJOR(x) ((x) & 0xf)
13 #define IPMI_BMC_GET_SELFTEST_RESULTS 0x04
14 #define IPMI_APP_SELFTEST_RESERVED 0xFF
15 #define IPMI_APP_SELFTEST_NO_ERROR 0x55
16 #define IPMI_APP_SELFTEST_NOT_IMPLEMENTED 0x56
17 #define IPMI_APP_SELFTEST_ERROR 0x57
18 #define IPMI_APP_SELFTEST_FATAL_HW_ERROR 0x58
19 
20 #define IPMI_NETFN_FIRMWARE 0x08
21 #define IPMI_NETFN_STORAGE 0x0a
22 #define IPMI_READ_FRU_DATA 0x11
23 #define IPMI_ADD_SEL_ENTRY 0x44
24 #define IPMI_NETFN_TRANSPORT 0x0c
25 
26 #define IPMI_CMD_ACPI_POWERON 0x06
27 
28 extern int ipmi_kcs_message(int port, int netfn, int lun, int cmd,
29  const unsigned char *inmsg, int inlen,
30  unsigned char *outmsg, int outlen);
31 
32 /* Run basic IPMI init functions in romstage from the provided PnP device,
33  * returns CB_SUCCESS on success and CB_ERR if an error occurred. */
34 enum cb_err ipmi_kcs_premem_init(const u16 port, const u16 device);
35 
36 void ipmi_bmc_version(uint8_t *ipmi_bmc_major_revision, uint8_t *ipmi_bmc_minor_revision);
37 
38 struct ipmi_rsp {
43 
44 /* Get Device ID */
46  struct ipmi_rsp resp;
55 } __packed;
56 
57 /* Get Self Test Results */
59  struct ipmi_rsp resp;
62 } __packed;
63 
64 #endif
cb_err
coreboot error codes
Definition: cb_err.h:15
port
Definition: i915.h:29
enum cb_err ipmi_kcs_premem_init(const u16 port, const u16 device)
void ipmi_bmc_version(uint8_t *ipmi_bmc_major_revision, uint8_t *ipmi_bmc_minor_revision)
Definition: ipmi_kcs_ops.c:334
struct ipmi_rsp __packed
int ipmi_kcs_message(int port, int netfn, int lun, int cmd, const unsigned char *inmsg, int inlen, unsigned char *outmsg, int outlen)
Definition: ipmi_kcs.c:222
uint16_t u16
Definition: stdint.h:48
unsigned char uint8_t
Definition: stdint.h:8
Definition: device.h:107
uint8_t fw_rev2
Definition: ipmi_kcs.h:50
uint8_t device_revision
Definition: ipmi_kcs.h:48
uint8_t fw_rev1
Definition: ipmi_kcs.h:49
uint8_t device_id
Definition: ipmi_kcs.h:47
struct ipmi_rsp resp
Definition: ipmi_kcs.h:46
uint8_t additional_device_support
Definition: ipmi_kcs.h:52
uint8_t ipmi_version
Definition: ipmi_kcs.h:51
uint8_t product_id[2]
Definition: ipmi_kcs.h:54
uint8_t manufacturer_id[3]
Definition: ipmi_kcs.h:53
uint8_t lun
Definition: ipmi_kcs.h:39
uint8_t completion_code
Definition: ipmi_kcs.h:41
uint8_t cmd
Definition: ipmi_kcs.h:40
struct ipmi_rsp resp
Definition: ipmi_kcs.h:59
uint8_t param
Definition: ipmi_kcs.h:61
uint8_t result
Definition: ipmi_kcs.h:60