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
{
39
uint8_t
lun
;
40
uint8_t
cmd
;
41
uint8_t
completion_code
;
42
}
__packed
;
43
44
/* Get Device ID */
45
struct
ipmi_devid_rsp
{
46
struct
ipmi_rsp
resp
;
47
uint8_t
device_id
;
48
uint8_t
device_revision
;
49
uint8_t
fw_rev1
;
50
uint8_t
fw_rev2
;
51
uint8_t
ipmi_version
;
52
uint8_t
additional_device_support
;
53
uint8_t
manufacturer_id
[3];
54
uint8_t
product_id
[2];
55
}
__packed
;
56
57
/* Get Self Test Results */
58
struct
ipmi_selftest_rsp
{
59
struct
ipmi_rsp
resp
;
60
uint8_t
result
;
61
uint8_t
param
;
62
}
__packed
;
63
64
#endif
cb_err
cb_err
coreboot error codes
Definition:
cb_err.h:15
port
port
Definition:
i915.h:29
ipmi_kcs_premem_init
enum cb_err ipmi_kcs_premem_init(const u16 port, const u16 device)
Definition:
ipmi_kcs_ops_premem.c:34
ipmi_bmc_version
void ipmi_bmc_version(uint8_t *ipmi_bmc_major_revision, uint8_t *ipmi_bmc_minor_revision)
Definition:
ipmi_kcs_ops.c:334
__packed
struct ipmi_rsp __packed
ipmi_kcs_message
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
u16
uint16_t u16
Definition:
stdint.h:48
uint8_t
unsigned char uint8_t
Definition:
stdint.h:8
device
Definition:
device.h:107
ipmi_devid_rsp
Definition:
ipmi_kcs.h:45
ipmi_devid_rsp::fw_rev2
uint8_t fw_rev2
Definition:
ipmi_kcs.h:50
ipmi_devid_rsp::device_revision
uint8_t device_revision
Definition:
ipmi_kcs.h:48
ipmi_devid_rsp::fw_rev1
uint8_t fw_rev1
Definition:
ipmi_kcs.h:49
ipmi_devid_rsp::device_id
uint8_t device_id
Definition:
ipmi_kcs.h:47
ipmi_devid_rsp::resp
struct ipmi_rsp resp
Definition:
ipmi_kcs.h:46
ipmi_devid_rsp::additional_device_support
uint8_t additional_device_support
Definition:
ipmi_kcs.h:52
ipmi_devid_rsp::ipmi_version
uint8_t ipmi_version
Definition:
ipmi_kcs.h:51
ipmi_devid_rsp::product_id
uint8_t product_id[2]
Definition:
ipmi_kcs.h:54
ipmi_devid_rsp::manufacturer_id
uint8_t manufacturer_id[3]
Definition:
ipmi_kcs.h:53
ipmi_rsp
Definition:
ipmi_kcs.h:38
ipmi_rsp::lun
uint8_t lun
Definition:
ipmi_kcs.h:39
ipmi_rsp::completion_code
uint8_t completion_code
Definition:
ipmi_kcs.h:41
ipmi_rsp::cmd
uint8_t cmd
Definition:
ipmi_kcs.h:40
ipmi_selftest_rsp
Definition:
ipmi_kcs.h:58
ipmi_selftest_rsp::resp
struct ipmi_rsp resp
Definition:
ipmi_kcs.h:59
ipmi_selftest_rsp::param
uint8_t param
Definition:
ipmi_kcs.h:61
ipmi_selftest_rsp::result
uint8_t result
Definition:
ipmi_kcs.h:60
src
drivers
ipmi
ipmi_kcs.h
Generated by
1.9.1