X-Git-Url: https://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=discover%2Fipmi.h;h=eb2a1831638ed9c8350db4b4b11e1789df3661f4;hp=0ed6068f1a5395e447c58d2b1b5b0212b162822c;hb=cecbe53013e9ed85fd5b2429c230759d59025644;hpb=9dec4ac0431895f027cfa72e8e0656d3d69e3e63 diff --git a/discover/ipmi.h b/discover/ipmi.h index 0ed6068..eb2a183 100644 --- a/discover/ipmi.h +++ b/discover/ipmi.h @@ -4,15 +4,34 @@ #include #include -enum ipmi_bootdev { - IPMI_BOOTDEV_NONE = 0x0, - IPMI_BOOTDEV_NETWORK = 0x1, - IPMI_BOOTDEV_DISK = 0x2, - IPMI_BOOTDEV_SAFE = 0x3, - IPMI_BOOTDEV_CDROM = 0x5, - IPMI_BOOTDEV_SETUP = 0x6, +#include + +enum ipmi_netfn { + IPMI_NETFN_CHASSIS = 0x0, + IPMI_NETFN_SE = 0x04, + IPMI_NETFN_TRANSPORT = 0x0c, +}; + +enum ipmi_cmd { + IPMI_CMD_CHASSIS_SET_SYSTEM_BOOT_OPTIONS = 0x08, + IPMI_CMD_CHASSIS_GET_SYSTEM_BOOT_OPTIONS = 0x09, + IPMI_CMD_SENSOR_SET = 0x30, + IPMI_CMD_TRANSPORT_GET_LAN_PARAMS = 0x02, }; +enum ipmi_sensor_ids { + IPMI_SENSOR_ID_OS_BOOT = 0x1F, +}; + +struct ipmi; + bool ipmi_present(void); +bool ipmi_bootdev_is_valid(int x); +struct ipmi *ipmi_open(void *ctx); + +int ipmi_transaction(struct ipmi *ipmi, uint8_t netfn, uint8_t cmd, + uint8_t *req_buf, uint16_t req_len, + uint8_t *resp_buf, uint16_t *resp_len, + int timeout_ms); #endif /* _IPMI_H */