X-Git-Url: https://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=discover%2Fipmi.h;fp=discover%2Fipmi.h;h=e60ff619215984c58da52293df3315ad9de773ce;hp=157cca898685f36e906ba1969f4a705457dbd4ab;hb=2e05b1dd0490ce7ecdd15f522e6c700bc6522062;hpb=d3e95283e69d3099fe9f36e56be1f645f565c843 diff --git a/discover/ipmi.h b/discover/ipmi.h index 157cca8..e60ff61 100644 --- a/discover/ipmi.h +++ b/discover/ipmi.h @@ -4,16 +4,33 @@ #include #include +enum ipmi_netfn { + IPMI_NETFN_CHASSIS = 0x0, +}; + +enum ipmi_cmd { + IPMI_CMD_CHASSIS_SET_SYSTEM_BOOT_OPTIONS = 0x08, + IPMI_CMD_CHASSIS_GET_SYSTEM_BOOT_OPTIONS = 0x09, +}; + enum ipmi_bootdev { - IPMI_BOOTDEV_NONE = 0x0, - IPMI_BOOTDEV_NETWORK = 0x1, + IPMI_BOOTDEV_NONE = 0x00, + IPMI_BOOTDEV_NETWORK = 0x01, IPMI_BOOTDEV_DISK = 0x2, IPMI_BOOTDEV_SAFE = 0x3, IPMI_BOOTDEV_CDROM = 0x5, IPMI_BOOTDEV_SETUP = 0x6, }; -bool ipmi_bootdev_is_valid(int x); +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 */