]> bbs.cooldavid.org Git - net-next-2.6.git/blame - include/linux/ipmi_msgdefs.h
ipv6: AF_INET6 link address family
[net-next-2.6.git] / include / linux / ipmi_msgdefs.h
CommitLineData
1da177e4
LT
1/*
2 * ipmi_smi.h
3 *
4 * MontaVista IPMI system management interface
5 *
6 * Author: MontaVista Software, Inc.
7 * Corey Minyard <minyard@mvista.com>
8 * source@mvista.com
9 *
10 * Copyright 2002 MontaVista Software Inc.
11 *
12 * This program is free software; you can redistribute it and/or modify it
13 * under the terms of the GNU General Public License as published by the
14 * Free Software Foundation; either version 2 of the License, or (at your
15 * option) any later version.
16 *
17 *
18 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
19 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
20 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
23 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
24 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
25 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
26 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
27 * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 *
29 * You should have received a copy of the GNU General Public License along
30 * with this program; if not, write to the Free Software Foundation, Inc.,
31 * 675 Mass Ave, Cambridge, MA 02139, USA.
32 */
33
34#ifndef __LINUX_IPMI_MSGDEFS_H
35#define __LINUX_IPMI_MSGDEFS_H
36
37/* Various definitions for IPMI messages used by almost everything in
38 the IPMI stack. */
39
40/* NetFNs and commands used inside the IPMI stack. */
41
42#define IPMI_NETFN_SENSOR_EVENT_REQUEST 0x04
43#define IPMI_NETFN_SENSOR_EVENT_RESPONSE 0x05
44#define IPMI_GET_EVENT_RECEIVER_CMD 0x01
45
46#define IPMI_NETFN_APP_REQUEST 0x06
47#define IPMI_NETFN_APP_RESPONSE 0x07
48#define IPMI_GET_DEVICE_ID_CMD 0x01
b9675136
CM
49#define IPMI_COLD_RESET_CMD 0x02
50#define IPMI_WARM_RESET_CMD 0x03
1da177e4 51#define IPMI_CLEAR_MSG_FLAGS_CMD 0x30
50c812b2 52#define IPMI_GET_DEVICE_GUID_CMD 0x08
1da177e4
LT
53#define IPMI_GET_MSG_FLAGS_CMD 0x31
54#define IPMI_SEND_MSG_CMD 0x34
55#define IPMI_GET_MSG_CMD 0x33
56#define IPMI_SET_BMC_GLOBAL_ENABLES_CMD 0x2e
57#define IPMI_GET_BMC_GLOBAL_ENABLES_CMD 0x2f
58#define IPMI_READ_EVENT_MSG_BUFFER_CMD 0x35
59#define IPMI_GET_CHANNEL_INFO_CMD 0x42
60
40112ae7
CM
61/* Bit for BMC global enables. */
62#define IPMI_BMC_RCV_MSG_INTR 0x01
63#define IPMI_BMC_EVT_MSG_INTR 0x02
64#define IPMI_BMC_EVT_MSG_BUFF 0x04
65#define IPMI_BMC_SYS_LOG 0x08
66
1da177e4
LT
67#define IPMI_NETFN_STORAGE_REQUEST 0x0a
68#define IPMI_NETFN_STORAGE_RESPONSE 0x0b
69#define IPMI_ADD_SEL_ENTRY_CMD 0x44
70
b9675136
CM
71#define IPMI_NETFN_FIRMWARE_REQUEST 0x08
72#define IPMI_NETFN_FIRMWARE_RESPONSE 0x09
73
1da177e4
LT
74/* The default slave address */
75#define IPMI_BMC_SLAVE_ADDR 0x20
76
77/* The BT interface on high-end HP systems supports up to 255 bytes in
78 * one transfer. Its "virtual" BMC supports some commands that are longer
79 * than 128 bytes. Use the full 256, plus NetFn/LUN, Cmd, cCode, plus
4d7cbac7
CM
80 * some overhead; it's not worth the effort to dynamically size this based
81 * on the results of the "Get BT Capabilities" command. */
1da177e4
LT
82#define IPMI_MAX_MSG_LENGTH 272 /* multiple of 16 */
83
84#define IPMI_CC_NO_ERROR 0x00
85#define IPMI_NODE_BUSY_ERR 0xc0
86#define IPMI_INVALID_COMMAND_ERR 0xc1
4d7cbac7 87#define IPMI_TIMEOUT_ERR 0xc3
1da177e4 88#define IPMI_ERR_MSG_TRUNCATED 0xc6
4d7cbac7
CM
89#define IPMI_REQ_LEN_INVALID_ERR 0xc7
90#define IPMI_REQ_LEN_EXCEEDED_ERR 0xc8
91#define IPMI_NOT_IN_MY_STATE_ERR 0xd5 /* IPMI 2.0 */
1da177e4 92#define IPMI_LOST_ARBITRATION_ERR 0x81
46d52b09
CM
93#define IPMI_BUS_ERR 0x82
94#define IPMI_NAK_ON_WRITE_ERR 0x83
1da177e4
LT
95#define IPMI_ERR_UNSPECIFIED 0xff
96
97#define IPMI_CHANNEL_PROTOCOL_IPMB 1
98#define IPMI_CHANNEL_PROTOCOL_ICMB 2
99#define IPMI_CHANNEL_PROTOCOL_SMBUS 4
100#define IPMI_CHANNEL_PROTOCOL_KCS 5
101#define IPMI_CHANNEL_PROTOCOL_SMIC 6
102#define IPMI_CHANNEL_PROTOCOL_BT10 7
103#define IPMI_CHANNEL_PROTOCOL_BT15 8
104#define IPMI_CHANNEL_PROTOCOL_TMODE 9
105
106#define IPMI_CHANNEL_MEDIUM_IPMB 1
107#define IPMI_CHANNEL_MEDIUM_ICMB10 2
108#define IPMI_CHANNEL_MEDIUM_ICMB09 3
109#define IPMI_CHANNEL_MEDIUM_8023LAN 4
110#define IPMI_CHANNEL_MEDIUM_ASYNC 5
111#define IPMI_CHANNEL_MEDIUM_OTHER_LAN 6
112#define IPMI_CHANNEL_MEDIUM_PCI_SMBUS 7
113#define IPMI_CHANNEL_MEDIUM_SMBUS1 8
114#define IPMI_CHANNEL_MEDIUM_SMBUS2 9
115#define IPMI_CHANNEL_MEDIUM_USB1 10
116#define IPMI_CHANNEL_MEDIUM_USB2 11
117#define IPMI_CHANNEL_MEDIUM_SYSINTF 12
4dec302f 118#define IPMI_CHANNEL_MEDIUM_OEM_MIN 0x60
119#define IPMI_CHANNEL_MEDIUM_OEM_MAX 0x7f
1da177e4
LT
120
121#endif /* __LINUX_IPMI_MSGDEFS_H */