diff options
Diffstat (limited to 'include/ipmitool/ipmi_channel.h')
| -rw-r--r-- | include/ipmitool/ipmi_channel.h | 258 | 
1 files changed, 258 insertions, 0 deletions
| diff --git a/include/ipmitool/ipmi_channel.h b/include/ipmitool/ipmi_channel.h new file mode 100644 index 0000000..7cbb9ad --- /dev/null +++ b/include/ipmitool/ipmi_channel.h @@ -0,0 +1,258 @@ +/* + * Copyright (c) 2003 Sun Microsystems, Inc.  All Rights Reserved. + *  + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + *  + * Redistribution of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + *  + * Redistribution in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + *  + * Neither the name of Sun Microsystems, Inc. or the names of + * contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + *  + * This software is provided "AS IS," without a warranty of any kind. + * ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, + * INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A + * PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. + * SUN MICROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL NOT BE LIABLE + * FOR ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING + * OR DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES.  IN NO EVENT WILL + * SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, + * OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR + * PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF + * LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, + * EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + */ + +#ifndef IPMI_CHANNEL_H +#define IPMI_CHANNEL_H + +#if HAVE_CONFIG_H +# include <config.h> +#endif +#include <ipmitool/ipmi.h> + + +#define IPMI_GET_CHANNEL_AUTH_CAP      0x38 +#define IPMI_GET_CHANNEL_ACCESS        0x41 +#define IPMI_GET_CHANNEL_INFO          0x42 +#define IPMI_SET_USER_ACCESS           0x43 +#define IPMI_GET_USER_ACCESS           0x44 +#define IPMI_SET_USER_NAME             0x45 +#define IPMI_GET_USER_NAME             0x46 +#define IPMI_SET_USER_PASSWORD         0x47 +#define IPMI_GET_CHANNEL_CIPHER_SUITES 0x54 + + +/* + * The Get Authentication Capabilities response structure + * From table 22-15 of the IPMI v2.0 spec + */ +#ifdef HAVE_PRAGMA_PACK +#pragma pack(1) +#endif +struct get_channel_auth_cap_rsp { +	uint8_t channel_number; +#if WORDS_BIGENDIAN +	uint8_t v20_data_available : 1; /* IPMI v2.0 data is available */ +	uint8_t __reserved1        : 1;  +	uint8_t enabled_auth_types : 6; /* IPMI v1.5 enabled auth types */ +#else +	uint8_t enabled_auth_types : 6; /* IPMI v1.5 enabled auth types */ +	uint8_t __reserved1        : 1; +	uint8_t v20_data_available : 1; /* IPMI v2.0 data is available */ +#endif +#if WORDS_BIGENDIAN +	uint8_t __reserved2        : 2; +	uint8_t kg_status          : 1; /* two-key login status */ +	uint8_t per_message_auth   : 1; /* per-message authentication status */ +	uint8_t user_level_auth    : 1; /* user-level authentication status */ +	uint8_t non_null_usernames : 1; /* one or more non-null users exist */ +	uint8_t null_usernames     : 1; /* one or more null usernames non-null pwds */ +	uint8_t anon_login_enabled : 1; /* a null-named, null-pwd user exists */ +#else +	uint8_t anon_login_enabled : 1; /* a null-named, null-pwd user exists */ +	uint8_t null_usernames     : 1; /* one or more null usernames non-null pwds */ +	uint8_t non_null_usernames : 1; /* one or more non-null users exist */ +	uint8_t user_level_auth    : 1; /* user-level authentication status */ +	uint8_t per_message_auth   : 1; /* per-message authentication status */ +	uint8_t kg_status          : 1; /* two-key login status */ +	uint8_t __reserved2        : 2; +#endif +#if WORDS_BIGENDIAN +	uint8_t __reserved3        : 6; +	uint8_t ipmiv20_support    : 1; /* channel supports IPMI v2.0 connections */ +	uint8_t ipmiv15_support    : 1; /* channel supports IPMI v1.5 connections */ +#else +	uint8_t ipmiv15_support    : 1; /* channel supports IPMI v1.5 connections */ +	uint8_t ipmiv20_support    : 1; /* channel supports IPMI v2.0 connections */ +	uint8_t __reserved3        : 6; +#endif +	uint8_t oem_id[3];    /* IANA enterprise number for auth type */ +	uint8_t oem_aux_data; /* Additional OEM specific data for oem auths */ +} ATTRIBUTE_PACKING; +#ifdef HAVE_PRAGMA_PACK +#pragma pack(0) +#endif + + + +/* + * The Get Channel Info response structure + * From table 22-29 of the IPMI v2.0 spec + */ +#ifdef HAVE_PRAGMA_PACK +#pragma pack(1) +#endif +struct get_channel_info_rsp { +#if WORDS_BIGENDIAN +	uint8_t __reserved1       : 4;  +	uint8_t channel_number    : 4; /* channel number */ +#else +	uint8_t channel_number    : 4; /* channel number */ +	uint8_t __reserved1       : 4;  +#endif +#if WORDS_BIGENDIAN +	uint8_t __reserved2       : 1; +	uint8_t channel_medium    : 7; /* Channel medium type per table 6-3 */ +#else +	uint8_t channel_medium    : 7; /* Channel medium type per table 6-3 */ +	uint8_t __reserved2       : 1; +#endif +#if WORDS_BIGENDIAN +	uint8_t __reserved3       : 3; +	uint8_t channel_protocol  : 5; /* Channel protocol per table 6-2 */ +#else +	uint8_t channel_protocol  : 5; /* Channel protocol per table 6-2 */ +	uint8_t __reserved3       : 3; +#endif +#if WORDS_BIGENDIAN +	uint8_t session_support   : 2; /* Description of session support */ +	uint8_t active_sessions   : 6; /* Count of active sessions */ +#else +	uint8_t active_sessions   : 6; /* Count of active sessions */ +	uint8_t session_support   : 2; /* Description of session support */ +#endif +	uint8_t vendor_id[3]; /* For OEM that specified the protocol */ +	uint8_t aux_info[2];  /* Not used*/ +} ATTRIBUTE_PACKING; +#ifdef HAVE_PRAGMA_PACK +#pragma pack(0) +#endif + + + +/* + * The Get Channel Access response structure + * From table 22-28 of the IPMI v2.0 spec + */ +#ifdef HAVE_PRAGMA_PACK +#pragma pack(1) +#endif +struct get_channel_access_rsp { +#if WORDS_BIGENDIAN +	uint8_t __reserved1        : 2; +	uint8_t alerting           : 1; +	uint8_t per_message_auth   : 1; +	uint8_t user_level_auth    : 1; +	uint8_t access_mode        : 3; +#else +	uint8_t access_mode        : 3; +	uint8_t user_level_auth    : 1; +	uint8_t per_message_auth   : 1; +	uint8_t alerting           : 1; +	uint8_t __reserved1        : 2; +#endif +#if WORDS_BIGENDIAN +	uint8_t __reserved2        : 4; +	uint8_t channel_priv_limit : 4; /* Channel privilege level limit */ +#else +	uint8_t channel_priv_limit : 4; /* Channel privilege level limit */ +	uint8_t __reserved2        : 4; +#endif +} ATTRIBUTE_PACKING; +#ifdef HAVE_PRAGMA_PACK +#pragma pack(0) +#endif + +#ifdef HAVE_PRAGMA_PACK +#pragma pack(1) +#endif +struct get_user_access_rsp { +#if WORDS_BIGENDIAN +	uint8_t __reserved1        : 2; +	uint8_t max_user_ids       : 6; +	uint8_t __reserved2        : 2; +	uint8_t enabled_user_ids   : 6; +	uint8_t __reserved3        : 2; +	uint8_t fixed_user_ids     : 6; +	uint8_t __reserved4        : 1; +	uint8_t callin_callback    : 1; +	uint8_t link_auth          : 1; +	uint8_t ipmi_messaging     : 1; +	uint8_t privilege_limit    : 4; +#else +	uint8_t max_user_ids       : 6; +	uint8_t __reserved1        : 2; +	uint8_t enabled_user_ids   : 6; +	uint8_t __reserved2        : 2; +	uint8_t fixed_user_ids     : 6; +	uint8_t __reserved3        : 2; +	uint8_t privilege_limit    : 4; +	uint8_t ipmi_messaging     : 1; +	uint8_t link_auth          : 1; +	uint8_t callin_callback    : 1; +	uint8_t __reserved4        : 1; +#endif +} ATTRIBUTE_PACKING; +#ifdef HAVE_PRAGMA_PACK +#pragma pack(0) +#endif + +#ifdef HAVE_PRAGMA_PACK +#pragma pack(1) +#endif +struct set_user_access_data { +#if WORDS_BIGENDIAN +	uint8_t change_bits        : 1; +	uint8_t callin_callback    : 1; +	uint8_t link_auth          : 1; +	uint8_t ipmi_messaging     : 1; +	uint8_t channel            : 4; +	uint8_t __reserved1        : 2; +	uint8_t user_id            : 6; +	uint8_t __reserved2        : 4; +	uint8_t privilege_limit    : 4; +	uint8_t __reserved3        : 4; +	uint8_t session_limit      : 4; +#else +	uint8_t channel            : 4; +	uint8_t ipmi_messaging     : 1; +	uint8_t link_auth          : 1; +	uint8_t callin_callback    : 1; +	uint8_t change_bits        : 1; +	uint8_t user_id            : 6; +	uint8_t __reserved1        : 2; +	uint8_t privilege_limit    : 4; +	uint8_t __reserved2        : 4; +	uint8_t session_limit      : 4; +	uint8_t __reserved3        : 4; +#endif +} ATTRIBUTE_PACKING; +#ifdef HAVE_PRAGMA_PACK +#pragma pack(0) +#endif + +uint8_t ipmi_get_channel_medium(struct ipmi_intf * intf, uint8_t channel); +uint8_t ipmi_current_channel_medium(struct ipmi_intf * intf); +int ipmi_channel_main(struct ipmi_intf * intf, int argc, char ** argv); +int ipmi_get_channel_auth_cap(struct ipmi_intf * intf, uint8_t channel, uint8_t priv); +int ipmi_get_channel_info(struct ipmi_intf * intf, uint8_t channel); + +#endif /*IPMI_CHANNEL_H*/ | 
