diff options
Diffstat (limited to 'util')
-rw-r--r-- | util/ilan.c~ | 5242 |
1 files changed, 0 insertions, 5242 deletions
diff --git a/util/ilan.c~ b/util/ilan.c~ deleted file mode 100644 index 7d91d55..0000000 --- a/util/ilan.c~ +++ /dev/null @@ -1,5242 +0,0 @@ -/*--------------------------------------------------------------------------- - * Filename: ilan.c (was pefconfig.c) - * - * Author: arcress at users.sourceforge.net - * Copyright (c) 2009 Kontron America, Inc. - * - * Abstract: - * This tool sets up the custom Platform Event Filter for the panicSEL - * record (0x20, OS Critical Stop) to send a PEF SNMP alert for Linux - * panics. It also configures the BMC LAN parameters, which are needed - * to support PEF alerts. - * - * ----------- Change History ----------------------------------------------- - * 10/16/01 Andy Cress - created - * 10/24/01 Andy Cress - mods for SetPefEntry(0c) - * 11/02/01 Andy Cress - added option to disable a given PefEntry - * 11/15/01 Andy Cress - added function to GetLanEntry - * 11/19/01 Andy Cress - added function to SetLanEntry - * 01/18/02 Andy Cress - added GetCfgData function - * 01/31/02 Andy Cress - converted to use ipmi_cmd_ia - * 02/06/02 Andy Cress - removed GetCfgData - * 02/06/02 Andy Cress - added ipmi_cmd_va - * 02/08/02 Andy Cress - added GetChanAcc - * 02/14/02 Andy Cress - added Get_IPMac_Addr() - * 02/21/02 Andy Cress - added Alert IP/MAC logic to Get_IPMac_Addr() - * 03/21/02 Andy Cress - do SetChanAcc(0x80) with every SetChanAcc(0x40) - * 04/15/02 Andy Cress v1.2 - fix bug with user-specified Alert IP: - * (ccode=c7 on SetLanEntry(16 & 18), also - * added Get_Mac() for user-specified Alert IP. - * 04/16/02 Andy Cress v1.3 added SetUser() to set password if specified, - * also changed unset mac[0] to be 0xFF, not 0. - * 05/09/02 Andy Cress v1.4 fixed bug 504 gwymac[0]=00 (mymac overwrote it), - * also fixed alert scan to pick last trapsink - * 05/31/02 Andy Cress v1.5 for gwy mac, changed arping -c 1 to -c 2, - * also get com2sec community from snmpd.conf, - * set dest type for no ack, no retry, - * special handling to set preset PEF entries - * 07/02/02 Andy Cress v1.6 added more Usage text - * 07/08/02 Andy Cress v1.7 SetUserAccess length change - * 08/02/02 Andy Cress v1.8 moved common ipmi_cmd() code to ipmicmd.c - * 08/27/02 Andy Cress v1.9 fixed 0xc7 on SETUSER_ACCESS with pefconfig -P "", - * show message if alert dest not found - * 09/10/02 Andy Cress v1.10 make channel nums into defines (16) - * 09/17/02 Andy Cress v1.11 decode Dest Addr IP (19) in decimal, - * fix enable user padding in SetUser, - * display new community string when setting - * 12/09/02 Andy Cress v1.12 fix error w -C & snmpd.conf conflict - * 01/29/03 Andy Cress v1.13 added MV OpenIPMI support - * 02/05/03 Andy Cress v1.14 show pef entry descriptions, - * added EnablePef routine - * show correct Alert dest mac if -A only - * 04/04/03 Andy Cress v1.15 add eth interface option (-i) - * 05/13/03 Andy Cress v1.16 fix EnablePef if startup delay not supported - * 06/19/03 Andy Cress v1.17 added errno.h (email from Travers Carter) - * 07/25/03 Andy Cress v1.18 add SerialOverLan configuration - * mod to SetUser, added GetBmcEthDevice, - * use 'arping -I' if eth1. - * 08/18/03 Andy Cress v1.19 Don't abort if IPMI 1.0, just skip PEF, - * SetLanEntry(10 & 11) for bmc grat arp, - * SetLanEntry(2) to 0x17 for auth priv - * 09/10/03 Andy Cress v1.20 Don't enable a PEF entry if it is empty, - * added -L lan_ch parameter, - * scan for lan_ch in GetBmcEthDevice - * 09/22/03 Andy Cress v1.21 Add DHCP option (-D), from Jerry Yu. - * 12/05/03 Andy Cress v1.22 Fix auth type enables for ServerConfig - * 12/16/03 Andy Cress v1.23 Allow flexible auth types via authmask - * 03/19/04 Andy Cress v1.24 Change default pefnum for mBMC to 10 - * 04/15/04 Andy Cress v1.25 Init each response for channel info, avoids - * 0xcc error with /dev/ipmi0 due to wrong lan_ch - * 05/05/04 Andy Cress v1.26 call ipmi_close before exit. Note that - * Get_IPMac_Addr and GetBmcEthDevice - * routines need more work for WIN32. - * 05/24/04 Andy Cress v1.27 added CHAN_ACC params for ia64 - * 06/28/04 Andy Cress v1.28 added parsing to get community from trapsink - * 07/23/04 Andy Cress v1.29 use lan_ch variable to set Alert Policy Table - * 08/23/04 Andy Cress v1.30 fixed decoding of PE Table entries, - * added -e option (same as no params) - * 08/25/04 Andy Cress v1.31 added some WIN32 logic to Get_Mac, Get_IPMac_Addr - * 11/01/04 Andy Cress v1.32 add -N / -R for remote nodes - * added -U for remote username - * 11/18/04 Andy Cress v1.33 added -u to configure a lan username (user 2) - * 11/23/04 Andy Cress v1.34 added pef_defaults if first 11 empty - * 01/11/05 Andy Cress v1.35 allow scan for BMC LAN if fIPMI10 - * 01/20/05 Andy Cress v1.36 fix to allow IPMI 2.0 - * 02/16/05 Andy Cress v1.37 added IPMI 2.0 VLAN parameters, - * if DHCP, can set DHCP Server via -I param - * 03/02/05 Andy Cress v1.38 show Serial-Over-Lan params, - * fix -L with lan_ch_parm. mods to GetBmcEthDevice - * 03/18/05 Andy Cress v1.39 fix GetBmcEthDevice for invalid MAC compares - * 06/03/05 Andy Cress v1.40 For my MAC in BMC, check user-specified, then - * check existing BMC MAC, then check OS MAC. - * 06/10/05 Andy Cress v1.41 Display multiple Alert Destinations, - * handle fSOL20 commands - * 07/07/05 Andy Cress v1.42 Fix GetBmcEthDevice for TIGI2U to skip GCM ch 3 - * 07/08/05 Andy Cress v1.43 Mods to handle Intel NSI2U miniBMC, - * 08/01/05 Andy Cress v1.44 added -t option to test if BMC LAN configured - * 08/10/05 Andy Cress v1.45 truncate extra string chars, - * decode more PEF params - * 09/07/05 Andy Cress v1.46 enable mBMC PEF entries 26 thru 30 - * 04/06/06 Andy Cress v1.47 show "gcm" as ifname if -L 3. - * 06/20/06 Andy Cress v1.48 fix strcmp(gcm), show all 4 alert policies, - * add PefDesc() for misc vendor pefdesc, add -a. - * 08/08/06 Andy Cress v1.49 add Alcolu to fsharedMAC - * 09/29/06 Andy Cress v1.52 use bmcmymac if valid, use bmcmyip if ok, - * added -q for user number, - * enhanced Get_IPMac_Addr for Windows - * 10/12/06 Andy Cress v1.53 FindEthNum updates, always use gwy iface for mac - * 11/02/06 Andy Cress v1.55 add user names, EnablePef mods for non-Intel. - * 05/02/07 Brian Johnson v1.65 add fpefenable flag to not do SetPefEntry - * if no Alert Destination. Previously did - * SetPefEntry but not EnablePef in this case. - * 05/04/07 Andy Cress v1.65 Use 0x02 for DHCP source instead of 0x03, - * fix 1714748 missing "X:" in getopt line - * 05/23/07 Jakub Gorgolewski - * v1.66 Use iphlpapi for Windows detection - * 10/31/07 Andy Cress v2.3 Fixed PEF entry for Power Redundancy Lost - * 11/15/07 Andy Cress v2.4 Move custom PEF to #14, add to usage, - * Allow broadcast MAC for -X - * 12/17/07 Andy Cress v2.5 Add fSetPEFOks & secondary Gateway - */ -/*M* - *--------------------------------------------------------------------------- -Copyright (c) 2009 Kontron America, 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: - - a.. Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - b.. Redistributions 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. - c.. Neither the name of Kontron nor the names of its contributors - may be used to endorse or promote products derived from this software - without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND -ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED -WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE -DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR -ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES -(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON -ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS -SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - *--------------------------------------------------------------------------- - *M*/ -#ifdef WIN32 -#include <winsock2.h> -#include <iphlpapi.h> -#include <windows.h> -#include <stdio.h> -#include <string.h> -#include <stdlib.h> -#include "getopt.h" -#elif defined(DOS) -#include <dos.h> -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include "getopt.h" -#else -/* Linux or similar */ -#include <stdio.h> -#include <stdlib.h> -#include <sys/types.h> -#include <sys/stat.h> -#include <fcntl.h> -#if defined(HPUX) -/* getopt is defined in stdio.h */ -#elif defined(MACOS) -/* getopt is defined in unistd.h */ -#include <unistd.h> -#else -#include <getopt.h> -#endif -#include <string.h> -#include <sys/socket.h> -#include <sys/ioctl.h> -#include <net/if.h> -#include <errno.h> -#endif -#ifdef LINUX -#include <unistd.h> -#endif -#ifdef SOLARIS -#include <sys/sockio.h> -#define SIOCGIFHWADDR SIOCGENADDR -#define ifr_netmask ifr_ifru.ifru_addr -// #define ifr_hwaddr.sa_data ifr_ifru.ifru_enaddr -#elif defined(BSD) -#include <sys/sockio.h> -#define SIOCGIFHWADDR SIOCGIFMAC -#define ifr_netmask ifr_ifru.ifru_addr -// #define ifr_hwaddr.sa_data ifr_ifru.ifru_addr -#elif defined(MACOS) -#include <sys/sockio.h> -#define ifr_netmask ifr_ifru.ifru_addr -#endif -#include "ipmicmd.h" -#include "oem_intel.h" -#include "oem_supermicro.h" - -#define SELprintf printf -#define RTF_UP 0x0001 /* route usable */ - -#define SOL_ENABLE_FLAG 0x01 -#define SOL_DISABLE_FLAG 0x00 -#define SOL_PRIVILEGE_LEVEL_USER 0x02 -#define SOL_PRIVILEGE_LEVEL_OPERATOR 0x03 -#define SOL_PRIVILEGE_LEVEL_ADMIN 0x04 -#define SOL_PREFERRED_BAUD_RATE 0x0a /*115.2k*/ -/* For IPMI 1.5, use Intel SOL commands & subfunctions */ -#define SOL_ENABLE_PARAM 0x01 -#define SOL_AUTHENTICATION_PARAM 0x02 -#define SOL_ACC_INTERVAL_PARAM 0x03 -#define SOL_RETRY_PARAM 0x04 -#define SOL_BAUD_RATE_PARAM 0x05 /*non-volatile*/ -#define SOL_VOL_BAUD_RATE_PARAM 0x06 /*volatile*/ -/* For IPMI 2.0, use IPMI SOL commands & subfunctions */ -#define SOL_ENABLE_PARAM2 0x08 -#define SOL_AUTHENTICATION_PARAM2 0x09 -#define SOL_BAUD_RATE_PARAM2 0x11 - -/* IPMI 2.0 SOL PAYLOAD commands */ -#define SET_PAYLOAD_ACCESS 0x4C -#define GET_PAYLOAD_ACCESS 0x4D -#define GET_PAYLOAD_SUPPORT 0x4E - -/* Channel Access values */ -#define CHAN_ACC_DISABLE 0x20 /* PEF off, disabled*/ -#define CHAN_ACC_PEFON 0x02 /* PEF on, always avail */ -#define CHAN_ACC_PEFOFF 0x22 /* PEF off, always avail*/ -/* special channel access values for ia64 */ -#define CHAN_ACC_PEFON64 0x0A /* PEF on, always avail, UserLevelAuth=off */ -#define CHAN_ACC_PEFOFF64 0x2A /* PEF off, always avail, UserLevelAuth=off */ -#define OS_LINUX 1 -#define OS_WINDOWS 2 -#define OS_SOLARIS 3 -#define OS_BSD 4 -#define OS_HPUX 5 - - /* TSRLT2 Channels: 0=IPMB, 1=Serial/EMP, 6=LAN2, 7=LAN1 */ - /* S5000 Channels: 0=IPMB, 1=LAN1, 2=LAN2, 3=RMM2, 4=Serial, 6=pci, 7=sys */ - /* For TIGPT1U/mBMC: 1=LAN channel, no serial */ -#define LAN_CH 1 -#define SER_CH 4 -#define MAXCHAN 12 /*was 16, reduced for gnu ipmi_lan*/ -#define NUM_DEVICES_TO_CHECK 32 /*for GetBmcEthDevice()*/ -#define MAC_LEN 6 /*length of MAC Address*/ -#define PSW_LEN 16 /* see also PSW_MAX =20 in ipmicmd.h*/ -/* Note: The optional IPMI 2.0 20-byte passwords are not supported here, - * due to back-compatibility issues. */ - - /* IP address source values */ -#define SRC_STATIC 0x01 -#define SRC_DHCP 0x02 /* BMC running DHCP */ -#define SRC_BIOS 0x03 /* BIOS, sometimes DHCP */ -#define SRC_OTHER 0x04 - -/* PEF event severities */ -#define PEF_SEV_UNSPEC 0x00 -#define PEF_SEV_MON 0x01 -#define PEF_SEV_INFO 0x02 -#define PEF_SEV_OK 0x04 -#define PEF_SEV_WARN 0x08 -#define PEF_SEV_CRIT 0x10 -#define PEF_SEV_NORECOV 0x20 -#define FLAG_INIT 99 /*initial value of char flag, beyond scope*/ -#define PARM_INIT 0xff - -typedef struct -{ /* See IPMI Table 15-2 */ - uchar rec_id; - uchar fconfig; - uchar action; - uchar policy; - uchar severity; - uchar genid1; - uchar genid2; - uchar sensor_type; - uchar sensor_no; - uchar event_trigger; - uchar data1; - uchar mask1; - uchar res[9]; -} PEF_RECORD; - -typedef struct -{ /* See IPMI Table 19-3 */ - uchar data[36]; -} LAN_RECORD; /*LanRecord*/ - -#ifdef METACOMMAND -extern int get_lan_stats(uchar chan); /*see bmchealth.c */ -extern char *get_sensor_type_desc(uchar stype); /*from ievents.c*/ -#endif - -#define MYIP 0x01 -#define GWYIP 0x02 -#define DESTIP 0x04 -#define MAXPEF 41 /* max pefnum offset = 40 (41 entries) */ -/* - * Global variables - */ -static char * progver = "3.03"; -static char * progname = "ilan"; -static char fdebug = 0; -static char fipmilan = 0; -static char fIPMI10 = 0; /* =1 if IPMI v1.0 or less */ -static char fIPMI20 = 0; /* =1 if IPMI v2.0 or greater */ -static char fSOL20 = 1; /* =1 if use Serial-Over-Lan 2.0 w IPMI 2.0 */ -static char fsharedMAC = 0; /* =1 if special shared-MAC BMC LAN port */ -static char fAdjustPefNum = 0; /* =1 adjust pefnum to first empty index */ -static char fUserPefNum = 0; /* =1 if user specified a valid pefnum value*/ -static char freadonly = 1; /* =1 to only read LAN & PEF parameters */ -static char fcanonical = 0; /* =1 to show only canonical output */ -static char flansecure = 0; /* =1 set lan security: no null, cipher0 off*/ -static char bdelim = BCOLON; /* delimiter ':' or '|' if canonical output*/ -static char ftestonly = 0; -static char fprivset = 0; -static char flanstats = 0; /* =1 to show the IPMI LAN statistics */ -static char foptmsg = 0; /* =1 to show the option warning msg */ -static char fshowchan = 0; /* =1 to show the IPMI channels */ -static char nopts = 0; /* number of pefconfig options specified*/ -static int nerrs = 0; /* number of errors during processing */ -static int ngood = 0; /* number of good results */ -static int lasterr = 0; /* value of the last error */ -static char fCustomPEF = 0; /* =1 if -j to input a custom PEF record */ -static char fSetPEFOks = 0; /* =1 if -k to set PEF OK rules */ -static char fdisable = 0; -static char fenable = 0; /* =1 to config BMC LAN and PEF */ -static char fpefenable = 0; /* =1 enable PEF if Alert Dest is specified*/ -static char fdisableSOL = 0; -static char fgetser = 0; -static char fsetifn = 0; /* =1 if user specified ifname[] with -i */ -static char fethfound = 0; /* =1 if FindEthNum successful */ -static char fset_ip = 0; /* !=0 if options used to specify an IP addr*/ -static char fpassword = 0; /* =1 user-specified a password, so set it. */ -static uchar fmBMC = 0; /* =1 mini-BMC, =0 Sahalee BMC */ -static uchar fiBMC = 0; /* =1 Intel iBMC */ -static uchar fRomley = 0; /* =1 Intel Romley BMC */ -static uchar fGrantley = 0; -static uchar fipv6 = 0; /* =1 if BMC supports IPv6 */ -static uchar bmcpefctl = 0; /* existing BMC PEF Control, !0 = enabled */ -static char alertnum = 1; /* alert dest num (usu 1 thru 4) */ -static char alertmax = 9; /* alert dest num max (usu 4, error if >9) */ -static char pefnum = 12; /* 11 pre-defined entries, adding 12th */ -static char pefadd = 0; /* num PEF rules added (usu 2, could be 5 */ -static char pefmax = MAXPEF; /* 20 for Sahalee, 30 for miniBMC */ -static char *myuser = NULL; /* username to set, specified by -u */ -static uchar usernum = 0; /* set non-zero to specify user number */ -static uchar rgmyip[4] = {0,0,0,0}; -static uchar rggwyip[4] = {0,0,0,0}; -static uchar rggwy2ip[4] = {0,0,0,0}; -static uchar rgdestip[4] = {0,0,0,0}; -static uchar rgsubnet[4] = {0,0,0,0}; -static uchar bmcsubnet[4] = {255,255,255,0}; /* default subnet */ -static uchar ossubnet[4] = {0,0,0,0}; -static uchar osmyip[4] = {0,0,0,0}; -static uchar bmcmyip[4] = {0,0,0,0}; -static uchar bmcdestip[4] = {0,0,0,0}; -static uchar bmcdestmac[6]= {0xff,0,0,0,0,0}; -static uchar bmcgwyip[4] = {0,0,0,0}; -static uchar bmcgwymac[6]= {0xff,0,0,0,0,0}; -static uchar bmcmymac[6] = {0xff,0,0,0,0,0}; -static uchar rgmymac[6] = {0xff,0,0,0,0,0}; -static uchar osmymac[6] = {0xff,0,0,0,0,0}; -static uchar rggwymac[6] = {0xff,0,0,0,0,0}; -static uchar rggwy2mac[6] = {0xff,0,0,0,0,0}; -static uchar rgdestmac[6] = {0xff,0,0,0,0,0}; -static uchar rgdhcpmac[6] = {0xff,0,0,0,0,0}; -static int nciphers = 16; -static int ncipher0 = 0; -static uchar rgciphers[16] = {0xff,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; -static char rghostname[32] = {'\0'}; -static uchar custPEF[20]; /* max used = 18 bytes */ -static char rgcommunity[19] = "public"; /* default community */ -static char fsetcommunity = 0; /* =1 if user-specified community */ -static char passwordData[PSW_MAX+1] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; -static uchar authmask = 0; /* usu 0x17, mBMC = 0x15 */ -static uchar bAuth = 0x16; /*exclude auth=None for security*/ -static uchar arp_interval = 0x04; /* in 500 ms increments, 0-based */ -static uchar arp_ctl = 0x01; /* 01=grat arp, 02=arp resp, 03=both*/ -static uchar fsetarp = 0; /* 1=user-specified arp_ctl */ -#ifdef WIN32 -static uchar ostype = OS_WINDOWS; /*windows*/ -static char ifname[64] = "Local Area Connection "; /* interface name */ -static char ifpattn[25] = "Local Area Connection "; -#elif SOLARIS -/* for i86pc use "e1000g0", but for sun4u(sparc) this might be "eri0" */ -static uchar ostype = OS_SOLARIS; -#ifdef __SPARC__ -static char ifname[16] = "eri0"; /* SPARC interface name */ -static char ifname0[16] = "eri0"; -static char ifpattn[14] = "eri"; -#else -static char ifname[16] = "e1000g0"; /* Solaris x86 interface name */ -static char ifname0[16] = "e1000g0"; -static char ifpattn[14] = "e1000g"; -#endif -#elif defined(BSD) -static uchar ostype = OS_BSD; -static char ifname[16] = "em0"; /* interface name */ -static char ifname0[16] = "em0"; -static char ifpattn[14] = "em"; -#elif defined(HPUX) -static uchar ostype = OS_HPUX; -static char ifname[16] = "lan0"; /* interface name */ -static char ifname0[16] = "lan0"; -static char ifpattn[14] = "lan"; -#else -static uchar ostype = OS_LINUX; -static char ifname[16] = "eth0"; /* interface name */ -static char ifname0[16] = "eth0"; -static char ifpattn[14] = "eth"; -#endif -static char *pspace1 = "\t"; /*used for fcanonical output*/ -static char *pspace2 = "\t\t"; -static char *pspace3 = "\t\t\t"; -static char *pspace4 = "\t\t\t\t"; -static int vend_id; -static int prod_id; -static int lan_dhcp = 0; /*=1 if using DHCP for bmc lan channel*/ -static uchar ser_ch = SER_CH; -static uchar gcm_ch = PARM_INIT; -static uchar failover_enable = PARM_INIT; -static uchar vlan_enable = PARM_INIT; -static uchar vlan_prio = 0; /*default = 0*/ -static ushort vlan_id = 0; /*max 12 bits used*/ -static uchar lan_access = 0x04; /* -v usu 4=Admin, 3=Operator, 2=User */ -static uchar lan_user = 0x02; /* -u if specified, default to user 2 */ -static uchar lan_ch_parm = PARM_INIT; /* -L to set, unused if PARM_INIT */ -static uchar lan_ch = LAN_CH; /* default=LAN_CH=1 */ -static uchar max_users = 5; /* set in GetUser(1); */ -static uchar enabled_users = 0; /* set in GetUser(1); */ -static uchar show_users = 5; /* default, adjusted based on DeviceID */ -static uchar fnewbaud = 0; /* =1 if user specified baud */ -static uchar sol_baud = SOL_PREFERRED_BAUD_RATE; /*115.2k default*/ -static uchar sol_accum[2] = { 0x04, 0x32 }; -static uchar sol_retry[2] = { 0x06, 0x14 }; -static uchar sol_bvalid = 0; /* =1 if SOL baud is valid */ -static uchar chan_pefon = CHAN_ACC_PEFON; -static uchar chan_pefoff = CHAN_ACC_PEFOFF; -static uchar SessInfo[18]; /* Session Info data */ -// static uchar bparm7[3] = {0x00, 0x00, 0x00}; /*ipv4 header before*/ -static uchar iparm7[3] = {0x1E, 0x00, 0x00}; /*intel ipv4 TTL,Flags,Service*/ -static uchar oparm7[3] = {0x40, 0x40, 0x10}; /*other ipv4 TTL,Flags,Service*/ -static uchar *parm7 = &oparm7[0]; -#define MAX_PEFPARAMS 14 /* max pef params = 14 */ -uchar peflen[MAX_PEFPARAMS] = {0,1,1,1,1,1,21,2,1,4,17,1,3,18}; /*for ShowPef*/ -uchar pef_array[MAXPEF][21]; /* array of all PEF entries read, */ - /* sizeof(PEF_RECORD) = 21 */ -uchar pef_defaults[11][21] = { /* array of first 11 default PEF entries */ -{0x01,0x80,1,1,PEF_SEV_CRIT,0xff,0xff,0x01,0xff,0x01,0x95,0x0a,0,0,0,0,0,0,0,0,0}, /*Temp*/ -{0x02,0x80,1,1,PEF_SEV_CRIT,0xff,0xff,0x02,0xff,0x01,0x95,0x0a,0,0,0,0,0,0,0,0,0}, /*Volt*/ -{0x03,0x80,1,1,PEF_SEV_CRIT,0xff,0xff,0x04,0xff,0x01,0x95,0x0a,0,0,0,0,0,0,0,0,0}, /*Fan*/ -{0x04,0x80,1,1,PEF_SEV_WARN,0xff,0xff,0x05,0x05,0x03,0x01,0x00,0,0,0,0,0,0,0,0,0}, /*Chass*/ -{0x05,0x80,1,1,PEF_SEV_WARN,0xff,0xff,0x08,0xff,0x6f,0x06,0x00,0,0,0,0,0,0,0,0,0}, /*PS*/ -{0x06,0x80,1,1,PEF_SEV_WARN,0xff,0xff,0x0c,0x08,0x6f,0x02,0x00,0,0,0,0,0,0,0,0,0}, /*ECC*/ -{0x07,0x80,1,1,PEF_SEV_CRIT,0xff,0xff,0x0f,0x06,0x6f,0x01,0x00,0,0,0,0,0,0,0,0,0}, /*FRB*/ -{0x08,0x80,1,1,PEF_SEV_WARN,0xff,0xff,0x07,0xff,0x6f,0x1c,0x00,0,0,0,0,0,0,0,0,0}, /*POST*/ -{0x09,0x80,1,1,PEF_SEV_CRIT,0xff,0xff,0x13,0xff,0x6f,0x3e,0x03,0,0,0,0,0,0,0,0,0}, /*NMI*/ -{0x0a,0x80,1,1,PEF_SEV_INFO,0xff,0xff,0x23,0x03,0x6f,0x0e,0x00,0,0,0,0,0,0,0,0,0}, /*WDT*/ -{0x0b,0x80,1,1,PEF_SEV_MON,0xff,0xff,0x12,0xff,0x6f,0x02,0x00,0,0,0,0,0,0,0,0,0} };/*Restart*/ - -char **pefdesc; -char *pefdesc1[MAXPEF] = { /* for Sahalee BMC */ -/* 0 0x00 */ "", -/* 1 0x01 */ "Temperature Sensor", -/* 2 0x02 */ "Voltage Sensor", -/* 3 0x04 */ "Fan Failure", -/* 4 0x05 */ "Chassis Intrusion", -/* 5 0x08 */ "Power Supply Fault", -/* 6 0x0c */ "Memory ECC Error", -/* 7 0x0f */ "BIOS POST Error", -/* 8 0x07 */ "FRB Failure", -/* 9 0x13 */ "Fatal NMI", -/*10 0x23 */ "Watchdog Timer Reset", -/*11 0x12 */ "System Restart", -/*12 0x20 */ "OS Critical Stop", -/*13 0x09 */ "Power Redundancy Lost", -/*14 0x00 */ "reserved", -/*15 0x00 */ "reserved", -/*16 0x00 */ "reserved", -/*17 */ "reserved", -/*18 */ "reserved", -/*19 */ "reserved", -/*20 */ "reserved", -/*21 */ "reserved", -/*22 */ "reserved", -/*23 */ "reserved", -/*24 */ "reserved", -/*25 */ "reserved", -/*26 */ "reserved", -/*27 */ "reserved", -/*28 */ "reserved", -/*29 */ "unused", -/*30 */ "unused" }; - -char *pefdesc2[MAXPEF] = { /* for NSC miniBMC */ -/* 0 */ "", -/* 1 0x02*/ "Voltage Sensor Assert", -/* 2 0x23*/ "Watchdog FRB Timeout", /* was "Proc FRB Thermal", */ -/* 3 0x02*/ "Voltage Sensor Deassert", -/* 4 0x07*/ "Proc1 IERR", -/* 5 0xff*/ "Digital Sensor OK", -/* 6 0x14*/ "Chassis Identify", -/* 7 0x13*/ "NMI Button", -/* 8 0x14*/ "Clear CMOS via Panel", -/* 9 0x0f*/ "OS Load POST Code", -/*10 0x20*/ "OS Critical Stop", -/*11 0x09 */ "Power Redundancy Lost", -/*12 0x00*/ "reserved", -/*13 */ "reserved", -/*14 */ "reserved", -/*15 */ "reserved", -/*16 */ "reserved", -/*17 */ "reserved", -/*18 */ "reserved", -/*19 */ "reserved", -/*20 */ "reserved", -/*21 */ "reserved", -/*22 */ "reserved", -/*23 */ "reserved", -/*24 */ "reserved", -/*25 */ "reserved", -/*26 0x05*/ "Chassis Intrusion", -/*27 0x0f*/ "POST Code Error", -/*28 0x02*/ "Voltage Failure", -/*29 0x04*/ "Fan Failure", -/*30 0x01*/ "Temperature Failure"}; - -#define NLAN 39 -char canon_param[NLAN] = { 0,0,0,1,1,1,1,0,0,0,0,0,1,1,0,0,1,0,0,1, - 0,0,0,0,0,0,1,1,1,1}; -struct { - int cmd; - int sz; - char desc[28]; -} lanparams[NLAN] = { /* see IPMI Table 19-4 */ - /* 0 */ { 0, 1, "Set in progress"}, - /* 1 */ { 1, 1, "Auth type support"}, - /* 2 */ { 2, 5, "Auth type enables"}, - /* 3 */ { 3, 4, "IP address"}, - /* 4 */ { 4, 1, "IP addr src"}, /* (DHCP/Static) */ - /* 5 */ { 5, 6, "MAC addr"}, - /* 6 */ { 6, 4, "Subnet mask"}, - /* 7 */ { 7, 3, "IPv4 header"}, - /* 8 */ { 8, 2, "Prim RMCP port"}, - /* 9 */ { 9, 2, "Sec RMCP port"}, - /* 10 */ {10, 1, "BMC grat ARP"}, - /* 11 */ {11, 1, "grat ARP interval"}, - /* 12 */ {12, 4, "Def gateway IP"}, - /* 13 */ {13, 6, "Def gateway MAC"}, - /* 14 */ {14, 4, "Sec gateway IP"}, - /* 15 */ {15, 6, "Sec gateway MAC"}, - /* 16 */ {16,18, "Community string"}, - /* 17 */ {17, 1, "Num dest"}, - /* 18 */ {18, 5, "Dest type"}, - /* 19 */ {19, 13, "Dest address"}, - /* 20 */ {20, 2, "VLAN ID"}, - /* 21 */ {21, 1, "VLAN Priority"}, - /* 22 */ {22, 1, "Cipher Suite Support"}, - /* 23 */ {23,17, "Cipher Suites "}, - /* 24 */ {24, 9, "Cipher Suite Priv"}, - /* 25 */ {25, 4, "VLAN Dest Tag"}, - /* 26 */ {96, 28, "OEM Alert String"}, - /* 27 */ {97, 1, "Alert Retry Algorithm"}, - /* 28 */ {98, 3, "UTC Offset"}, - /* 29 */ {102, 1, "IPv6 Enable"}, - /* 30 */ {103, 1, "IPv6 Addr Source"}, - /* 31 */ {104,16, "IPv6 Address"}, - /* 32 */ {105, 1, "IPv6 Prefix Len"}, - /* 33 */ {106,16, "IPv6 Default Gateway"}, - /* 34 */ {108,17, "IPv6 Dest address"}, - /* 35 */ {192, 4, "DHCP Server IP"}, - /* 36 */ {193, 6, "DHCP MAC Address"}, - /* 37 */ {194, 1, "DHCP Enable"}, - /* 38 */ {201, 2, "Channel Access Mode(Lan)"} -}; - -#define NSER 22 /* max=32 */ -struct { - int cmd; - int sz; - char desc[28]; -} serparams[NSER] = { /* see IPMI Table 20-4 */ - /* 0 */ { 0, 1, "Set in progress"}, - /* 1 */ { 1, 1, "Auth type support"}, - /* 2 */ { 2, 5, "Auth type enables"}, - /* 3 */ { 3, 1, "Connection Mode"}, - /* 4 */ { 4, 1, "Sess Inactiv Timeout"}, - /* 5 */ { 5, 5, "Channel Callback"}, - /* 6 */ { 6, 1, "Session Termination"}, - /* 7 */ { 7, 2, "IPMI Msg Comm"}, - /* 8 */ { 8, 2, "Mux Switch"}, - /* 9 */ { 9, 2, "Modem Ring Time"}, - /* 10 */ {10,17, "Modem Init String"}, - /* 11 */ {11, 5, "Modem Escape Seq"}, - /* 12 */ {12, 8, "Modem Hangup Seq"}, - /* 13 */ {13, 8, "Modem Dial Command"}, - /* 14 */ {14, 1, "Page Blackout Interval"}, - /* 15 */ {15,18, "Community String"}, - /* 16 */ {16, 1, "Num of Alert Dest"}, - /* 17 */ {17, 5, "Destination Info"}, - /* 18 */ {18, 1, "Call Retry Interval"}, - /* 19 */ {19, 3, "Destination Comm Settings"}, - /* 20 */ {29, 2, "Terminal Mode Config"}, - /* 21 */ {201, 2,"Channel Access Mode (Ser)"} -}; - -static void getauthstr(uchar auth, char *s) -{ - if (s == NULL) return; - s[0] = 0; - if (auth & 0x01) strcat(s,"None "); - if (auth & 0x02) strcat(s,"MD2 "); - if (auth & 0x04) strcat(s,"MD5 "); - if (auth & 0x10) strcat(s,"Pswd "); - if (auth & 0x20) strcat(s,"OEM "); - return; -} - -static int GetDeviceID(LAN_RECORD *pLanRecord) -{ /*See also ipmi_getdeviceid( pLanRecord, sizeof(LAN_RECORD),fdebug); */ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - int status; - uchar inputData[24]; - uchar completionCode; - - if (pLanRecord == NULL) return(-1); - - status = ipmi_cmd(GET_DEVICE_ID, inputData, 0, responseData, - &responseLength, &completionCode, fdebug); - - if (status == ACCESS_OK) { - if( completionCode ) { - SELprintf("GetDeviceID: completion code=%x\n", - completionCode); - status = completionCode; - } else { - memcpy(pLanRecord,&responseData[0],responseLength); - set_mfgid(&responseData[0],responseLength); - return(0); // successful, done - } - } /* endif */ - /* if get here, error */ - return(status); -} /*end GetDeviceID() */ - -static int GetChanAcc(uchar chan, uchar parm, LAN_RECORD *pLanRecord) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - int status; - uchar inputData[24]; - uchar completionCode; - - if (pLanRecord == NULL) return(-1); - responseLength = 3; - inputData[0] = chan; - inputData[1] = parm; /* 0x80 = active, 0x40 = non-volatile */ - responseLength = sizeof(responseData); - status = ipmi_cmd(GET_CHANNEL_ACC, inputData, 2, responseData, - &responseLength, &completionCode, fdebug); - - if (status == ACCESS_OK) { - if( completionCode ) { - SELprintf("GetChanAcc: completion code=%x\n", - completionCode); - status = completionCode; - } else { - // dont copy first byte (Parameter revision, usu 0x11) - memcpy(pLanRecord,&responseData[0],responseLength); - return(0); // successful, done - } - } /* endif */ - /* if get here, error */ - return(status); -} /*GetChanAcc()*/ - -static int SetChanAcc(uchar chan, uchar parm, uchar val) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - int status; - uchar inputData[24]; - uchar completionCode; - - if (fmBMC) return(0); /* mBMC doesn't support this */ - /* parm: 0x80 = active, 0x40 = set non-vol*/ - responseLength = 1; - inputData[0] = chan; /* channel */ - inputData[1] = (parm & 0xc0) | (val & 0x3F); - inputData[2] = (parm & 0xc0) | lan_access; /* set priv level to Admin */ - - responseLength = sizeof(responseData); - status = ipmi_cmd(SET_CHANNEL_ACC, inputData, 3, responseData, - &responseLength, &completionCode, fdebug); - - if (status == ACCESS_OK) { - if( completionCode ) { - SELprintf("SetChanAcc: completion code=%x\n", - completionCode); - status = completionCode; - } else { - return(0); // successful, done - } - } /* endif */ - /* if get here, error */ - return(status); -} /*SetChanAcc()*/ - -int SetPasswd(int unum, char *uname, char *upswd, uchar chan, uchar priv) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - int status, i, psw_len; - uchar completionCode; - uchar inputData[24]; - int ret = 0; - - inputData[0] = (uchar)unum; /*user 1 = null user */ - responseLength = sizeof(responseData); - status = ipmi_cmd(GET_USER_NAME, inputData, 1, responseData, - &responseLength, &completionCode, fdebug); - SELprintf("GET_USERNAME: %x %x %x, status = %x, ccode=%x\n", - responseData[0],responseData[1],responseData[2], - status,completionCode); - if (fdebug) { - char aname[17]; - printf("User %d: ",unum); - for (i = 0; i < responseLength; i++) { - printf("%02x ",responseData[i]); - if (responseData[i] < 0x20) aname[i] = '.'; - else aname[i] = responseData[i]; - } - aname[16] = 0; - printf(" %s\n",aname); - } - - if (unum != 1) - { /* user specified a lan username */ - if (fiBMC && (unum == 2)) { - /* cannot set user 2 name */ - if (uname != NULL) { - if (strcmp(uname,"root") != 0) - printf("SETUSERNAME - user2 name %s must be root\n",uname); - } - } else if (unum == 2 && (vend_id == VENDOR_SUPERMICROX || - vend_id == VENDOR_SUPERMICRO) ) { - /* cannot set user 2 name */ - if (uname != NULL) { - if (strcmp(uname,"ADMIN") != 0) - printf("SETUSERNAME - user2 name %s must be ADMIN\n",uname); - } - } else if (uname != NULL) { - inputData[0] = (uchar)unum; - memset(&inputData[1],0,16); - memcpy(&inputData[1],uname,strlen(uname)); - status = ipmi_cmd(SET_USER_NAME, inputData, 17, responseData, - &responseLength, &completionCode, fdebug); - if (completionCode == 0xCC) - status = 0; /*setting username to previous gives 0xCC, ok*/ - else { - SELprintf("SETUSERNAME - %x %x %x status = %x, ccode=%x\n", - inputData[0],inputData[1],inputData[2], - status,completionCode); - if (status == 0) status = completionCode; - if (status != 0) ret = status; - } - } - } - - if ((unum != 1) && (uname == NULL)) { - ; /* if no username, do not enable user */ - } else { - inputData[0] = (uchar)unum; - inputData[1] = 0x01; /*enable user*/ - responseLength = sizeof(responseData); - status = ipmi_cmd(SET_USER_PASSWORD, inputData, 2, responseData, - &responseLength, &completionCode, fdebug); - printf("SETUSERENAB - inputData %x %x %x, status = %x, ccode=%x\n", - inputData[0],inputData[1],inputData[2], - status,completionCode); - if (status == 0) status = completionCode; - if (status != 0) ret = status; - } - - if (upswd != NULL) { - inputData[0] = (uchar)unum; - inputData[1] = 0x02; /*set password*/ - psw_len = PSW_LEN; /*=16 change if 20-byte passwords supported */ - memset(&inputData[2],0,psw_len); - strcpy((char *)&inputData[2],upswd); - if (fdebug) { - char apsw[PSW_MAX+1]; - char c; - printf("Pswd %d: ",unum); - for (i = 0; i < psw_len; i++) { - c = inputData[i+2]; - printf("%02x ",(unsigned char)c); - if (c < 0x20) apsw[i] = '.'; - else apsw[i] = c; - } - apsw[psw_len] = 0; - printf(" %s\n",apsw); - } - responseLength = sizeof(responseData); - status = ipmi_cmd(SET_USER_PASSWORD, inputData, 2+psw_len, - responseData,&responseLength, &completionCode,fdebug); - SELprintf("SETUSERPSW - inputData %x %x %x, status = %x, ccode=%x\n", - inputData[0],inputData[1],inputData[2], - status,completionCode); - if (status == 0) status = completionCode; - if (status != 0) ret = status; - - inputData[0] = (uchar)unum; /*user 1 = null user */ - inputData[1] = 0x03; /*test password*/ - memset(&inputData[2],0,psw_len); - if (upswd != NULL) - strcpy((char *)&inputData[2],upswd); - responseLength = sizeof(responseData); - status = ipmi_cmd(SET_USER_PASSWORD, inputData, 2+psw_len, - responseData,&responseLength, &completionCode,fdebug); - SELprintf("TESTUSERPSW - inputData %x %x %x, status = %x, ccode=%x\n", - inputData[0],inputData[1],inputData[2], - status,completionCode); - } - - if (fiBMC && (unum == 2)) { /*iBMC doesn't support this on user 2*/ - if (fdebug) - printf("skipping SETUSER_ACCESS on iBMC for user %d\n",unum); - } else { - inputData[0] = 0x90 | chan; /* = 0x97 for chan=lan_ch=7 */ - inputData[1] = (uchar)unum; /* user num */ - inputData[2] = priv; /* usu priv=lan_access is admin */ - inputData[3] = 0x00; /* User Session Limit, 0=not limited*/ - responseLength = sizeof(responseData); - status = ipmi_cmd(SET_USER_ACCESS, inputData, 4, responseData, - &responseLength, &completionCode, fdebug); - printf("SETUSER_ACCESS - inputData %x %x %x, status = %x ccode=%x\n", - (uchar)inputData[0],inputData[1],inputData[2], - status,completionCode); - if (status == 0) status = completionCode; - if (status != 0) ret = status; - } - - return(ret); -} /*end SetPswd()*/ - -int SetUser(int unum, char *uname, char *passwd, uchar chan) -{ - int ret = 0; - /* if the user specified a username or password, set it. */ - if ((fpassword) || (uname != NULL)) { - /* set username and password */ - ret = SetPasswd(unum, uname,passwd, chan, lan_access); - } - return(ret); -} /*end SetUser()*/ - -int -DisableUser(int unum, uchar chan) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - int status; - uchar completionCode; - uchar inputData[24]; - - inputData[0] = 0x80 | chan; /* = 0x87, no IPMI */ - inputData[1] = (uchar)unum; /* user 1 */ - inputData[2] = 0x0F; /* No access */ - inputData[3] = 0x00; /* User Session Limit, 0=not limited*/ - responseLength = sizeof(responseData); - status = ipmi_cmd(SET_USER_ACCESS, inputData, 4, responseData, - &responseLength, &completionCode, fdebug); - if (status == 0) status = completionCode; - return(status); -} - -static char *parse_priv(uchar c) -{ - char *p; - c = (c & 0x0f); - switch(c) { - case 1: p = "Callback"; break; - case 2: p = "User "; break; - case 3: p = "Operator"; break; - case 4: p = "Admin "; break; - case 5: p = "OEM "; break; - case 0x0f: p = "No access"; break; - default: p = "Reserved"; /*usually =0*/ - } - return(p); -} - -static void show_priv(uchar c) -{ - char *privstr; - privstr = parse_priv(c); - printf("%s",privstr); -} - -static int valid_priv(int c) -{ - int rv; - switch(c) { - case 1: - case 2: - case 3: - case 4: - case 5: - case 0x0f: - rv = 1; - break; - default: - rv = 0; - break; - } - return rv; -} - -/* GetUserINfo - get user configuration info for user subfunction */ -int GetUserInfo(uchar unum, uchar chan, uchar *enab, uchar *priv, char *uname) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - int status, rv; - uchar completionCode; - uchar inputData[24]; - uchar upriv; - - if (enab == NULL || priv == NULL) return(-2); - inputData[0] = chan; /*lan_ch*/ - inputData[1] = unum; /* user number for IPMI LAN */ - responseLength = sizeof(responseData); - status = ipmi_cmd(GET_USER_ACCESS, inputData, 2, responseData, - &responseLength, &completionCode, fdebug); - rv = status; - if (status == 0 && completionCode != 0) rv = completionCode; - if (rv == 0) { - if (unum == 1) { /*get max_users and enabled_users*/ - max_users = responseData[0] & 0x3f; - enabled_users = responseData[1] & 0x3f; - } - upriv = responseData[3]; - inputData[0] = unum; /* usually = 1 for BMC LAN */ - responseLength = sizeof(responseData); - status = ipmi_cmd(GET_USER_NAME, inputData, 1, responseData, - &responseLength, &completionCode, fdebug); - if (status != 0 || completionCode != 0) - responseData[0] = 0; /*empty user name */ - responseData[PSW_MAX-1] = 0; /*for safety*/ - *priv = upriv; - if ((responseData[1] & 0x80) == 0) *enab = 0; - else *enab = 1; - if (uname != NULL) strcpy(uname,responseData); - } - return(rv); -} - -/* GetUser - get and show user configuration */ -int GetUser(uchar user_num, uchar chan) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - int status; - uchar completionCode; - uchar inputData[24]; - - inputData[0] = chan; /*lan_ch*/ - inputData[1] = user_num; /* usually = 1 for BMC LAN */ - responseLength = sizeof(responseData); - status = ipmi_cmd(GET_USER_ACCESS, inputData, 2, responseData, - &responseLength, &completionCode, fdebug); - if (status == 0 && completionCode == 0) { - uchar c; - if (user_num == 1) { /*get max_users and enabled_users*/ - max_users = responseData[0] & 0x3f; - enabled_users = responseData[1] & 0x3f; - if (enabled_users > show_users) show_users = enabled_users; - if (show_users > max_users) show_users = max_users; - if (!fcanonical) - SELprintf("Users: showing %d of max %d users (%d enabled)\n", - show_users,max_users,enabled_users); - } - if (fcanonical) - SELprintf("Channel %d User %d Access %s%c ", chan, user_num, - pspace2,bdelim); - else - SELprintf("User Access(chan%d,user%d): %02x %02x %02x %02x : ", - chan, user_num, (uchar)responseData[0], - responseData[1],responseData[2], responseData[3]); - c = responseData[3]; - inputData[0] = user_num; /* usually = 1 for BMC LAN */ - responseLength = sizeof(responseData); - status = ipmi_cmd(GET_USER_NAME, inputData, 1, responseData, - &responseLength, &completionCode, fdebug); - if (status != 0 || completionCode != 0) - responseData[0] = 0; - if (c & 0x10) printf("IPMI, "); - show_priv(c); - printf(" (%s)\n",responseData); /*show user name */ - } else - SELprintf("Get User Access(%d,%d), status=%x, ccode=%x\n", - chan, user_num, status, completionCode); - return(status); -} /*end ShowUser()*/ - -static int GetSerEntry(uchar subfunc, LAN_RECORD *pLanRecord) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - uchar inputData[24]; - int status; - uchar completionCode; - uchar chan; uchar bset; - - if (pLanRecord == NULL) - { - if (fdebug) - printf("GetSerEntry(%d): error, output buffer is NULL\n",subfunc); - return (-1); - } - - chan = ser_ch; /* 1=EMP, 0=IPMB, 6=LAN2, 7=LAN1 */ - bset = 0; - - inputData[0] = chan; // flags, channel 3:0 (1=EMP) - inputData[1] = subfunc; // Param selector - inputData[2] = bset; // Set selector - inputData[3] = 0; // Block selector - if (subfunc == 10) { - inputData[2] = 0; - inputData[3] = 1; - } - - status = ipmi_cmd(GET_SER_CONFIG, inputData, 4, responseData, - &responseLength, &completionCode, fdebug); - - if (status == ACCESS_OK) { - if( completionCode ) { - if (fdebug) - SELprintf("GetSerEntry(%d,%d): completion code=%x\n", - chan,subfunc,completionCode); - } else { - // dont copy first byte (Parameter revision, usu 0x11) - memcpy(pLanRecord,&responseData[1],responseLength-1); - pLanRecord->data[responseLength-1] = 0; - //successful, done - return(0); - } - } - - // we are here because completionCode is not COMPLETION_CODE_OK - if (fdebug) - SELprintf("GetSerEntry(%d,%d): ipmi_cmd status=%x ccode=%x\n", - chan,subfunc,status,completionCode); - return -1; -} - -static int GetLanEntry(uchar subfunc, uchar bset, LAN_RECORD *pLanRecord) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - uchar inputData[24]; - int status, n; - uchar completionCode; - uchar chan; - - if (pLanRecord == NULL) - { - if (fdebug) - printf("GetLanEntry: error, output buffer is NULL\n"); - return (-1); - } - - chan = lan_ch; /* LAN 1 = 7 */ - - inputData[0] = chan; // flags, channel 3:0 (LAN 1) - inputData[1] = subfunc; // Param selector (3 = ip addr) - inputData[2] = bset; // Set selector - inputData[3] = 0; // Block selector - - status = ipmi_cmd(GET_LAN_CONFIG, inputData, 4, responseData, - &responseLength, &completionCode, fdebug); - - if (status == ACCESS_OK) { - if( completionCode ) { - if (fdebug) - SELprintf("GetLanEntry: completion code=%x\n", - completionCode); - status = completionCode; - } else { - // dont copy first byte (Parameter revision, usu 0x11) - if (responseLength > 0) { - n = responseLength-1; - memcpy(pLanRecord,&responseData[1],n); - } else n = 0; - pLanRecord->data[n] = 0; - //successful, done - return(0); - } - } - - // we are here because completionCode is not COMPLETION_CODE_OK - if (fdebug) - SELprintf("GetLanEntry: ipmi_cmd status=%d completionCode=%x\n", - status,completionCode); - return status; -} /* end GetLanEntry() */ - -static int SetLanEntry(uchar subfunc, LAN_RECORD *pLanRecord, int reqlen) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - uchar inputData[24]; - int status; - uchar completionCode; - - if (pLanRecord == NULL) - { - if (fdebug) - printf("SetLanEntry(%d): error, input buffer is NULL\n",subfunc); - return (-1); - } - if (vend_id == VENDOR_SUPERMICROX || vend_id == VENDOR_SUPERMICRO) { - /* SUPERMICRO cannot set grat arp or grat arp interval */ - if (subfunc == 10 || subfunc == 11) return(0); - } - - inputData[0] = lan_ch; // flags, channel 3:0 (LAN 1) - inputData[1] = subfunc; // Param selector (3 = ip addr) - memcpy(&inputData[2],pLanRecord,reqlen); - - status = ipmi_cmd(SET_LAN_CONFIG, inputData, (uchar)(reqlen+2), - responseData, &responseLength,&completionCode,fdebug); - - if (status == ACCESS_OK) { - if( completionCode ) { - if (fdebug) - SELprintf("SetLanEntry(%d): completion code=%x\n", - subfunc,completionCode); // responseData[0]); - return(completionCode); - } else { - //successful, done - return(0); - } - } - - // we are here because completionCode is not COMPLETION_CODE_OK - if (fdebug) - SELprintf("SetLanEntry(%d): ipmi_cmd status=%d ccode=%x\n", - subfunc,status,completionCode); - return status; -} /* end SetLanEntry() */ - -int GetPefEntry(uchar subfunc, ushort rec_id, PEF_RECORD *pPefRecord) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - uchar inputData[24]; /* only use 3 bytes for input */ - int status, n; - uchar completionCode; - - if (pPefRecord == NULL) - { - if (fdebug) - printf("GetPefEntry(%d): error, output buffer is NULL\n",subfunc); - return (-1); - } - - inputData[0] = subfunc; // Parameter = Evt Filter Table - inputData[1] = (uchar)rec_id; - inputData[2] = 0; - - status = ipmi_cmd(GET_PEF_CONFIG, inputData, 3, responseData, - &responseLength, &completionCode, fdebug); - - if (status == ACCESS_OK) { - if( completionCode ) { - if (fdebug) - SELprintf("GetPefEntry(%d/%d): completion code=%x\n", - subfunc,rec_id,completionCode); - status = completionCode; - } else { - /* expect PEF record to be >=21 bytes */ - if (responseLength > 1) n = responseLength-1; - else n = 0; - if (n > 21) n = 21; /*only use 21 bytes*/ - if ((subfunc == 6) && (n < 21)) { - if (fdebug) - printf("GetPefEntry(%d/%d): length %d too short\n", - subfunc,rec_id,responseLength); - } - // dont copy first byte (Parameter revision, usu 0x11) - if (n == 0) memset(pPefRecord,0,21); - else memcpy(pPefRecord,&responseData[1],n); - //successful, done - return(0); - } - } - - // we are here because completionCode is not COMPLETION_CODE_OK - if (fdebug) - SELprintf("GetPefEntry: ipmi_cmd status=%x completionCode=%x\n", - status, completionCode); - return status; -} /* end GetPefEntry() */ - -int SetPefEntry(PEF_RECORD *pPefRecord) -{ - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - uchar inputData[32]; /* sizeof(PEF_RECORD) = 21 +1=22 */ - int status; - uchar completionCode; - uchar subfunc; - - subfunc = 0x06; // Parameter = Evt Filter Table - - if (pPefRecord == NULL) { - if (fdebug) - printf("SetPefEntry: error, output buffer is NULL\n"); - return (-1); - } - - // 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 - // 06 0c 80 01 01 00 ff ff 20 ff 6f ff 00 00 00 00 00 00 00 00 00 00 - // memset(&inputData[0],0,requestData.dataLength); - inputData[0] = subfunc; - memcpy(&inputData[1],pPefRecord,sizeof(PEF_RECORD)); - - status = ipmi_cmd(SET_PEF_CONFIG, inputData, sizeof(PEF_RECORD)+1, - responseData, &responseLength, &completionCode, fdebug); - - if (status == ACCESS_OK) { - if( completionCode ) { - if (fdebug) - SELprintf("SetPefEntry: completion code=%x\n", - completionCode); // responseData[0]); - status = completionCode; - } else { - //successful, done - return(0); - } - - } - - // we are here because completionCode is not COMPLETION_CODE_OK - if (fdebug) - SELprintf("SetPefEntry: ipmi_cmd status=%d completion code=%x\n", - status,completionCode); - return(status); - -} /* end SetPefEntry() */ - -int DisablePef(int anum) -{ - uchar iData[24]; /* sizeof(PEF_RECORD) = 21 +1=22 */ - uchar rData[MAX_BUFFER_SIZE]; - int rLength = MAX_BUFFER_SIZE; - uchar cc; - int status; - - if (fmBMC) { - SELprintf("mini-BMC does not support disabling BMC LAN\n"); - return(-1); - } else { - status = SetChanAcc(lan_ch, 0x80, CHAN_ACC_DISABLE); - if (fdebug) SELprintf("SetChanAcc(lan/active), ret = %d\n",status); - status = SetChanAcc(lan_ch, 0x40, CHAN_ACC_DISABLE); - SELprintf("SetChanAcc(lan), ret = %d\n",status); - if (status != 0) return(status); - } - - iData[0] = 0x01; /* PEF Control Param */ - iData[1] = 0x00; /* PEF disable */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(SET_PEF_CONFIG, iData, 2, rData, &rLength, - &cc, fdebug); - if (status != 0) return(status); - if( cc ) { - SELprintf("DisablePef[%d]: completion code=%x\n",iData[0],cc); - return(-1); - } - - if (anum != 0) { - iData[0] = 0x09; /* PEF Alert Policy Table */ - iData[1] = (uchar)anum; /* Policy number (default 0x01) */ - iData[2] = 0x10; /* PEF LAN, policy disable */ - iData[3] = 0x00; /* LAN_CH=00, default dest=00 */ - iData[4] = 0x00; /* No alert string */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(SET_PEF_CONFIG, iData, 5, rData, &rLength, - &cc, fdebug); - if (status != 0) return(status); - if( cc ) { - SELprintf("DisablePef[%d]: completion code=%x\n",iData[0],cc); - return(-1); - } - } - return(status); -} - -int ShowPef(void) -{ - uchar iData[24]; /* sizeof(PEF_RECORD) = 21 +1=22 */ - uchar rData[MAX_BUFFER_SIZE]; - int rLength = MAX_BUFFER_SIZE; - uchar cc; - int status, i,j; - - for (j = 1; j < MAX_PEFPARAMS; j++) { - if (j == 4 && fmBMC) { - /* fmBMC gets cc=0x80 for param 4, so skip it. */ - continue; - } - iData[0] = (uchar)j; /* PEF Control Param */ - if (j == 6 || j == 7 || j == 9) iData[1] = 1; - else iData[1] = 0x00; /* PEF Set Selector */ - if (j == 13) iData[2] = 1; - else iData[2] = 0x00; /* PEF Block Selector */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(GET_PEF_CONFIG, iData, 3, rData, &rLength, - &cc, fdebug); - if (status == 0 && cc == 0) { - SELprintf("PefParam[%d]: ",iData[0]); - if (rLength > 0) - for (i=0;i<peflen[j];i++) SELprintf("%02x ", rData[1+i]); - SELprintf("\n"); - } else - SELprintf("PefParam[%d]: GET_PEF status=%d cc=%x\n", - iData[0],status,cc); - } - return(status); -} - -int EnablePef(int anum) -{ - uchar iData[24]; /* sizeof(PEF_RECORD) = 21 +1=22 */ - uchar rData[MAX_BUFFER_SIZE]; - int rLength = MAX_BUFFER_SIZE; - uchar cc; - int status; - uchar sdelay; - - status = SetChanAcc(lan_ch, 0x80, chan_pefon); - if (fdebug) SELprintf("SetChanAcc(lan/active), ret = %d\n",status); - status = SetChanAcc(lan_ch, 0x40, chan_pefon); - SELprintf("SetChanAcc(lan), ret = %d\n",status); - if (status != 0) return(status); - - { - iData[0] = 0x01; /* PEF Control Param */ - iData[1] = 0x00; /* PEF Set Selector */ - iData[2] = 0x00; /* PEF Block Selector */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(GET_PEF_CONFIG, iData, 3, rData, &rLength, - &cc, fdebug); - if (status != 0 || cc != 0) sdelay = 0; - else sdelay = rData[1]; - if (fdebug) SELprintf("EnablePef[%d]: get cc=%x, control=%02x\n", - iData[0],cc,sdelay); - iData[0] = 0x01; /* PEF Control Param (0x01 or 0x05) */ - iData[1] = 0x01; /* PEF enable, & no startup delay */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(SET_PEF_CONFIG, iData, 2, rData, &rLength, - &cc, fdebug); - if (status != 0) return(status); - if( cc ) { - SELprintf("EnablePef[%d]: completion code=%x\n",iData[0],cc); - return(-1); - } - -#ifdef TEST - iData[0] = 0x01; /* Serial Channel */ - iData[1] = 0x13; /* Dest Com settings = 19. */ - iData[2] = 0x01; /* POL Default Dest */ - iData[3] = 0x60; - iData[4] = 0x07; - status = ipmi_cmd(SET_SER_CONFIG, iData, 5, rData, &rLength, - &cc, fdebug); -#endif - - iData[0] = 0x02; /* PEF Action Param */ - iData[1] = 0x00; /* PEF Set Selector */ - iData[2] = 0x00; /* PEF Block Selector */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(GET_PEF_CONFIG, iData, 3, rData, &rLength, - &cc, fdebug); - if (fdebug) SELprintf("EnablePef[%d]: get cc=%x, val=%02x\n", - iData[0],cc,rData[1]); - iData[0] = 0x02; /* PEF Action Param */ - if (vend_id == VENDOR_INTEL) - iData[1] = 0x2f; /* enable alerts, reset, power cycle/down, diag*/ - else - iData[1] = 0x0f; /* enable alerts, reset, power cycle/down */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(SET_PEF_CONFIG, iData, 2, rData, &rLength, - &cc, fdebug); - if (status != 0) return(status); - if( cc ) { - SELprintf("EnablePef[%d]: completion code=%x\n",iData[0],cc); - return(-1); - } - - if ((sdelay & 0x04) != 0) { /* startup delay is supported */ - iData[0] = 0x03; /* PEF Startup Delay Param */ - iData[1] = 0x00; /* 0 seconds, default is 0x3c (60 sec) */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(SET_PEF_CONFIG, iData, 2, rData, &rLength, - &cc, fdebug); - if (fdebug) SELprintf("EnablePef[%d]: set val=%02x cc=%x\n", - iData[0],iData[1],cc); - if (status != 0) return(status); - if( cc ) { - SELprintf("EnablePef[%d]: completion code=%x\n",iData[0],cc); - // return(-1); - } - iData[0] = 0x04; /* PEF Alert Startup Delay Param */ - iData[1] = 0x00; /* 0 seconds, default is 0x3c (60 sec) */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(SET_PEF_CONFIG, iData, 2, rData, &rLength, - &cc, fdebug); - if (fdebug) SELprintf("EnablePef[%d]: set val=%02x cc=%x\n", - iData[0],iData[1],cc); - if (status != 0) return(status); - if( cc ) { - SELprintf("EnablePef[%d]: completion code=%x\n",iData[0],cc); - // return(-1); - } - } /*endif sdelay*/ - - iData[0] = 0x09; /* PEF Alert Policy Table */ - iData[1] = (uchar)anum; /* Policy number (default 0x01) */ - iData[2] = 0x18; /* PEF LAN, always alert, policy enable */ - iData[3] = (lan_ch << 4) + anum; /* LAN_CH=70, default dest=01 */ - iData[4] = 0x00; /* No alert string */ - rLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(SET_PEF_CONFIG, iData, 5, rData, &rLength, - &cc, fdebug); - if (fdebug) SELprintf("EnablePef[%d]: set val=%02x cc=%x\n", - iData[0],iData[1],cc); - if (status != 0) return(status); - if( cc ) { - SELprintf("EnablePef[%d]: completion code=%x\n",iData[0],cc); - return(-1); - } - } /*endif IPMI 1.5 */ - - return(status); -} /* end EnablePef */ - -#define NBAUDS 10 -static struct { - unsigned char val; - char str[8]; - } mapbaud[NBAUDS] = { - { 6, "9600" }, - { 6, "9.6K" }, - { 7, "19.2K" }, - { 7, "19200" }, - { 8, "38.4K" }, - { 8, "38400" }, - { 9, "57.6K" }, - { 9, "57600" }, - { 10, "115.2K" }, - { 10, "115200" } - }; - -static unsigned char Str2Baud(char * str) -{ - unsigned char baud = 0; - int i, n, len; - len = strlen_(str); - for (i = 0; i < len; i++) /*toupper*/ - if (str[i] >= 'a' && str[i] <= 'z') str[i] &= 0x5F; - for (i = 0; i < NBAUDS; i++) { - n = strlen_(mapbaud[i].str); - if (strncmp(str,mapbaud[i].str,n) == 0) { - baud = mapbaud[i].val; - break; - } - } - if (i == NBAUDS || baud == 0) { - printf("Invalid -B parameter value (%s), using 19.2K.\n",str); - i = 1; /* default is 19.2K */ - baud = mapbaud[i].val; /* =7 */ - } - if (fdebug) printf("new baud = %02x (%s)\n",baud,mapbaud[i].str); - return(baud); -} - -static char *Baud2Str(unsigned char bin) -{ - char *baudstr; - unsigned char b; - b = bin & 0x0f; - switch(b) { - case 6: baudstr = "9600 "; break; - case 7: baudstr = "19.2k"; break; - case 8: baudstr = "38.4k"; break; - case 9: baudstr = "57.6k"; break; - case 10: baudstr = "115.2k"; break; - default: baudstr = "nobaud"; - } - return(baudstr); -} - -static int BaudValid(unsigned char b) -{ - int val = 0; - switch(b) { - case 6: val = 1; break; - case 7: val = 1; break; - case 8: val = 1; break; - case 9: val = 1; break; - case 10: val = 1; break; - default: val = 0; break; - } - return(val); -} - -/* - * atomac - converts ASCII string to binary MAC address (array). - * Accepts input formatted as 11:22:33:44:55:66 or 11-22-33-44-55-66. - */ -void atomac(uchar *array, char *instr) -{ - int i,j,n; - char *pi; - j = 0; - pi = instr; - n = strlen_(instr); - for (i = 0; i <= n; i++) { - if (instr[i] == ':') { - array[j++] = htoi(pi); - pi = &instr[i+1]; - } else if (instr[i] == '-') { - array[j++] = htoi(pi); - pi = &instr[i+1]; - } else if (instr[i] == 0) { - array[j++] = htoi(pi); - } - if (j >= MAC_LEN) break; /*safety valve*/ - } - if (fdebug) - printf("atomac: %02x %02x %02x %02x %02x %02x\n", - array[0],array[1],array[2],array[3], array[4],array[5]); -} /*end atomac()*/ - -/* extern void atoip(uchar *array,char *instr); *from subs.c*/ -void MacSetInvalid(uchar *mac) -{ - int i; - if (mac == NULL) return; - for (i = 0; i < MAC_LEN; i++) { - if (i == 0) mac[i] = 0xFF; - else mac[i] = 0x00; - } -} - -int MacIsValid(uchar *mac) -{ - int fvalid = 0; - int i; - /* check for initial invalid value of FF:00:... */ - if (mac[0] == 0xff && mac[1] == 0x00) /* marked as invalid */ - return(fvalid); - /* check for all zeros */ - for (i = 0; i < MAC_LEN; i++) - if (mac[i] != 0) { /* not all zeros */ - fvalid = 1; - break; - } - return(fvalid); -} - -int IpIsValid(uchar *ipadr) -{ - int fvalid = 1; - if (ipadr[0] == 0) fvalid = 0; - return(fvalid); -} - -int SubnetIsValid(uchar *subnet) -{ - int fvalid = 0; - /* if masking off at least one bit, say valid */ - if (subnet[0] != 0) fvalid = 1; - return(fvalid); -} - -int SubnetIsSame(uchar *ip1, uchar *ip2, uchar *subnet) -{ - int i; - uchar c1, c2; - for (i = 0; i < 4; i ++) { - c1 = ip1[i] & subnet[i]; - c2 = ip2[i] & subnet[i]; - if (c1 != c2) return 0; - } - return 1; /*same, return true*/ -} - -#ifdef WIN32 -/* - * Obtain network adapter information (Windows). - */ -PIP_ADAPTER_ADDRESSES GetAdapters() { - PIP_ADAPTER_ADDRESSES AdapterAddresses = NULL; - ULONG OutBufferLength = 0; - ULONG RetVal = 0, i; - - // The size of the buffer can be different - // between consecutive API calls. - // In most cases, i < 2 is sufficient; - // One call to get the size and one call to get the actual parameters. - // But if one more interface is added or addresses are added, - // the call again fails with BUFFER_OVERFLOW. - // So the number is picked slightly greater than 2. - // We use i <5 in the example - for (i = 0; i < 5; i++) { - RetVal = GetAdaptersAddresses( - AF_INET, 0, NULL, - AdapterAddresses, - &OutBufferLength); - - if (RetVal != ERROR_BUFFER_OVERFLOW) { - break; - } - - if (AdapterAddresses != NULL) { - free(AdapterAddresses); - } - - AdapterAddresses = (PIP_ADAPTER_ADDRESSES) malloc(OutBufferLength); - if (AdapterAddresses == NULL) { - RetVal = GetLastError(); - break; - } - } - if (RetVal == NO_ERROR) { - // If successful, return pointer to structure - return AdapterAddresses; - } - else { - LPVOID MsgBuf; - - printf("Call to GetAdaptersAddresses failed.\n"); - if (FormatMessage( - FORMAT_MESSAGE_ALLOCATE_BUFFER | - FORMAT_MESSAGE_FROM_SYSTEM | - FORMAT_MESSAGE_IGNORE_INSERTS, - NULL, - RetVal, - MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language - (LPTSTR) &MsgBuf, - 0, - NULL )) { - printf("\tError: %s", MsgBuf); - } - LocalFree(MsgBuf); - } - return NULL; -} - -/* - * Set BMC MAC corresponding to current BMC IP address (Windows). - */ -int GetLocalMACByIP() { - PIP_ADAPTER_ADDRESSES AdapterAddresses = NULL; - PIP_ADAPTER_ADDRESSES AdapterList; - int result = 0; - - struct sockaddr_in *si; - - AdapterAddresses = GetAdapters(); - AdapterList = AdapterAddresses; - - while (AdapterList) { - PIP_ADAPTER_UNICAST_ADDRESS addr; - addr = AdapterList->FirstUnicastAddress; - if (addr == NULL) si = NULL; - else si = (struct sockaddr_in*)addr->Address.lpSockaddr; - if (si != NULL) { - if(memcmp(&si->sin_addr.s_addr, rgmyip, 4) == 0) { - if (!MacIsValid(rgmymac)) - memcpy(rgmymac, AdapterList->PhysicalAddress, MAC_LEN); - memcpy(osmyip, &si->sin_addr.s_addr, 4); - memcpy(osmymac, AdapterList->PhysicalAddress, MAC_LEN); - wcstombs(ifname,AdapterList->FriendlyName, sizeof(ifname)); - result = 1; - break; - } - } - AdapterList = AdapterList->Next; - } - - if (AdapterAddresses != NULL) { - free(AdapterAddresses); - } - return result; -} - -/* - * Get First IP Address in Windows OS - * ipaddr is 4 bytes, macaddr is 6 bytes, ipname can be 64 bytes. - * (called by idiscover.c) - */ -int GetFirstIP(uchar *ipaddr, uchar *macadr, char *ipname, char fdbg) -{ - PIP_ADAPTER_ADDRESSES AdapterAddresses = NULL; - PIP_ADAPTER_ADDRESSES AdapterList; - struct sockaddr_in *si; - uchar *psaddr; - int result = -1; - - AdapterAddresses = GetAdapters(); - AdapterList = AdapterAddresses; - - while (AdapterList) { - PIP_ADAPTER_UNICAST_ADDRESS addr; - - addr = AdapterList->FirstUnicastAddress; - si = (struct sockaddr_in*)addr->Address.lpSockaddr; - psaddr = (uchar *)&si->sin_addr.s_addr; - if ((psaddr[0] != 0) && (psaddr[0] != 169)) { - if (fdbg) printf("found IP: s_addr=%d.%d.%d.%d\n", - psaddr[0], psaddr[1], psaddr[2], psaddr[3]); - if (ipaddr != NULL) - memcpy(ipaddr, &si->sin_addr.s_addr, 4); - if (macadr != NULL) { - memcpy(macadr, AdapterList->PhysicalAddress, MAC_LEN); - if (fdbg) printf("found MAC: %02x:%02x:%02x:%02x:%02x:%02x\n", - macadr[0], macadr[1], macadr[2], macadr[3], - macadr[4], macadr[5]); - } - if (ipname != NULL) { - wcstombs(ipname,AdapterList->FriendlyName, sizeof(ifname)); - if (fdbg) printf("found Adapter: %d\n",ipname); - } - result = 0; - break; - } - AdapterList = AdapterList->Next; - } - - if (AdapterAddresses != NULL) { - free(AdapterAddresses); - } - return result; -} - -/* - * Set BMC MAC corresponding to current BMC IP address (Windows). - */ -int GetLocalIPByMAC(uchar *macadr) { - PIP_ADAPTER_ADDRESSES AdapterAddresses = NULL; - PIP_ADAPTER_ADDRESSES AdapterList; - int result = 0; - - struct sockaddr_in *si; - - AdapterAddresses = GetAdapters(); - AdapterList = AdapterAddresses; - - while (AdapterList) { - PIP_ADAPTER_UNICAST_ADDRESS addr; - if(memcmp(AdapterList->PhysicalAddress, macadr, MAC_LEN) == 0) { - addr = AdapterList->FirstUnicastAddress; - - si = (struct sockaddr_in*)addr->Address.lpSockaddr; - if (fdebug) { - uchar *psaddr; - psaddr = (uchar *)&si->sin_addr.s_addr; - printf("mac match: rgmyip=%d.%d.%d.%d s_addr=%d.%d.%d.%d\n", - rgmyip[0], rgmyip[1], rgmyip[2], rgmyip[3], - psaddr[0], psaddr[1], psaddr[2], psaddr[3]); - } - if (!IpIsValid(rgmyip) && (fsharedMAC==1)) /*not specified, shared*/ - memcpy(rgmyip, &si->sin_addr.s_addr, 4); - memcpy(osmyip, &si->sin_addr.s_addr, 4); - memcpy(osmymac, AdapterList->PhysicalAddress, MAC_LEN); - wcstombs(ifname,AdapterList->FriendlyName, sizeof(ifname)); - result = 1; - break; - } - AdapterList = AdapterList->Next; - } - - if (AdapterAddresses != NULL) { - free(AdapterAddresses); - } - return result; -} -/* - * Set MAC and IP address from given interface name (Windows). - */ -int GetLocalDataByIface() { - PIP_ADAPTER_ADDRESSES AdapterAddresses = NULL; - PIP_ADAPTER_ADDRESSES AdapterList; - int result = 0; - - size_t origsize, newsize, convertedChars; - wchar_t* wcstring; - struct sockaddr_in *si; - - AdapterAddresses = GetAdapters(); - AdapterList = AdapterAddresses; - - origsize = strlen(ifname) + 1; - newsize = origsize; - convertedChars = 0; - wcstring = (wchar_t*) malloc(sizeof(wchar_t) * newsize) ; - if (wcstring == NULL) AdapterList = NULL; /*skip loop, do free*/ - else mbstowcs(wcstring, ifname, origsize ); - - while (AdapterList) { - PIP_ADAPTER_UNICAST_ADDRESS addr; - if(wcsstr(AdapterList->FriendlyName, wcstring)) { - printf("Using interface: %S\n", AdapterList->FriendlyName); - printf("\t%S\n", AdapterList->Description); - addr = AdapterList->FirstUnicastAddress; - - si = (struct sockaddr_in*)addr->Address.lpSockaddr; - if (fdebug) { - uchar *psaddr; - psaddr = (uchar *)&si->sin_addr.s_addr; - printf("mac match: rgmyip=%d.%d.%d.%d s_addr=%d.%d.%d.%d " - "fsharedMAC=%d\n", - rgmyip[0], rgmyip[1], rgmyip[2], rgmyip[3], - psaddr[0], psaddr[1], psaddr[2], psaddr[3], - fsharedMAC); - } - if (!IpIsValid(rgmyip)) { /*IP not specified*/ - memcpy(rgmyip, &si->sin_addr.s_addr, 4); - memcpy(rgmymac, AdapterList->PhysicalAddress, MAC_LEN); - } - memcpy(osmyip, &si->sin_addr.s_addr, 4); - memcpy(osmymac, AdapterList->PhysicalAddress, MAC_LEN); - /* FriendlyName == ifname already */ - result = 1; - break; - } - AdapterList = AdapterList->Next; - } - - if (AdapterAddresses != NULL) { - free(AdapterAddresses); - } - return result; -} - -int FindEthNum(uchar *macadrin) -{ - int i; - uchar macadr[MAC_LEN]; - memcpy(macadr,macadrin,MAC_LEN); - if (fsharedMAC == 0 && vend_id == VENDOR_INTEL) { - /* Intel factory assigns them this way, so use that to compare */ - macadr[MAC_LEN-1] -= 2; /*OS MAC = BMC MAC - 2*/ - } - i = GetLocalIPByMAC(macadr); - if (i == 1) fethfound = 1; - if (fdebug) /* show the local OS eth if and MAC */ - printf("FindEth: OS %s IP=%d.%d.%d.%d MAC=%02x:%02x:%02x:%02x:%02x:%02x\n", - ifname, osmyip[0], osmyip[1], osmyip[2], osmyip[3], - osmymac[0], osmymac[1], osmymac[2], osmymac[3], - osmymac[4], osmymac[5]); - /* The actual Windows ethernet interface is determined - * in Get_IPMac_Addr using ipconfig, so - * init eth interface number as eth0 for Windows. */ - return(0); -} -#elif defined(HPUX) -#define INSAP 22 -#define OUTSAP 24 - -#include <sys/types.h> -#include <fcntl.h> -#include <errno.h> -#include <stdio.h> -#include <string.h> -#include <signal.h> -#include <ctype.h> -#include <sys/stropts.h> -#include <sys/poll.h> -#include <sys/dlpi.h> - -#define bcopy(source, destination, length) memcpy(destination, source, length) -#define AREA_SZ 5000 /*=* buffer length in bytes *=*/ -#define GOT_CTRL 1 -#define GOT_DATA 2 -#define GOT_BOTH 3 -#define GOT_INTR 4 -#define GOT_ERR 128 -static u_long ctl_area[AREA_SZ]; -static u_long dat_area[AREA_SZ]; -static struct strbuf ctl = {AREA_SZ, 0, (char *)ctl_area}; -static struct strbuf dat = {AREA_SZ, 0, (char *)dat_area}; -static char *dlpi_dev[] = {"/dev/dlpi", ""}; - -/*=* get a message from a stream; return type of message *=*/ -static int get_msg(int fd) -{ - int flags = 0; - int res, ret; - ctl_area[0] = 0; - dat_area[0] = 0; - ret = 0; - res = getmsg(fd, &ctl, &dat, &flags); - if(res < 0) { - if(errno == EINTR) { - return(GOT_INTR); - } else { - return(GOT_ERR); - } - } - if(ctl.len > 0) { - ret |= GOT_CTRL; - } - if(dat.len > 0) { - ret |= GOT_DATA; - } - return(ret); -} - -/*=* verify that dl_primitive in ctl_area = prim *=*/ -static int check_ctrl(int prim) -{ - dl_error_ack_t *err_ack = (dl_error_ack_t *)ctl_area; - if(err_ack->dl_primitive != prim) { - return GOT_ERR; - } - return 0; -} - -/*=* put a control message on a stream *=*/ -static int put_ctrl(int fd, int len, int pri) -{ - ctl.len = len; - if(putmsg(fd, &ctl, 0, pri) < 0) { - return GOT_ERR; - } - return 0; -} - -/*=* put a control + data message on a stream *=*/ -static int put_both(int fd, int clen, int dlen, int pri) -{ - ctl.len = clen; - dat.len = dlen; - if(putmsg(fd, &ctl, &dat, pri) < 0) { - return GOT_ERR; - } - return 0; -} - -/*=* open file descriptor and attach *=*/ -static int dl_open(const char *dev, int ppa, int *fd) -{ - dl_attach_req_t *attach_req = (dl_attach_req_t *)ctl_area; - if((*fd = open(dev, O_RDWR)) == -1) { - return GOT_ERR; - } - attach_req->dl_primitive = DL_ATTACH_REQ; - attach_req->dl_ppa = ppa; - put_ctrl(*fd, sizeof(dl_attach_req_t), 0); - get_msg(*fd); - return check_ctrl(DL_OK_ACK); -} - -/*=* send DL_BIND_REQ *=*/ -static int dl_bind(int fd, int sap, u_char *addr) -{ - dl_bind_req_t *bind_req = (dl_bind_req_t *)ctl_area; - dl_bind_ack_t *bind_ack = (dl_bind_ack_t *)ctl_area; - bind_req->dl_primitive = DL_BIND_REQ; - bind_req->dl_sap = sap; - bind_req->dl_max_conind = 1; - bind_req->dl_service_mode = DL_CLDLS; - bind_req->dl_conn_mgmt = 0; - bind_req->dl_xidtest_flg = 0; - put_ctrl(fd, sizeof(dl_bind_req_t), 0); - get_msg(fd); - if (GOT_ERR == check_ctrl(DL_BIND_ACK)) { - return GOT_ERR; - } - bcopy((u_char *)bind_ack + bind_ack->dl_addr_offset, addr, - bind_ack->dl_addr_length); - return 0; -} - -int FindEthNum(uchar *addr) -{ /* Need to use DLPI for HPUX */ - /*See http://cplus.kompf.de/artikel/macaddr.html */ - int fd; - int ppa; - u_char mac_addr[25]; - char **dev; - int i = 0; - - for (dev = dlpi_dev; **dev != ''; ++dev) { - for (ppa=0; ppa<10; ++ppa) { - if (GOT_ERR != dl_open(*dev, ppa, &fd)) { - if (GOT_ERR != dl_bind(fd, INSAP, mac_addr)) { - // bcopy( mac_addr, addr, 6); - i = ppa; - if (memcmp(mac_addr,addr,MAC_LEN) == 0) { - memcpy(osmymac, addr, MAC_LEN); - return(ppa); - } - } - } - close(fd); - } - } - return(i); -} -#else - -static char *get_ifreq_mac(struct ifreq *ifrq) -{ - char *ptr; -#ifdef SOLARIS - ptr = (char *)&ifrq->ifr_ifru.ifru_enaddr[0]; -#elif BSD - ptr = (char *)&ifrq->ifr_ifru.ifru_addr.sa_data[0]; -#elif MACOS - static uchar mactmp[MAC_LEN]; - ptr = &mactmp[0]; - MacSetInvalid(ptr); -#else - ptr = (char *)&ifrq->ifr_hwaddr.sa_data[0]; -#endif - return (ptr); -} - -extern int find_ifname(char *ifname); /*see idiscover.c*/ - -int FindEthNum(uchar *macadrin) -{ /*only used for Linux*/ - struct ifreq ifr; - int skfd; - int nCurDevice; - int devnum = -1; - int devos = 0; - uchar macadr[MAC_LEN]; - uchar macsav[MAC_LEN]; - uchar mactmp[MAC_LEN]; - uchar ipsav[4]; - char szDeviceName[ 16 ]; /* MAX_DEVICE_NAME_LENGTH + 1 */ - uchar fipvalid = 0; - int n; - - memcpy(macadr,macadrin,MAC_LEN); - if (fsharedMAC == 0 && vend_id == VENDOR_INTEL) { - /* Intel factory assigns them this way, so use that to compare */ - macadr[MAC_LEN-1] -= 2; /*OS MAC = BMC MAC - 2*/ - } -#ifdef DBG - if (fdebug) { - uchar *pb; - pb = macadrin; - printf("input mac:%02x:%02x:%02x:%02x:%02x:%02x " - "tmp mac:%02x:%02x:%02x:%02x:%02x:%02x\n", - pb[0],pb[1],pb[2],pb[3],pb[4],pb[5], - macadr[0],macadr[1],macadr[2],macadr[3],macadr[4],macadr[5]); - } -#endif - - n = find_ifname(szDeviceName); - if (n >= 0) { - n = strlen_(szDeviceName); - if (n < sizeof(ifpattn)) { - strcpy(ifpattn,szDeviceName); - ifpattn[n - 1] = 0; /*truncate last digit*/ - } - if (fdebug) - printf("found ifname %s, pattern %s\n",szDeviceName,ifpattn); - } - - if ( ( skfd = socket(AF_INET, SOCK_DGRAM, 0 ) ) < 0) { - if ( fdebug ) { - perror("socket"); - return devnum; - } - } - - for( nCurDevice = 0 ; - (nCurDevice < NUM_DEVICES_TO_CHECK) && (devnum == -1); - nCurDevice++ ) - { - sprintf( szDeviceName, "%s%d", ifpattn, nCurDevice ); /*eth%d*/ - memset((char *)&ifr,0,sizeof(ifr)); - strcpy(ifr.ifr_name, szDeviceName ); -#ifdef SIOCGIFHWADDR - if (ioctl(skfd, SIOCGIFHWADDR, &ifr) > 0) { - if ( fdebug ) - printf("FindEthNum: Could not get MAC address for %s\n", - szDeviceName); - } else -#endif - { - uchar *pb; - pb = (uchar *)get_ifreq_mac(&ifr); -#ifdef DBG - if (fdebug) { - printf("%s mac: %02x:%02x:%02x:%02x:%02x:%02x\n", - szDeviceName, pb[0],pb[1],pb[2],pb[3],pb[4],pb[5]); - } -#endif - memcpy(macsav, pb, MAC_LEN); - /* check if this device is configured for IP addr */ - memset((char *)&ifr,0,sizeof(ifr)); - strcpy(ifr.ifr_name, szDeviceName); - ifr.ifr_addr.sa_family = AF_INET; - if (ioctl(skfd, SIOCGIFADDR, &ifr) >= 0) { - fipvalid = 1; - memcpy(ipsav, &ifr.ifr_addr.sa_data[2], 4); - } else fipvalid = 0; - if (memcmp(macsav, macadr, MAC_LEN) == 0) { /*found match*/ - devnum = nCurDevice; - memcpy(osmymac, macsav, MAC_LEN); - if (fipvalid) memcpy(osmyip, ipsav, 4); - break; - } - if (nCurDevice == 0) { /*set a default of eth0*/ - devos = nCurDevice; - memcpy(osmymac,macsav, MAC_LEN); - if (fipvalid) memcpy(osmyip, ipsav, 4); - } else if (fipvalid) { /*check if NIC1 is eth1,2,3,...*/ - memcpy(mactmp,osmymac,MAC_LEN); - mactmp[MAC_LEN-1] -= 1; - if (memcmp(mactmp,macsav,MAC_LEN) == 0) { - devos = nCurDevice; - memcpy(osmymac, macsav, MAC_LEN); - memcpy(osmyip, ipsav, 4); - } - } - } /*end else*/ - } - if (!fsetifn) { - if (devnum == -1) { /*not found, use devos default*/ - devnum = devos; - sprintf( ifname, "%s%d", ifpattn, devnum ); /*eth%d*/ - } else { /* match was found, devnum set */ - fethfound = 1; - strcpy(ifname, szDeviceName ); - } - } - close(skfd); - if (fdebug) /* show the local OS eth if and MAC */ - printf("FindEth: OS %s IP=%d.%d.%d.%d MAC=%02x:%02x:%02x:%02x:%02x:%02x\n", - ifname, osmyip[0], osmyip[1], osmyip[2], osmyip[3], - osmymac[0], osmymac[1], osmymac[2], osmymac[3], - osmymac[4], osmymac[5]); - return(devnum); -} -#endif - -int show_channels(void) -{ - int ret, rlen; - uchar iData[2]; - uchar rData[10]; - uchar cc, mtype; - int j; - int rv = -1; - - for (j = 1; j < MAXCHAN; j++) { - rlen = sizeof(rData); - iData[0] = (uchar)j; /*channel #*/ - memset(rData,0,9); /*initialize recv data*/ - ret = ipmi_cmd(GET_CHANNEL_INFO, iData, 1, rData, &rlen, &cc, fdebug); - if (rv != 0) rv = ret; - if (ret == 0xcc || cc == 0xcc) /* special case for ipmi_lan */ - continue; - if (ret != 0) { - if (fdebug) printf("get_chan_info rc = %x\n",ret); - break; - } - mtype = rData[1]; /* channel medium type */ - switch(mtype) { - case 4: printf("channel[%d] type = lan\n",j); break; /*802.3 LAN type*/ - case 5: printf("channel[%d] type = serial\n",j); break; - case 7: printf("channel[%d] type = pci_smbus\n",j); break; - case 12: printf("channel[%d] type = system_interface\n",j); break; - default: printf("channel[%d] type = other %d\n",j,mtype); break; - } - rv = 0; - } /*end for j*/ - return(rv); -} - -/* - * GetBmcEthDevice - * Attempt to auto-detect the BMC LAN channel and matching OS eth port. - * INPUT: lan_parm = lan channel from user -L option, 0xFF if not specified - * OUTPUT: lan_ch is set to BMC LAN channel number - * if success, returns index of OS eth port (0, 1, ...). - * if no lan channels found, returns -2. - * if other error, returns -1. - */ -int GetBmcEthDevice(uchar lan_parm, uchar *pchan) -{ - LAN_RECORD LanRecord; - int devnum = -1; - int ret; - uchar bmcMacAddress[ MAC_LEN ]; /*MAC_LEN = 6*/ - int rlen; - uchar iData[2]; - uchar rData[10]; - uchar cc; - int i = 0; - int j, jstart, jend, jlan; - uchar mtype; - uchar *pb; - int fchgmac; - // int found = 0; - - /* Find the LAN channel(s) via Channel Info */ - if (lan_parm < MAXCHAN) { /* try user-specified channel only */ - lan_ch = lan_parm; - jstart = lan_parm; - jend = lan_parm+1; - } else { - jstart = 1; - jend = MAXCHAN; - } - memset(bmcMacAddress,0xff,sizeof(bmcMacAddress)); /*initialize to invalid*/ - for (j = jstart; j < jend; j++) { - rlen = sizeof(rData); - iData[0] = (uchar)j; /*channel #*/ - memset(rData,0,9); /*initialize recv data*/ - ret = ipmi_cmd(GET_CHANNEL_INFO, iData, 1, rData, &rlen, &cc, fdebug); - if (ret == 0xcc || cc == 0xcc) /* special case for ipmi_lan */ - continue; - if (ret != 0) { - if (fdebug) printf("get_chan_info rc = %x\n",ret); - break; - } - mtype = rData[1]; /* channel medium type */ - if (mtype == 4) { /* 802.3 LAN type*/ - if (fdebug) printf("chan[%d] = lan\n",j); - jlan = lan_ch; /*save prev lan chan */ - /* Get BMC MAC for this LAN channel. */ - /* Note: BMC MAC may not be valid yet. */ - lan_ch = (uchar)j; /*set lan channel for GetLanEntry*/ - ret = GetLanEntry( 5 /*MAC_ADDRESS_LAN_PARAM*/,0, &LanRecord); - if ( ret != 0 ) { - lan_ch = (uchar)jlan; /*restore lan_ch*/ - printf( "GetBmcEthDevice: GetLanEntry failed\n" ); - return devnum; - } else { - pb = &LanRecord.data[0]; - if (fdebug) printf("chan[%d] BMC MAC %x:%x:%x:%x:%x:%x\n",j, - pb[0], pb[1], pb[2], pb[3], pb[4], pb[5] ); - fchgmac = 0; - /* use the lowest valid lan channel MAC address */ - if (!MacIsValid(bmcMacAddress)) /* old MAC not valid*/ - fchgmac = 1; - else if (MacIsValid(pb) && /* new MAC is valid and*/ - (memcmp(bmcMacAddress,pb, sizeof(bmcMacAddress)) > 0)) - fchgmac = 1; /* new MAC lower */ - /* if no -L 3 and this is gcm, do not pick it. */ - if ((j == gcm_ch) && (lan_parm == PARM_INIT)) - fchgmac = 0; - if (fchgmac) { /* pick this channel & MAC */ - memcpy(bmcMacAddress,pb,sizeof(bmcMacAddress)); - lan_ch = (uchar)j; - } else lan_ch = (uchar)jlan; /*restore prev lan chan*/ - } - i++; /* i = num lan channels found */ - } else if (mtype == 5) { /* serial type*/ - if (fdebug) printf("chan[%d] = serial\n",j); - ser_ch = (uchar)j; /* set to last serial channel */ - } else if (mtype == 7) { /* PCI SMBus */ - if (fdebug) printf("chan[%d] = pci_smbus\n",j); - } else if (mtype == 12) { /* system interface */ - if (fdebug) printf("chan[%d] = system_interface\n",j); - } else if (mtype == 1) { /* IPMB */ - if (fdebug) printf("chan[%d] = IPMB\n",j); - } else /* other channel medium types, see IPMI 1.5 Table 6-3 */ - if (fdebug) printf("chan[%d] = %d\n",j,mtype); - } - if (i == 0) return(-2); /* no lan channels found */ - if (fdebug) printf("lan_ch detected = %d\n",lan_ch); - - /* This will work if the BMC MAC is shared with the OS */ - /* Otherwise, wait until we get the eth dev from the gateway below */ - devnum = FindEthNum(bmcMacAddress); - if ( fdebug ) - printf("GetBmcEthDevice: channel %d, %s%d\n",lan_ch,ifpattn,devnum); - if (pchan != NULL) *pchan = lan_ch; - return devnum; -} - -/* file_grep/findmatch - No longer used here, see ievents.c */ - -/* - * Get_Mac - * This routine finds a MAC address from a given IP address. - * Usually for the Alert destination. - * It uses ARP cache to do this. - */ -#if defined(WIN32) -int Get_Mac(uchar *ipadr,uchar *macadr, char *nodname) -{ - DWORD dwRetVal; - IPAddr DestIp = 0; - IPAddr SrcIp = 0; /* default for src ip */ - ULONG MacAddr[2]; /* for 6-byte hardware addresses */ - ULONG PhysAddrLen = MAC_LEN; /* default to length of six bytes */ - BYTE *bPhysAddr; - - if (!IpIsValid(ipadr)) { - if (fdebug) printf("Get_Mac: invalid IP addr\n"); - return 1; /*error*/ - } - memcpy(&DestIp, ipadr, 4); - - /* invoke system ARP query */ - dwRetVal = SendARP(DestIp, SrcIp, MacAddr, &PhysAddrLen); - - if (dwRetVal == NO_ERROR) - { /* no error - get the MAC */ - bPhysAddr = (BYTE *) & MacAddr; - if (PhysAddrLen) { - memcpy(macadr, bPhysAddr, MAC_LEN); - } else - printf("Warning: SendArp completed successfully, but returned length=0\n"); - } else if (dwRetVal == ERROR_GEN_FAILURE) - { /* MAC not available in this network - get gateway MAC */ - memcpy(macadr, rggwymac, MAC_LEN); - } else - { /* other errors */ - printf("Error: SendArp failed with error: %d", dwRetVal); - switch (dwRetVal) { - case ERROR_INVALID_PARAMETER: - printf(" (ERROR_INVALID_PARAMETER)\n"); - break; - case ERROR_INVALID_USER_BUFFER: - printf(" (ERROR_INVALID_USER_BUFFER)\n"); - break; - case ERROR_BAD_NET_NAME: - printf(" (ERROR_GEN_FAILURE)\n"); - break; - case ERROR_BUFFER_OVERFLOW: - printf(" (ERROR_BUFFER_OVERFLOW)\n"); - break; - case ERROR_NOT_FOUND: - printf(" (ERROR_NOT_FOUND)\n"); - break; - default: - printf("\n"); - break; - } - return 1; - } - return 0; -} /* end Get_Mac() for WIN32*/ -#elif defined(SOLARIS) -int Get_Mac(uchar *ipadr,uchar *macadr, char *nodename) -{ - FILE *fparp; - char buff[1024]; - /* char arpfile[] = "/proc/net/arp"; */ - char alertfile[] = "/tmp/dest.arping"; - char arping_cmd[128]; - char *pb, *pm; - int num, i; - int foundit = 0; - int ret = 0; - - if (IpIsValid(ipadr)) { /* if valid IP address */ - sprintf(arping_cmd, - "ping %d.%d.%d.%d >/dev/null; arp -a -n |grep %d.%d.%d.%d >%s\n", - ipadr[0],ipadr[1],ipadr[2],ipadr[3], - ipadr[0],ipadr[1],ipadr[2],ipadr[3], alertfile); - } else if (nodename != NULL) { /*if valid nodename */ - sprintf(arping_cmd, - "ping %s >/dev/null; arp -a |grep %s >%s\n", - nodename,nodename,alertfile); - } else ret = -1; - - if (ret == 0) { /* if valid IP address */ - /* make sure the destination is in the arp cache */ - if (fdebug) printf("%s", arping_cmd); - system(arping_cmd); - - fparp = fopen(alertfile,"r"); - if (fparp == NULL) { - fprintf(stdout,"Get_Mac: Cannot open %s, errno = %d\n", - alertfile,get_errno()); - ret = -1; - } else { - /* sample output: */ - /* e1000g0 cooper9 255.255.255.255 o 00:07:e9:06:55:c8 */ - while (fgets(buff, 1023, fparp)) { - /* should only run through loop once */ - num = strcspn(buff," \t"); /* skip 1st word ("e1000g0") */ - i = strspn(&buff[num]," \t"); /* skip whitespace */ - pb = &buff[num+i]; - num = strcspn(pb," \t"); /* skip 2nd word (nodename/IP) */ - i = strspn(&pb[num]," \t"); /* skip whitespace */ - pb += (num+i); - pm = &pb[25]; /* Now pb[25] has the MAC address */ - { /*validate new address?*/ - if (fdebug) printf("Get_Mac: mac=%s\n",pm); - foundit = 1; - if (!MacIsValid(macadr)) atomac(macadr,pm); - break; - } - } /*end while*/ - fclose(fparp); - } /*end else file opened*/ - } /*endif valid IP */ - - if (foundit == 0) { /* no errors, but no mac reply */ - if (MacIsValid(rggwymac) && !MacIsValid(macadr)) - /* this is useful if the ipadr is not in the local subnet */ - memcpy(macadr,rggwymac,6); /* get to it from the default gateway */ - } - return(ret); -} /*end Get_Mac for Solaris*/ -#elif defined(BSD) -int Get_Mac(uchar *ipadr,uchar *macadr, char *nodename) -{ - FILE *fparp; - char buff[1024]; - /* char arpfile[] = "/proc/net/arp"; */ - char alertfile[] = "/tmp/dest.arping"; - char arping_cmd[128]; - char *pb, *pm; - int num, i, j; - int foundit = 0; - int ret = 0; - - if (IpIsValid(ipadr)) { /* if valid IP address */ - sprintf(arping_cmd, - "ping -c2 %d.%d.%d.%d >/dev/null; arp -a -n |grep %d.%d.%d.%d >%s\n", - ipadr[0],ipadr[1],ipadr[2],ipadr[3], - ipadr[0],ipadr[1],ipadr[2],ipadr[3], alertfile); - } else if (nodename != NULL) { /*if valid nodename */ - sprintf(arping_cmd, - "ping -c2 %s >/dev/null; arp -a |grep %s >%s\n", - nodename,nodename,alertfile); - } else ret = -1; - - if (ret == 0) { /* if valid IP address */ - /* make sure the destination is in the arp cache */ - if (fdebug) printf("%s", arping_cmd); - system(arping_cmd); - - fparp = fopen(alertfile,"r"); - if (fparp == NULL) { - fprintf(stdout,"Get_Mac: Cannot open %s, errno = %d\n", - alertfile,get_errno()); - ret = -1; - } else { - /* sample output of arp -a -n: */ - /* ? (192.168.1.200) at 00:0e:0c:e5:df:65 on em0 [ethernet] */ - /* sample output of arp -a: */ - /* telcoserv (192.168.1.200) at 00:0e:0c:e5:df:65 on em0 [ethernet] */ - while (fgets(buff, 1023, fparp)) { - /* should only run through loop once */ - pb = &buff[0]; - for (j = 0; j < 3; j++) { /* skip 3 words */ - num = strcspn(pb," \t"); /* skip jth word */ - i = strspn(&pb[num]," \t"); /* skip whitespace */ - pb += (num+i); - } - pm = &pb[0]; /* Now pb[0] has the MAC address */ - { /* no need to validate new address*/ - if (fdebug) printf("Get_Mac: mac=%s\n",pm); - foundit = 1; - if (!MacIsValid(macadr)) atomac(macadr,pm); - break; - } - } /*end while*/ - fclose(fparp); - } /*end else file opened*/ - } /*endif valid IP */ - - if (foundit == 0) { /* no errors, but no mac reply */ - if (MacIsValid(rggwymac) && !MacIsValid(macadr)) - /* this is useful if the ipadr is not in the local subnet */ - memcpy(macadr,rggwymac,6); /* get to it from the default gateway */ - } - return(ret); -} /*end Get_Mac for BSD */ -#else -int Get_Mac(uchar *ipadr,uchar *macadr, char *nodename) -{ /* Get_Mac for Linux */ - FILE *fparp; - char buff[1024]; - /* char arpfile[] = "/proc/net/arp"; */ - char alertfile[] = "/tmp/dest.arping"; - char arping_cmd[128]; - char *pb, *pm, *px; - int num, i; - int foundit = 0; - int ret = 0; - char *_ifname; - - if (strcmp(ifname,"gcm") == 0) _ifname = ifname0; /*see gcm_ch instead*/ - else _ifname = ifname; - - /* Get a MAC address for a given IP address or nodename */ - if (IpIsValid(ipadr)) { /* if valid IP address */ - sprintf(arping_cmd, - "arping -I %s -c 2 %d.%d.%d.%d |grep reply |tail -n1 >%s\n", - _ifname,ipadr[0],ipadr[1],ipadr[2],ipadr[3],alertfile); - } else if (nodename != NULL) { /*if valid nodename */ - sprintf(arping_cmd, - "arping -I %s -c 2 %s |grep reply |tail -n1 >%s\n", - _ifname,nodename,alertfile); - } else ret = -1; - - if (ret == 0) { /* if valid IP address */ - /* make sure the destination is in the arp cache */ - if (fdebug) printf("%s", arping_cmd); - ret = system(arping_cmd); - - fparp = fopen(alertfile,"r"); - if (fparp == NULL) { - fprintf(stdout,"Get_Mac: Cannot open %s, errno = %d\n", - alertfile,get_errno()); - ret = -1; - } else { - ret = 0; - while (fgets(buff, 1023, fparp)) { - /* should only run through loop once */ - num = strcspn(buff," \t"); /* skip 1st word ("Unicast") */ - i = strspn(&buff[num]," \t"); - pb = &buff[num+i]; - if (strncmp(pb,"reply",5) == 0) { /* valid output */ - /* Find the ip address */ - pb += 6 + 5; /* skip "reply from " */ - num = strcspn(pb," \t"); - pb[num] = 0; - if (fdebug) printf("Get_Mac: ip=%s\n",pb); - /* IP address should already match input param */ - if (!IpIsValid(ipadr)) /* had nodname only*/ - atoip(ipadr,pb); /* fill in ipadr */ - /* Now find the mac address */ - pm = strchr(&pb[num+1],'['); - if (pm == NULL) pm = &pb[num+2]; /* just in case */ - pm++; - px = strchr(pm,']'); - if (px == NULL) px = pm + 17; /* just in case */ - px[0] = 0; - if (fdebug) printf("Get_Mac: mac=%s\n",pm); - foundit = 1; - if (!MacIsValid(macadr)) atomac(macadr,pm); - break; - } - } /*end while*/ - fclose(fparp); - } /*end else file opened*/ - } /*endif valid IP */ - - if (foundit == 0) { /* no errors, but no mac reply */ - if (MacIsValid(rggwymac) && !MacIsValid(macadr)) - /* this is useful if the ipadr is not in the local subnet */ - memcpy(macadr,rggwymac,6); /* get to it from the default gateway */ - } - return(ret); -} /* end Get_Mac() for Linux*/ -#endif - -#ifdef WIN32 -/* - * Set subnet mask based on current IP address (Windows). - */ -int SetSubnetMask() { - PMIB_IPADDRTABLE pIPAddrTable; - unsigned int i; - DWORD dwSize = 0, dwRetVal; - LPVOID lpMsgBuf; - - pIPAddrTable = (MIB_IPADDRTABLE*) malloc( sizeof( MIB_IPADDRTABLE) ); - - if ( pIPAddrTable ) { - // Make an initial call to GetIpAddrTable to get the - // necessary size into the dwSize variable - if (GetIpAddrTable(pIPAddrTable, &dwSize, 0) == ERROR_INSUFFICIENT_BUFFER) { - free( pIPAddrTable ); - pIPAddrTable = (MIB_IPADDRTABLE *) malloc ( dwSize ); - } - } else - printf("Memory allocation failed.\n"); - - if ( pIPAddrTable ) { - // Make a second call to GetIpAddrTable to get the - // actual data we want - if ( (dwRetVal = GetIpAddrTable( pIPAddrTable, &dwSize, 0 )) == NO_ERROR ) { - for(i = 0; i < pIPAddrTable->dwNumEntries; ++i) { - if(memcmp(&(pIPAddrTable->table[i].dwAddr), rgmyip, 4) == 0) { - memcpy(rgsubnet, &(pIPAddrTable->table[i].dwMask), 4); - free( pIPAddrTable ); - return 1; - } - } - } else { - if (FormatMessage( - FORMAT_MESSAGE_ALLOCATE_BUFFER | - FORMAT_MESSAGE_FROM_SYSTEM | - FORMAT_MESSAGE_IGNORE_INSERTS, - NULL, - dwRetVal, - MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language - (LPTSTR) &lpMsgBuf, - 0, - NULL )) { - printf("\tError: %s", lpMsgBuf); - } - - printf("Call to GetIpAddrTable failed.\n"); - } - } - - if ( pIPAddrTable ) - free( pIPAddrTable ); - - return 0; -} - -/* - * Extract gateway address from routing table (Windows). - */ -int SetDefaultGateway() { - PMIB_IPFORWARDTABLE pIpForwardTable; - DWORD dwRetVal, dwSize; - - unsigned int nord_mask; - unsigned int nord_ip; - unsigned int nord_net; - - unsigned int i; - - nord_mask = *((unsigned int *)rgsubnet); - nord_ip = *((unsigned int *)rgmyip); - - nord_net = nord_ip & nord_mask; - - pIpForwardTable = (MIB_IPFORWARDTABLE*) malloc(sizeof(MIB_IPFORWARDTABLE)); - if (pIpForwardTable == NULL) { - printf("Error allocating memory\n"); - return 0; - } - - dwSize = 0; - if (GetIpForwardTable(pIpForwardTable, &dwSize, 0) == ERROR_INSUFFICIENT_BUFFER) { - free(pIpForwardTable); - pIpForwardTable = (MIB_IPFORWARDTABLE*) malloc(dwSize); - if (pIpForwardTable == NULL) { - printf("Error allocating memory\n"); - return 0; - } - } - - /* - * Note that the IPv4 addresses returned in - * GetIpForwardTable entries are in network byte order - */ - if ((dwRetVal = GetIpForwardTable(pIpForwardTable, &dwSize, 0)) == NO_ERROR) { - for (i = 0; i < (int) pIpForwardTable->dwNumEntries; i++) { - unsigned int gwaddr = pIpForwardTable->table[i].dwForwardNextHop; - if(nord_net == (gwaddr & nord_mask) && nord_ip != gwaddr) - { /* searching for gateways from our network with different address than ours */ - memcpy(rggwyip, &gwaddr, 4); - return 0; - } - } - free(pIpForwardTable); - return 1; - } - else { - printf("\tGetIpForwardTable failed.\n"); - free(pIpForwardTable); - return 0; - } - -} -/*endif WIN32*/ -#endif - -/* - * Get_IPMac_Addr - * This routine finds the IP and MAC for the local interface, - * the default gateway, and SNMP alert destination from the - * BMC and OS information. - * - * Linux snmpd.conf locations (see ipmiutil.spec): - * RedHat, MontaVista: /etc/snmp/snmpd.conf - * SuSE SLES 8: /etc/ucdsnmpd.conf - * SuSE SLES 9: /etc/snmpd.conf - */ -#ifdef WIN32 -int Get_IPMac_Addr() -{ /*for Windows*/ - char ipstr[] = "IP Address"; - char macstr[] = "Physical Address"; - char gwystr[] = "Default Gateway"; - char substr[] = "Subnet Mask"; - int found = 0; - char fgetmac; - - if (IpIsValid(rgmyip)) - { /* user-specified ip, get mac */ - if (fdebug) printf("User IP was specified\n"); - if (!MacIsValid(rgmymac)) - { /* no user-specified MAC, get it from IP */ - if (fdebug) printf("No user MAC specified\n"); - if(!GetLocalMACByIP()) - { /* couldn't get MAC from IP, get old one */ - if (fdebug) printf("No MAC from IP, use old\n"); - if(IpIsValid(bmcmyip) && MacIsValid(bmcmymac)) - { - printf("Using current BMC MAC %02x:%02x:%02x:%02x:%02x:%02x\n", - bmcmymac[0], bmcmymac[1], - bmcmymac[2], bmcmymac[3], - bmcmymac[4], bmcmymac[5]); - memcpy(rgmymac,bmcmymac,MAC_LEN); - } else { - printf("Failed to obtain valid MAC\n"); - } - } else { - printf("Using adapter MAC %02x:%02x:%02x:%02x:%02x:%02x\n", - rgmymac[0], rgmymac[1], - rgmymac[2], rgmymac[3], - rgmymac[4], rgmymac[5]); - } - } else { /* user MAC available */ - printf("Using user MAC %02x:%02x:%02x:%02x:%02x:%02x\n", - rgmymac[0], rgmymac[1], - rgmymac[2], rgmymac[3], - rgmymac[4], rgmymac[5]); - } - } else { /* no user-specified IP */ - if (fdebug) printf("No user IP specified\n"); - if (!MacIsValid(rgmymac)) - { /* no user-specified MAC, get it from interface */ - if(!GetLocalDataByIface()) - { /* use existing MAC an IP */ - printf("Using current BMC IP %d.%d.%d.%d\n", - bmcmyip[0], bmcmyip[1], - bmcmyip[2], bmcmyip[3]); - memcpy(rgmyip,bmcmyip,4); - printf("Using current BMC MAC %02x:%02x:%02x:%02x:%02x:%02x\n", - bmcmymac[0], bmcmymac[1], - bmcmymac[2], bmcmymac[3], - bmcmymac[4], bmcmymac[5]); - memcpy(rgmymac,bmcmymac,MAC_LEN); - - } - } else { /* user-specified MAC */ - if(!GetLocalIPByMAC(rgmymac)) - { /* use existing MAC and IP */ - printf("Using current BMC IP %d.%d.%d.%d\n", - bmcmyip[0], bmcmyip[1], - bmcmyip[2], bmcmyip[3]); - memcpy(rgmyip,bmcmyip,4); - printf("Using current BMC MAC %02x:%02x:%02x:%02x:%02x:%02x\n", - bmcmymac[0], bmcmymac[1], - bmcmymac[2], bmcmymac[3], - bmcmymac[4], bmcmymac[5]); - memcpy(rgmymac,bmcmymac,MAC_LEN); - } - } - } - - if (rghostname[0] == 0) { /*hostname not specified*/ - if (!fipmilan) - gethostname(rghostname,sizeof(rghostname)); - } - if (fdebug) /* show the local OS eth if and MAC */ - printf("OS %s IP=%d.%d.%d.%d %s MAC=%02x:%02x:%02x:%02x:%02x:%02x used for arp\n", - ifname, osmyip[0],osmyip[1],osmyip[2],osmyip[3], rghostname, - osmymac[0], osmymac[1], osmymac[2], osmymac[3], - osmymac[4], osmymac[5]); - - if(!SubnetIsValid(rgsubnet)) { - SetSubnetMask(); - } - if (!IpIsValid(rggwyip)) { /* if gwy ip not user-specified */ - SetDefaultGateway(); - } - - if (lan_ch == gcm_ch) { - if (SubnetIsSame(rgmyip,rggwyip,rgsubnet)) fgetmac = 1; - else fgetmac = 0; - } else fgetmac = 1; - - if (fgetmac) { - if (IpIsValid(rggwyip) && !MacIsValid(rggwymac)) /*gwy mac not specified*/ - Get_Mac(rggwyip,rggwymac,NULL); - - if (IpIsValid(rggwy2ip) && !MacIsValid(rggwy2mac)) /*gwy2 mac not valid*/ - Get_Mac(rggwy2ip,rggwy2mac,NULL); - } - - return(0); -} /* end Get_IPMac_Addr for Windows */ - -#elif defined(HPUX) -int Get_IPMac_Addr() -{ /*for HP-UX*/ - return(-1); -} -#else -int Get_IPMac_Addr() -{ /*for Linux*/ -#if defined(SOLARIS) - char rtfile[] = "/tmp/route"; - char snmpfile[] = "/etc/snmp/conf/snmpd.conf"; -#elif defined(BSD) - char rtfile[] = "/tmp/route"; - char snmpfile[] = "/etc/snmpd.config"; -#else - char rtfile[] = "/proc/net/route"; - char snmpfile[] = "/etc/snmp/snmpd.conf"; -#endif - // char alertfile[] = "/tmp/alert.arping"; - // FILE *fparp; - FILE *fprt; - int fd = -1; - int skfd; - uchar *pc; - int rc = 0; - int i,j; - uchar bnetadr[4]; - uchar bgateadr[4]; - char gate_addr[128]; - char iface[16]; - char defcommunity[19] = "public"; - char buff[1024]; - char alertname[60]; - int num, nmatch; - struct ifreq ifr; - char *_ifname; - char fgetmac; - - /* Get the IP address and associated MAC address specified. */ - /* Local for ethN; Default Gateway; Alert Destination */ - - /* Get the default gateway IP */ -#if defined(SOLARIS) || defined(BSD) - char rtcmd[80]; - sprintf(rtcmd,"netstat -r -n |grep default |awk '{ print $2 }' >%s",rtfile); - system(rtcmd); - /* use rtfile output from netstat -r, see also /etc/defaultroute */ - fprt = fopen(rtfile,"r"); - if (fprt == NULL) { - fprintf(stdout,"netstat: Cannot open %s, errno = %d\n",rtfile,get_errno()); - } else { - while (fgets(buff, 1023, fprt)) { - if ((buff[0] > '0') && (buff[0] <= '9')) { /*valid*/ - atoip(bgateadr,buff); - if (fdebug) - printf("default gateway: %s, %d.%d.%d.%d %s\n",buff, - bgateadr[0], bgateadr[1], bgateadr[2], bgateadr[3],ifname); - if (!IpIsValid(rggwyip)) /* if not user-specified */ - memcpy(rggwyip,bgateadr,4); - break; - } - } - fclose(fprt); - } /*end-else good open */ -#else - /* cat /proc/net/route and save Gwy if Dest == 0 and Gateway != 0 */ - fprt = fopen(rtfile,"r"); - if (fprt == NULL) { - fprintf(stdout,"route: Cannot open %s, errno = %d\n",rtfile,get_errno()); - } else { - char rtfmt[] = "%16s %128s %128s %X %d %d %d %128s %d %d %d\n"; - int iflags, refcnt, use, metric, mss, window, irtt; - char mask_addr[128], net_addr[128]; - uint *pnet; - uint *pgate; - - pnet = (uint *)&bnetadr[0]; - pgate = (uint *)&bgateadr[0]; - while (fgets(buff, 1023, fprt)) { - num = sscanf(buff, rtfmt, - iface, net_addr, gate_addr, - &iflags, &refcnt, &use, &metric, mask_addr, - &mss, &window, &irtt); - if (num < 10 || !(iflags & RTF_UP)) - continue; - - j = 6; - for (i = 0; i < 4; i ++) { - bnetadr[i] = htoi(&net_addr[j]); - bgateadr[i] = htoi(&gate_addr[j]); - j -= 2; - } - if ((*pnet == 0) && (*pgate != 0)) { /* found default gateway */ - if (fdebug) - printf("default gateway: %s, %d.%d.%d.%d %s\n",gate_addr, - bgateadr[0], bgateadr[1], bgateadr[2], bgateadr[3],iface); - if (!IpIsValid(rggwyip)) /* if not user-specified */ - memcpy(rggwyip,bgateadr,4); - _ifname = iface; /*use this iface for gwy mac */ - if (!fsetifn) strncpy(ifname,iface,16); - break; - } - } /*end while*/ - fclose(fprt); - } /*end-else good open */ -#endif - - /* Create a channel to the NET kernel. */ - if ((skfd = socket(AF_INET, SOCK_DGRAM, 0)) < 0) { - perror("socket"); - return(-3); - } - - /* Find a valid local BMC MAC Address */ - if (lan_ch == gcm_ch) { - /* GCM has its own unique mac address */ - if (!MacIsValid(rgmymac)) { - if (MacIsValid(bmcmymac)) { - memcpy(rgmymac,bmcmymac,MAC_LEN); /*use existing*/ - } else { /*error*/ - printf("invalid MAC address for gcm\n"); - } - } /*else use rgmymac if specified*/ - _ifname = iface; /*use the iface from gwy (e.g. eth0) */ - fsharedMAC = 0; /*gcm has separate NIC, separate MAC*/ - - // fd = -1; - fd = skfd; // get_socket_for_af(AF_INET) below; - } else { /*else not gcm*/ - if (!fsetifn && !fethfound) { /*do not have ifname yet*/ - i = FindEthNum(bmcmymac); - if (i >= 0) sprintf(ifname,"%s%d",ifpattn,i); - } - ifr.ifr_addr.sa_family = AF_INET; - if (fdebug) printf("getipmac: ifname=%s\n",ifname); - _ifname = ifname; - strcpy(ifr.ifr_name, _ifname); - -#ifdef SIOCGIFHWADDR - /* Get the local if HWADDR (MAC Address) from OS */ - if (ioctl(skfd, SIOCGIFHWADDR, &ifr) < 0) { - if (fdebug) - printf("ioctl(SIOCGIFHWADDR,%s) error, errno = %d\n",_ifname,get_errno()); - } else memcpy(osmymac,get_ifreq_mac(&ifr),MAC_LEN); /*OS mac*/ -#endif - - if (memcmp(bmcmymac,osmymac,MAC_LEN) == 0) { - /* osmymac and ifname were set above by FindEthNum */ - printf("\tBMC shares IP/MAC with OS NIC %s\n",_ifname); - fsharedMAC = 1; - } /* else fsharedMAC = 0; */ - - if (fsharedMAC == 0) { /* then BMC has separate MAC */ - if (!MacIsValid(rgmymac) && MacIsValid(bmcmymac)) - memcpy(rgmymac,bmcmymac,MAC_LEN); /*use existing*/ - } else { /* else OS & BMC share a MAC */ - /* Use the local if HWADDR (MAC Address) from OS */ - if (!MacIsValid(rgmymac)) { /* if not user-specified */ - if (MacIsValid(bmcmymac)) - memcpy(rgmymac,bmcmymac,MAC_LEN); /*use existing*/ - else memcpy(rgmymac,osmymac,MAC_LEN); /*use OS mac*/ - } - } - fd = skfd; // get_socket_for_af(AF_INET) below; - } - - if (fd >= 0) { /* if valid fd, find OS IP */ - strcpy(ifr.ifr_name, _ifname); - ifr.ifr_addr.sa_family = AF_INET; - /* Get the IFADDR (IP Address) from OS */ - if (ioctl(fd, SIOCGIFADDR, &ifr) < 0) { - int err; - err = get_errno(); - /* errno 99 here means that eth0 is not enabled/up/defined. */ - if (err == 99) - printf("ioctl(SIOCGIFADDR) error, %s not enabled\n",_ifname); - else if (fdebug) - printf("ioctl(SIOCGIFADDR,%s) error, errno=%d\n",_ifname,err); - } else { /* got the local OS IP successfully */ - pc = (uchar *)&ifr.ifr_addr.sa_data[2]; - if (fdebug) - printf("%s addr = %d.%d.%d.%d\n",_ifname,pc[0],pc[1],pc[2],pc[3]); - memcpy(osmyip, pc, 4); - if (!IpIsValid(rgmyip) && (fsharedMAC==1)) /*not specified, shared*/ - memcpy(rgmyip, osmyip, 4); - - /* get the local OS netmask */ - strcpy(ifr.ifr_name, _ifname); - if (ioctl(fd, SIOCGIFNETMASK, &ifr) < 0) { - if (fdebug) - printf("ioctl(SIOCGIFNETMASK) error, errno=%d\n",get_errno()); - /* if leave invalid, will use default rgsubnet */ - } else { // sizeof(struct sockaddr) - pc = (uchar *)&ifr.ifr_netmask.sa_data[2]; - if (fdebug) - printf("subnet = %d.%d.%d.%d \n", pc[0],pc[1],pc[2],pc[3]); - memcpy(ossubnet, pc, 4); - if (!SubnetIsValid(rgsubnet) && fsharedMAC) /*not specified*/ - memcpy(rgsubnet, pc, 4); - } - -#ifdef SIOCGIFHWADDR - /* Get the localhost OS HWADDR (MAC Address) */ - if (ioctl(fd, SIOCGIFHWADDR, &ifr) < 0) { - if (fdebug) - printf("ioctl(SIOCGIFHWADDR,%s) error, errno = %d\n", - _ifname,get_errno()); - } else memcpy(osmymac,get_ifreq_mac(&ifr),MAC_LEN); /*OS mac*/ -#endif - } - } - close(skfd); /* done, close the socket */ - - if (rghostname[0] == 0) { /*hostname not specified*/ - if (!fipmilan) - gethostname(rghostname,sizeof(rghostname)); - } - if (fdebug) /* show the local OS eth if and MAC */ - printf("OS %s IP=%d.%d.%d.%d %s MAC=%02x:%02x:%02x:%02x:%02x:%02x used for arp\n", - _ifname, osmyip[0],osmyip[1],osmyip[2],osmyip[3], rghostname, - osmymac[0], osmymac[1], osmymac[2], osmymac[3], - osmymac[4], osmymac[5]); - - if (!IpIsValid(rgmyip) && IpIsValid(bmcmyip)) { - /* If no user-specified IP and there is a valid IP already in the - * BMC LAN configuration, use the existing BMC LAN IP. */ - memcpy(rgmyip,bmcmyip,4); - if (fdebug) printf("Using current IP %d.%d.%d.%d\n", - bmcmyip[0], bmcmyip[1], - bmcmyip[2], bmcmyip[3]); - } - - /* Get the default gateway MAC */ - if (lan_ch == gcm_ch) { - if (SubnetIsSame(osmyip,rggwyip,ossubnet)) fgetmac = 1; - else { /* gateway is not on the same subnet as RMM/GCM */ - fgetmac = 0; /*don't try to get mac if not the same subnet*/ - if ((fset_ip & GWYIP) == 0) memset(rggwyip,0,4); - } - } else fgetmac = 1; - if (fgetmac && IpIsValid(rggwyip) && !MacIsValid(rggwymac)) - Get_Mac(rggwyip,rggwymac,NULL); /*gwy mac not specified, so get mac*/ - - /* Get the Alert Destination IP */ - /* By default, attempt to obtain this from /etc/snmp/snmpd.conf. */ - /* cat /etc/snmp/snmpd.conf | grep trapsink |tail -n1 | cut -f2 -d' ' */ - alertname[0] = 0; /* default to null string */ - fprt = fopen(snmpfile,"r"); - if (fprt == NULL) { - printf("snmp: Cannot open %s, errno = %d\n",snmpfile,get_errno()); - } else { - // char snmpfmt[] = "%20s %60s\n"; - // char *keywd, *value; - while (fgets(buff, 1023, fprt)) { - /* parse each line */ - if (buff[0] == '#') continue; /*skip comment lines*/ - /* skip leading whitespace here */ - j = strspn(&buff[0]," \t"); - if (strncmp(&buff[j],"com2sec",7) == 0) { /* found community line */ - /* usu like this: "com2sec demouser default public" */ - i = j + 7; - for (j = 0; j < 3; j++) { - num = strspn(&buff[i]," \t"); - i += num; - num = strcspn(&buff[i]," \t\r\n"); - if (j < 2) i += num; - } - buff[i+num] = 0; - if (fsetcommunity == 0) { /* if not user-specified */ - strcpy(rgcommunity,&buff[i]); - strcpy(defcommunity,&buff[i]); - } - } -#ifdef BSD - if (strncmp(&buff[j],"traphost :=",11) == 0) nmatch = 11; - else nmatch = 0; -#else - if (strncmp(&buff[j],"trapsink",8) == 0) nmatch = 8; - else if (strncmp(&buff[j],"trap2sink",9) == 0) nmatch = 9; - else nmatch = 0; -#endif - if (nmatch > 0) { /* found trapsink line match */ - if (fdebug) printf("%s: %s",snmpfile,&buff[j]); - num = strspn(&buff[j+nmatch]," \t"); - i = j + nmatch + num; - if (buff[i] == '`') continue; - num = strcspn(&buff[i]," \t\r\n"); - strncpy(alertname,&buff[i],num); /* save alert destination */ - alertname[num] = 0; - i += num; - num = strspn(&buff[i]," \t"); /*skip whitespace*/ - i += num; - num = strcspn(&buff[i]," \t\r\n"); /*span next word*/ - if (num != 0) { /* there is another word, that is community */ - if (fsetcommunity == 0) { /* if not user-specified */ - strncpy(rgcommunity,&buff[i],num); /* save community */ - rgcommunity[num] = 0; - } - } else { /*have trapsink node with no community*/ - /* use previously discovered default community from above */ - strcpy(rgcommunity,defcommunity); - } - /* dont break, keep looking, use the last one */ - } - } /*end while*/ - fclose(fprt); - if (fdebug) - printf("snmp alertname=%s community=%s\n",alertname,rgcommunity); - } /*end else snmpfile*/ - - /* Get the Alert Destination MAC from the alertname. */ - if (alertname[0] != 0) { -#ifdef TEST - char arping_cmd[128]; - char *pb, *pm, *px; - int num, i; - if (fdebug) printf("alert %s ip=%d.%d.%d.%d osip=%d.%d.%d.%d " - "mac=%02x:%02x:%02x:%02x:%02x:%02x " - "osmac=%02x:%02x:%02x:%02x:%02x:%02x\n", - alertname, - rgdestip[0], rgdestip[1], rgdestip[2], rgdestip[3], - osmyip[0], osmyip[1], osmyip[2], osmyip[3], - rgdestmac[0], rgdestmac[1], rgdestmac[2], rgdestmac[3], - rgdestmac[4], rgdestmac[5], - osmymac[0], osmymac[1], osmymac[2], osmymac[3], - osmymac[4], osmymac[5]); -#endif - if (!IpIsValid(rgdestip)) { /* if not user-specified with -A */ - if (IpIsValid(bmcdestip)) { /* use existing if valid */ - memcpy(rgdestip,bmcdestip,4); - if (MacIsValid(bmcdestmac)) - memcpy(rgdestmac,bmcdestmac,MAC_LEN); - } - else if ((strncmp(alertname,"localhost",9) == 0) ) - { /* snmpd.conf = localhost (self) is the SNMP alert destination */ - if (IpIsValid(osmyip)) - memcpy(rgdestip,osmyip,4); - if (!MacIsValid(rgdestmac)) { /* if not user-specified */ - // Get_Mac(rgdestip,rgdestmac,alertname); (wont work for local) - memcpy(rgdestmac,osmymac,MAC_LEN); - } - } /*endif local */ - } - if (!MacIsValid(rgdestmac)) /* if MAC not vaild or user-specified */ - { - /* Use arping to get MAC from alertname or IP */ - Get_Mac(rgdestip,rgdestmac,alertname); - } - } /*endif have alertname*/ - - return(rc); -} /* end Get_IPMac_Addr */ -#endif - -int ShowChanAcc(uchar bchan) -{ - LAN_RECORD LanRecord; - int ret = 0; - uchar access; - char *pstr; - uchar pb0, pb1; - - if (bchan == lan_ch) pstr = "lan"; - else if (bchan == ser_ch) pstr = "ser"; - else pstr = "?"; - ret = GetChanAcc(bchan, 0x40, &LanRecord); - if (fdebug) - printf(" GetChanAcc(%d), ret = %d, data = %02x %02x\n", - bchan,ret, LanRecord.data[0], LanRecord.data[1]); - pb0 = LanRecord.data[0]; - pb1 = LanRecord.data[1]; - if (fcanonical) - printf("Channel %d Access Mode %s%c ",bchan,pspace3,bdelim); - else - printf("Channel(%d=%s) Access Mode: %02x %02x : ",bchan,pstr,pb0,pb1); - access = pb0; - switch (access & 0x03) { - case 0: printf("Disabled, "); break; - case 1: printf("Pre-Boot, "); break; - case 2: printf("Always Avail, "); break; - case 3: printf("Shared, "); break; - } - if (access & 0x20) printf("PEF Alerts Disabled\n"); /*0*/ - else printf("PEF Alerts Enabled\n"); /*1*/ - return(ret); -} - -static int GetSessionInfo(uchar *rData, int sz) -{ - int rv, rlen; - uchar ccode; - uchar iData[5]; - - iData[0] = 0x00; /*get data for this session*/ - rlen = sz; - rv = ipmi_cmdraw(CMD_GET_SESSION_INFO,NETFN_APP, BMC_SA,PUBLIC_BUS,BMC_LUN, - iData,1,rData, &rlen, &ccode, fdebug); - if ((rv == 0) && (ccode != 0)) rv = ccode; - return(rv); -} - -static int GetPefCapabilities(uchar *bmax) -{ - int rv, rlen; - uchar ccode; - uchar rData[MAX_BUFFER_SIZE]; - - rlen = sizeof(rData); - rv = ipmi_cmdraw(0x10, NETFN_SEVT, BMC_SA,PUBLIC_BUS,BMC_LUN, - NULL,0,rData, &rlen, &ccode, fdebug); - if ((rv == 0) && (ccode != 0)) rv = ccode; - if ((rv == 0) && (bmax != NULL)) - *bmax = rData[2]; /*max num PEF table entries*/ - return(rv); -} - -int GetSerialOverLan( uchar chan, uchar bset, uchar block ) -{ - uchar requestData[24]; - uchar rData[MAX_BUFFER_SIZE]; - int rlen; - int status, i; - uchar ccode; - uchar enable_parm, auth_parm, baud_parm; - ushort getsolcmd; - uchar user; - - if (fIPMI20 && fSOL20) { - getsolcmd = GET_SOL_CONFIG2; - enable_parm = SOL_ENABLE_PARAM; - auth_parm = SOL_AUTHENTICATION_PARAM; - baud_parm = SOL_BAUD_RATE_PARAM; - } else { - getsolcmd = GET_SOL_CONFIG; - enable_parm = SOL_ENABLE_PARAM; - auth_parm = SOL_AUTHENTICATION_PARAM; - baud_parm = SOL_BAUD_RATE_PARAM; - chan = 0; /*override chan for IPMI 1.5*/ - } - if (!fcanonical) - printf("%s, GetSOL for channel %d ...\n",progname,chan); - - requestData[0] = chan; /*channel*/ - requestData[1] = enable_parm; - requestData[2] = bset; /*set*/ - requestData[3] = block; /*block*/ - rlen = sizeof(rData); - status = ipmi_cmd(getsolcmd, requestData,4, rData, &rlen,&ccode,fdebug); - if (status != 0) return(status); - if (ccode) { - if (ccode == 0xC1) { /* unsupported command */ - printf("Serial-Over-Lan not available on this platform\n"); - return(status); - } else { - printf("SOL Enable ccode = %x\n",ccode); - status = ccode; - } - } else { /*success*/ - if (fcanonical) { - printf("Channel %d SOL Enable %s",chan,pspace3); - } else { - printf("SOL Enable: "); - for (i = 1; i < rlen; i++) printf("%02x ",rData[i]); - } - if (rData[1] == 0x01) printf("%c enabled\n",bdelim); - else printf("%c disabled\n",bdelim); - } - - if (!fcanonical) - { - requestData[0] = chan; - requestData[1] = auth_parm; - requestData[2] = bset; // selector - requestData[3] = block; // block - rlen = sizeof(rData); - status = ipmi_cmd(getsolcmd,requestData,4,rData,&rlen,&ccode,fdebug); - if (status != 0) return(status); - if (ccode) { - printf("SOL Auth ccode = %x\n",ccode); - status = ccode; - } else { /*success*/ - printf("SOL Auth: "); - for (i = 1; i < rlen; i++) printf("%02x ",rData[i]); - printf(": "); - show_priv(rData[1]); /* priv level = User,Admin,... */ - printf("\n"); - } - - requestData[0] = chan; - requestData[1] = SOL_ACC_INTERVAL_PARAM; - requestData[2] = bset; - requestData[3] = block; - rlen = sizeof(rData); - status = ipmi_cmd(getsolcmd,requestData,4,rData,&rlen,&ccode,fdebug); - if (status != 0) return(status); - if (ccode) { - printf("SOL Accum Interval ccode = %x\n",ccode); - status = ccode; - } else { /*success*/ - printf("SOL Accum Interval: "); - for (i = 1; i < rlen; i++) printf("%02x ",rData[i]); - printf(": %d msec\n",(rData[1] * 5)); - } - - requestData[0] = chan; - requestData[1] = SOL_RETRY_PARAM; - requestData[2] = bset; - requestData[3] = block; - rlen = sizeof(rData); - status = ipmi_cmd(getsolcmd,requestData,4,rData,&rlen,&ccode,fdebug); - if (status != 0) return(status); - if (ccode) { - printf("SOL Retry ccode = %x\n",ccode); - status = ccode; - } else { /*success*/ - printf("SOL Retry Interval: "); - for (i = 1; i < rlen; i++) printf("%02x ",rData[i]); - printf(": %d msec\n",(rData[2] * 10)); - } - } - - if (!fRomley) - { - requestData[0] = chan; - requestData[1] = baud_parm; - requestData[2] = bset; - requestData[3] = block; - rlen = sizeof(rData); - status = ipmi_cmd(getsolcmd,requestData,4,rData, &rlen,&ccode,fdebug); - if (status != 0) return(status); - if (ccode) { - printf("SOL nvol Baud ccode = %x\n",ccode); - status = ccode; - } else { /*success*/ - uchar b; - if (fcanonical) { - printf("Channel %d SOL Baud Rate%s",chan,pspace3); - } else { - printf("SOL nvol Baud Rate: "); - for (i = 1; i < rlen; i++) printf("%02x ",rData[i]); - } - /* if not user-specified and previously enabled, use existing */ - b = (rData[1] & 0x0f); - if ((fnewbaud == 0) && BaudValid(b)) { - sol_baud = b; - sol_bvalid = 1; - } - printf("%c %s\n",bdelim,Baud2Str(b)); - } - - if (!fcanonical) - { - requestData[0] = chan; - requestData[1] = SOL_VOL_BAUD_RATE_PARAM; /*0x06*/ - requestData[2] = bset; - requestData[3] = block; - rlen = sizeof(rData); - status = ipmi_cmd(getsolcmd,requestData,4,rData,&rlen,&ccode,fdebug); - if (status != 0) return(status); - if (ccode) { - printf("SOL vol Baud ccode = %x\n",ccode); - status = ccode; - } else { /*success*/ - printf("SOL vol Baud Rate: "); - for (i = 1; i < rlen; i++) printf("%02x ",rData[i]); - printf("%c %s\n",bdelim,Baud2Str(rData[1])); - } - } - } - if (fIPMI20) { - if (vend_id != VENDOR_IBM) { - /* IBM 0x00DC returns invalid cmd for SOL Payload commands. */ - if (!fcanonical) { - requestData[0] = chan; - rlen = sizeof(rData); - status = ipmi_cmdraw(GET_PAYLOAD_SUPPORT, NETFN_APP, - BMC_SA,PUBLIC_BUS,BMC_LUN, - requestData,1,rData, &rlen, &ccode, fdebug); - if ((status != 0) || (ccode != 0)) { - printf("SOL Payload Support error %d, ccode = %x\n",status,ccode); - if (status == 0) status = ccode; - } else { /*success*/ - printf("SOL Payload Support(%d): ",chan); - for (i = 0; i < rlen; i++) printf("%02x ",rData[i]); - printf("\n"); - } - } /*endif not canonical*/ - /* get Payload Access for 4 users, not just lan_user */ - for (user = 1; user <= show_users; user++) - { - /* mBMC doesn't support more than 1 user */ - if (fmBMC && (user > 1)) break; - /* IPMI 2.0 has >= 4 users */ - requestData[0] = chan; - requestData[1] = user; - rlen = sizeof(rData); - status = ipmi_cmdraw(GET_PAYLOAD_ACCESS, NETFN_APP, - BMC_SA,PUBLIC_BUS,BMC_LUN, - requestData,2,rData, &rlen, &ccode, fdebug); - if ((status != 0) || (ccode != 0)) { - printf("SOL Payload Access(%d,%d) error %d, ccode = %x\n", - chan,user,status,ccode); - if (status == 0) status = ccode; - } else { /*success*/ - if (fcanonical) { - printf("Channel %d SOL Payload Access(user%d)%s",chan,user, - pspace1); - } else { - printf("SOL Payload Access(%d,%d): ",chan,user); - for (i = 0; i < rlen; i++) printf("%02x ",rData[i]); - } - if ((rData[0] & 0x02) != 0) printf("%c enabled\n",bdelim); - else printf("%c disabled\n",bdelim); - } - } /*end user loop*/ - } /*endif not IBM*/ - } - - return(status); -} /*end GetSerialOverLan */ - -/* -ECHO SOL Config Enable -CMDTOOL 20 30 21 %1 01 01 - -ECHO SOL Authentication (Administrator) -CMDTOOL 20 30 21 %1 02 04 - -ECHO SOL Accumlate Interval and threshold -CMDTOOL 20 30 21 %1 03 06 14 - -ECHO SOL Retry Interval and threshold -CMDTOOL 20 30 21 %1 04 06 14 - -ECHO SOL non-volatile baud rate -CMDTOOL 20 30 21 %1 05 07 - -ECHO SOL volatile baud rate -CMDTOOL 20 30 21 %1 06 07 - -ECHO Set user Payload Access for user 1 -CMDTOOL 20 18 4c %1 01 02 00 00 00 - */ -int SetupSerialOverLan( int benable ) -{ - uchar requestData[24]; - uchar responseData[MAX_BUFFER_SIZE]; - int responseLength = MAX_BUFFER_SIZE; - int status; - uchar completionCode; - uchar enable_parm, auth_parm, baud_parm; - ushort setsolcmd; - ushort getsolcmd; - uchar bchan, b; - - if (fIPMI20 && fSOL20) { - setsolcmd = SET_SOL_CONFIG2; - getsolcmd = GET_SOL_CONFIG2; - enable_parm = SOL_ENABLE_PARAM; - auth_parm = SOL_AUTHENTICATION_PARAM; - baud_parm = SOL_BAUD_RATE_PARAM; - bchan = lan_ch; - } else { - setsolcmd = SET_SOL_CONFIG; - getsolcmd = GET_SOL_CONFIG; - enable_parm = SOL_ENABLE_PARAM; - auth_parm = SOL_AUTHENTICATION_PARAM; - baud_parm = SOL_BAUD_RATE_PARAM; - bchan = 0x00; /*override chan for IPMI 1.5*/ - } - memset(requestData, 0, sizeof(requestData)); /* zero-fill */ - requestData[0] = bchan; - requestData[1] = enable_parm; - if (benable == 0) - requestData[2] = SOL_DISABLE_FLAG; - else - requestData[2] = SOL_ENABLE_FLAG; - responseLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(setsolcmd, requestData,3,responseData, - &responseLength, &completionCode, fdebug); - if (status == ACCESS_OK) { - switch( completionCode ) { - case 0x00: /* success */ - break; - case 0xC1: /* unsupported command */ - SELprintf("SetupSerialOverLan: SOL not available on this platform\n"); - return 0; - default: /* other error */ - SELprintf("SetupSerialOverLan: SOL_ENABLE_PARAM ccode=%x\n", - completionCode); - return -1; - break; - } - } else { - SELprintf( "SET_SOL_CONFIG, enable SOL failed\n" ); - return -1; - } - if (benable == 0) return 0; - - requestData[0] = bchan; /* channel */ - requestData[1] = auth_parm; - requestData[2] = 0x00; /* set selector */ - requestData[3] = 0x00; /* block selector */ - responseLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(getsolcmd, requestData,4,responseData, - &responseLength, &completionCode, fdebug); - if (status == ACCESS_OK) { - if( completionCode ) { - SELprintf("SetupSerialOverLan: GET_SOL_AUTHENTICATION_PARAM code=%x\n", - completionCode); - - return -1; - } - } else { - SELprintf( "SOL_CONFIG, get SOL authentication failed\n" ); - return -1; - } - - if ((vend_id == VENDOR_SUPERMICROX) || - (vend_id == VENDOR_SUPERMICRO)) b = SOL_PRIVILEGE_LEVEL_OPERATOR; - else b = SOL_PRIVILEGE_LEVEL_USER; - requestData[0] = bchan; - requestData[1] = auth_parm; - requestData[2] = b | ( responseData[1] & 0x80 ); /* priv | enable */ - responseLength = MAX_BUFFER_SIZE; - status = ipmi_cmd(setsolcmd, requestData,3,responseData, - &responseLength, &completionCode, fdebug); - if (status == ACCESS_OK) { - if( completionCode ) { - SELprintf("SET_SOL_AUTHENTICATION_PARAM code=%x\n", - completionCode); - - return -1; - } - } else { - SELprintf( "SET_SOL_CONFIG, set SOL authentication failed\n" ); - return -1; - } - - requestData[0] = bchan; - requestData[1] = SOL_ACC_INTERVAL_PARAM; - requestData[2] = sol_accum[0]; //0x04; - requestData[3] = sol_accum[1]; //0x32; - responseLength = MAX_BUFFER_SIZE; - if (fdebug) SELprintf("Setting SOL AccumInterval\n"); - status = ipmi_cmd(setsolcmd, requestData,4,responseData, - &responseLength, &completionCode, fdebug); - if (status != ACCESS_OK || completionCode) { - SELprintf("SET SOL AccumInterval ret=%d ccode=%x\n", - status,completionCode); - return -1; - } - - /* Some BMCs return sporadic errors for SOL params (e.g. Kontron)*/ - // if (vend_id == VENDOR_KONTRON) ; - // else - { - requestData[0] = bchan; - requestData[1] = SOL_RETRY_PARAM; - requestData[2] = sol_retry[0]; //0x06; - requestData[3] = sol_retry[1]; //0x14; - responseLength = MAX_BUFFER_SIZE; - if (fdebug) SELprintf("Setting SOL RetryInterval\n"); - status = ipmi_cmd(setsolcmd, requestData,4,responseData, - &responseLength, &completionCode, fdebug); - if (status != ACCESS_OK || completionCode) { - SELprintf("SET SOL RetryInterval ret=%d ccode=%x\n", - status,completionCode); - return -1; - } - } - - if (fRomley) ; /* skip SOL BAUD */ - else { /* else SOL BAUD is used, so set it. */ - if (fnewbaud == 0) { /* no user-specified SOL baud */ - /* if sol_bvalid, sol_baud was set to existing value above */ - if (!sol_bvalid) { - status = GetSerEntry(7, (LAN_RECORD *)&responseData); - if (status == 0) { /* use Serial baud for SOL */ - sol_baud = responseData[1]; - if (fdebug) SELprintf("Serial Baud is %s\n",Baud2Str(sol_baud)); - } - } - } - requestData[0] = bchan; - requestData[1] = baud_parm; - requestData[2] = sol_baud; - responseLength = MAX_BUFFER_SIZE; - if (fdebug) SELprintf("Setting SOL BAUD to %s\n",Baud2Str(sol_baud)); - status = ipmi_cmd(setsolcmd, requestData,3,responseData, - &responseLength, &completionCode, fdebug); - if (status != ACCESS_OK || completionCode) { - SELprintf("SET SOL BAUD ret=%d ccode=%x\n", status,completionCode); - return -1; - } - - requestData[0] = bchan; - requestData[1] = SOL_VOL_BAUD_RATE_PARAM; - requestData[2] = sol_baud; - responseLength = MAX_BUFFER_SIZE; - if (fdebug) - printf("Setting SOL vol BAUD to %s\n",Baud2Str(sol_baud)); - status = ipmi_cmd(setsolcmd, requestData,3,responseData, - &responseLength, &completionCode, fdebug); - if (status != ACCESS_OK || completionCode) { - printf("SET SOL vol BAUD ret=%d ccode=%x\n",status,completionCode); - return -1; - } - } - - if (fIPMI20 && fSOL20) { - if (vend_id == VENDOR_KONTRON && lan_user == 1) { - if (fdebug) SELprintf("Skipping SOL Payload Access for user %d\n", - lan_user); - } else if (vend_id == VENDOR_IBM) { /*non-conformance*/ - if (fdebug) SELprintf("Skipping SOL Payload Access for user %d\n", - lan_user); - } else { - if (fdebug) SELprintf("Setting SOL Payload Access for user %d\n", - lan_user); - requestData[0] = bchan; - requestData[1] = lan_user; /*enable this user*/ - requestData[2] = 0x02; /*enable std 2.0 SOL*/ - requestData[3] = 0; - requestData[4] = 0; - requestData[5] = 0; - responseLength = MAX_BUFFER_SIZE; - status = ipmi_cmdraw(SET_PAYLOAD_ACCESS, NETFN_APP, - BMC_SA,PUBLIC_BUS,BMC_LUN, - requestData,6,responseData, &responseLength, - &completionCode, fdebug); - if (status != ACCESS_OK || completionCode) { - SELprintf("SET SOL Payload Access ret=%d ccode=%x\n", - status,completionCode); - return -1; - } - } - } - return 0; -} /*end SetupSerialOverLan */ - -static char *PefDesc(int idx, uchar stype) -{ - char *pdesc, *p; - static char mystr[60]; - int mylen = sizeof(mystr); - pdesc = &mystr[0]; - if (pefdesc != NULL) strcpy(pdesc,pefdesc[idx]); /* if Intel, pre-defined */ - else strcpy(pdesc,"reserved"); /* else set default to detect */ - if ((stype != 0) && (strcmp(pdesc,"reserved") == 0)) { - /* Dynamically set the pef desc string from the sensor type */ - switch(stype) { - case 0x01: strcpy(pdesc,"Temperature"); break; - case 0x02: strcpy(pdesc,"Voltage"); break; - case 0x04: strcpy(pdesc,"Fan"); break; - case 0x05: strcpy(pdesc,"Chassis"); break; - case 0x07: strcpy(pdesc,"BIOS"); break; - case 0x08: strcpy(pdesc,"Power Supply"); break; - case 0x09: strcpy(pdesc,"Power Unit"); break; - case 0x0c: strcpy(pdesc,"Memory"); break; - case 0x0f: strcpy(pdesc,"Boot"); break; - case 0x12: strcpy(pdesc,"System Restart"); break; - case 0x13: strcpy(pdesc,"NMI"); break; - case 0x23: strcpy(pdesc,"Watchdog"); break; - case 0x20: strcpy(pdesc,"OS Critical Stop"); break; - default: -#ifdef METACOMMAND - p = get_sensor_type_desc(stype); - if (p != NULL) { - strncpy(pdesc,p,mylen); - mystr[mylen-1] = 0; /*stringify*/ - } -#else - sprintf(pdesc,"Other[%02x]",stype); -#endif - break; - } - if (pef_array[idx-1][4] == PEF_SEV_OK) strcat(pdesc," OK"); - } - return(pdesc); -} - - -#ifdef METACOMMAND -int i_lan(int argc, char **argv) -#else -#ifdef WIN32 -int __cdecl -#else -int -#endif -main(int argc, char **argv) -#endif -{ - int ret; - PEF_RECORD PefRecord; - LAN_RECORD LanRecord; - int i, idx, j; - int c; - char *pstr; - uchar bset; - int ndest = 4; - int idest; - char mystr[80]; - char fpefok = 1; - uchar * pc; int sz; - char *pa; - char *pb; - - // progname = argv[0]; - printf("%s ver %s \n",progname,progver); - j = 0; freadonly = FLAG_INIT; - idx = argc; /*getopt loop counter*/ - /* available opt chars: y O Q + = ~ _ */ - while ((c = getopt(argc, argv,"a:b:cdef:gh:i:j:klm:n:op:q:rstu:v:w:xy:z#::A:B:C:DEF:G:H:I:J:K:L:M:N:OP:Q:R:S:T:U:V:X:YZ:?")) != EOF) { - switch(c) { - case 'a': /* alert dest number (usu 1 thru 4) */ - alertnum = atob(optarg); - if (alertnum > alertmax) alertnum = 1; - j++; - break; - case 'b': bAuth = htoi(optarg); j++; break; /*undocumented*/ - case 'c': fcanonical = 1; bdelim = BDELIM; break; - case 'd': fenable = 0; fdisable = 1; freadonly = 0; break; - case 'e': fenable = 1; fdisable = 0; freadonly = 0; break; - case 'f': i = atoi(optarg); /*set arp_ctl*/ - if (i < 0 || i > 3) printf("Invalid ARP control %d\n",i); - else { - arp_ctl = i; - fsetarp = 1; - j++; - } - break; - case 'l': fpefenable = 0; fenable = 2; - fdisable = 0; freadonly = 0; break; - case 'h': /* VLAN ID */ - i = atoi(optarg); - if (i > 4095) vlan_enable = 0; - else { - vlan_enable = 1; - vlan_id = (ushort)i; - } - j++; - break; - case 'y': /* OEM LAN Failover enable/disable */ - i = atoi(optarg); - if (i < 0) printf("Failover(-y) parameter is negative\n"); - else failover_enable = i; - j++; - break; - case 'Q': /* VLAN Priority */ - i = atoi(optarg); - if (i > 7 || i < 0) vlan_enable = 0; - else { - vlan_enable = 1; - vlan_prio = (uchar)i; - } - j++; - break; - case 'i': /* eth interface (ifname) */ - fsetifn = 1; - i = sizeof(ifname); - if (strlen(optarg) > (uint)i) optarg[i] = 0; - strcpy(ifname,optarg); - if (fdebug) printf("ifname = %s\n",ifname); - j++; - break; - case 'j': fCustomPEF = 1; /*custom 10 PEF bytes */ - fpefenable = 1; /* PEF is implied here */ - freadonly = 0; - memset(custPEF,0,sizeof(custPEF)); - custPEF[0] = htoi(&optarg[0]); /*action */ - custPEF[1] = htoi(&optarg[2]); /*policy */ - custPEF[2] = htoi(&optarg[4]); /*severity*/ - custPEF[3] = htoi(&optarg[6]); /*genid1 */ - custPEF[4] = htoi(&optarg[8]); /*genid2 */ - custPEF[5] = htoi(&optarg[10]); /*sensor_type*/ - custPEF[6] = htoi(&optarg[12]); /*sensor_num */ - custPEF[7] = htoi(&optarg[14]); /*evt_trigger*/ - custPEF[8] = htoi(&optarg[16]); /*data1offset*/ - custPEF[9] = htoi(&optarg[18]); /*data1mask */ - if (optarg[20] != 0) { - /* optionally get 8 extra PEF entry bytes */ - custPEF[10] = htoi(&optarg[20]); /*data1cmp1 */ - custPEF[11] = htoi(&optarg[22]); /*data1cmp2 */ - custPEF[12] = htoi(&optarg[24]); /*data2mask */ - custPEF[13] = htoi(&optarg[26]); /*data2cmp1 */ - custPEF[14] = htoi(&optarg[28]); /*data2cmp2 */ - custPEF[15] = htoi(&optarg[30]); /*data3mask */ - custPEF[16] = htoi(&optarg[32]); /*data3cmp1 */ - custPEF[17] = htoi(&optarg[34]); /*data3cmp2 */ - } - j++; - break; - case 'k': fSetPEFOks = 1; j++; break; /*configure PEF OK rules */ - case 'm': set_max_kcs_loops(atoi(optarg)); break; - case 'n': /* number/index in PEF table to insert new entry */ - fpefenable = 1; - pefnum = atob(optarg); - if (pefnum >= MAXPEF) { - pefnum = MAXPEF - 1; - fAdjustPefNum = 1; - } else fUserPefNum = 1; - j++; - break; - case 'o': fdisableSOL = 1; /*disable SOL only*/ - fpefenable = 0; /*no change to PEF*/ - freadonly = 0; - break; - case 'r': freadonly = 1; fenable = 0; break; - case 's': fgetser = 1; break; - case 't': ftestonly = 1; freadonly = 1; break; - case 'v': /* user access privilege level */ - i = atoi(optarg); - if (valid_priv(i)) lan_access = i & 0x0f; - else printf("Invalid privilege -v %d, using Admin\n",i); - j++; - break; - case 'w': i = atoi(optarg); /*set grat arp interval, in #sec*/ - if (i >= 0 && i < 256) arp_interval = i * 2; - else printf("Invalid arp interval -w %d, skipping\n",i); - break; - case 'x': fdebug = 1; break; - case 'z': flanstats = 1; break; - case 'D': lan_dhcp = 1; j++; break; - case 'O': flansecure = 1; j++; break; - case 'I': /* My BMC IP Address */ - fset_ip |= MYIP; - atoip(rgmyip,optarg); - j++; - break; - case 'M': /* My BMC MAC Address */ - atomac(rgmymac,optarg); - if (!MacIsValid(rgmymac)) printf("Invalid MAC for -M\n"); - j++; - break; - case 'S': /* Subnet IP Address */ - atoip(rgsubnet,optarg); - j++; - break; - case 'G': /* Gateway IP Address */ - fset_ip |= GWYIP; - atoip(rggwyip,optarg); - j++; - break; - case 'g': /* Secondary Gateway IP Address */ - fset_ip |= GWYIP; - atoip(rggwy2ip,optarg); - j++; - break; - case 'H': /* Gateway MAC Address */ - atomac(rggwymac,optarg); - if (!MacIsValid(rggwymac)) printf("Invalid MAC for -H\n"); - j++; - break; - case 'B': /* SOL Baud rate */ - fnewbaud = 1; - sol_baud = Str2Baud(optarg); - j++; - break; - case 'A': /* Alert Dest IP Address */ - fset_ip |= DESTIP; - /* allow name or ip here via Get_Mac() ? */ - atoip(rgdestip,optarg); - fpefenable = 1; /* PEF is implied here */ - j++; - break; - case 'X': /* Alert Dest MAC Address */ - atomac(rgdestmac,optarg); - if (!MacIsValid(rgdestmac)) printf("Invalid MAC for -X\n"); - fpefenable = 1; /* PEF is implied here */ - j++; - break; - case 'K': /* Kontron IPMI hostname */ - i = sizeof(rghostname); /*usu 18*/ - if (strlen(optarg) > (uint)i) optarg[i] = 0; - strcpy(rghostname,optarg); - j++; - break; - case 'C': /* Community String */ - fsetcommunity = 1; - i = sizeof(rgcommunity); /*usu 18*/ - if (strlen(optarg) > (uint)i) optarg[i] = 0; - strcpy(rgcommunity,optarg); - fpefenable = 1; /* PEF is implied here */ - j++; - break; - case 'u': /* username to set */ - myuser = strdup_(optarg); /*remote username */ - j++; - break; - case 'p': /* password to set */ - fpassword = 1; - if (strlen(optarg) > PSW_MAX) optarg[PSW_MAX] = 0; - strcpy(passwordData,optarg); - if (fdebug) printf("Password = %s\n",passwordData); - /* Hide password from 'ps' */ - memset(optarg, ' ', strlen(optarg)); - j++; - break; - case 'q': - case '#': - usernum = atob(optarg); - if (usernum > 15) usernum = 0; /*MAX_IPMI_USERS = 15*/ - j++; - break; - case 'L': - if (strcmp(optarg,"list") == 0) fshowchan = 1; - lan_ch_parm = atob(optarg); - if (lan_ch_parm > MAXCHAN) lan_ch_parm = PARM_INIT; /*invalid*/ - break; - case 'V': /* priv level */ - fprivset = 1; - case 'N': /* nodename */ - case 'U': /* remote username */ - case 'P': /* remote password */ - case 'R': /* remote password */ - case 'E': /* get password from IPMI_PASSWORD environment var */ - case 'F': /* force driver type */ - case 'T': /* auth type */ - case 'J': /* cipher suite */ - case 'Y': /* prompt for remote password */ - case 'Z': /* set local MC address */ - parse_lan_options(c,optarg,fdebug); - break; - default: - printf("Usage: %s [-abcdefghijklmnopq#rstuvwxyzBDQK]\n",progname); - printf(" \t [-a alertnum -i eth1 -n pefnum ]\n"); - printf(" \t [-I ipadr -M macadr -S subnet ]\n"); - printf(" \t [-G gwyip -H gwymac -L lan_channel_num]\n"); - printf(" \t [-A alertip -X alertmac -C community ]\n"); - printf(" \t [-g 2nd_gwyip -v priv -B sol_baud ]\n"); - printf(" \t [-j 10_bytes_custom_pef -b authmask ]\n"); - printf("where -c shows Canonical, simpler output format\n"); - printf(" -d Disables BMC LAN & PEF\n"); - printf(" -e Enables BMC LAN & PEF\n"); - printf(" -f set ARP Control to 1=grat, 2=resp, 3=both\n"); - printf(" -g secondary Gateway IP (-G=primary_gwy_ip)\n"); - printf(" -h VLAN ID (>=4096 to disable)\n"); - printf(" -j specify custom PEF rule (10 or 18 hex bytes)\n"); - printf(" -k add PEF oK rules, if PEF enable\n"); - printf(" -l Enables BMC LAN only, not PEF\n"); - printf(" -o disable Only SOL\n"); - printf(" -p password to set \n"); - printf(" -q/-# User number of LAN username_to_set\n"); - printf(" -r Read-only BMC LAN & PEF settings\n"); - printf(" -s Show some Serial settings also \n"); - printf(" -t Test if BMC LAN is already configured\n"); - printf(" -u username to set \n"); - printf(" -v access priVilege: 4=Admin,3=Operator,2=User\n"); - printf(" -w set Grat ARP Interval to specified # seconds\n"); - printf(" -x Show eXtra debug messages\n"); - printf(" -y OEM LAN Failover (1=enable,0=disable if Intel)\n"); - printf(" -z Show IPMI LAN statistics\n"); - printf(" -B Baud for SerialOverLan (19.2K,115.2K,...)\n"); - printf(" -D Use DHCP instead of static IP (-I for server)\n"); - printf(" -K (Kontron) IPMI hostname to set\n"); - printf(" -Q VLAN Priority (default =0)\n"); - printf(" -O Force LAN security: no null user, cipher 0 off\n"); - print_lan_opt_usage(0); - ret = ERR_USAGE; - goto do_exit; - } /*end switch*/ - nopts++; - } /*end while*/ - - if ((freadonly == FLAG_INIT) && (j > 0)) { - /* got some options implying set, but no -e -l -d option specified. */ - foptmsg = 1; /*show warning message later*/ - freadonly = 1; /*assume read only*/ - } - fipmilan = is_remote(); - if (fipmilan && !fprivset) - parse_lan_options('V',"4",0); /*even if freadonly request admin*/ - if ((fsetarp == 0) && ostype == OS_WINDOWS) - arp_ctl = 0x03; /*grat arp & arp resp enabled */ - - ret = GetDeviceID( &LanRecord); - if (ret != 0) { - goto do_exit; - } else { /* success */ - uchar ipmi_maj, ipmi_min; - ipmi_maj = LanRecord.data[4] & 0x0f; - ipmi_min = LanRecord.data[4] >> 4; - show_devid( LanRecord.data[2], LanRecord.data[3], ipmi_maj, ipmi_min); - if (ipmi_maj == 0) fIPMI10 = 1; - else if (ipmi_maj == 1 && ipmi_min < 5) fIPMI10 = 1; - else fIPMI10 = 0; /* >= IPMI 1.5 is ok */ - if (ipmi_maj >= 2) fIPMI20 = 1; - if (fIPMI20) show_users = 5; - else show_users = 3; - if (fIPMI10) { - printf("This IPMI v%d.%d system does not support PEF records.\n", - ipmi_maj,ipmi_min); - /* Wont handle PEF, but continue and look for BMC LAN anyway */ - // fIPMI10 = 1; - // ipmi_close_(); - // exit(1); - } - prod_id = LanRecord.data[9] + (LanRecord.data[10] << 8); - vend_id = LanRecord.data[6] + (LanRecord.data[7] << 8) - + (LanRecord.data[8] << 16); - /* check Device ID response for Manufacturer ID = 0x0322 (NSC) */ - if (vend_id == VENDOR_NSC) { /* NSC = 0x000322 */ - fmBMC = 1; /*NSC miniBMC*/ - if (pefnum == 12) pefnum = 10; /* change CritStop pefnum to 0x0a */ - pefdesc = &pefdesc2[0]; /*mini-BMC PEF*/ - pefmax = 30; - fsharedMAC = 1; /* shared MAC with OS */ - } else if (vend_id == VENDOR_LMC) { /* LMC (on SuperMicro) = 0x000878 */ - pefdesc = NULL; /* unknown, see PefDesc() */ - if (pefnum == 12) pefnum = 15; /* change CritStop pefnum */ - pefmax = 16; - fsharedMAC = 0; /* not-shared BMC LAN port */ - } else if (vend_id == VENDOR_INTEL) { /* Intel = 0x000157 */ - pefdesc = &pefdesc1[0]; /*default Intel PEF*/ - pefmax = 20; /*default Intel PEF*/ - switch(prod_id) { - case 0x4311: /* Intel NSI2U w SE7520JR23 */ - fmBMC = 1; /* Intel miniBMC*/ - if (pefnum == 12) pefnum = 14; /* change CritStop pefnum */ - pefdesc = &pefdesc2[0]; /*mini-BMC PEF*/ - pefmax = 30; - fsharedMAC = 1; /* shared-MAC BMC LAN port, same MAC */ - break; - case 0x0022: /* Intel TIGI2U w SE7520JR23 +IMM*/ - fsharedMAC = 1; /* shared-MAC BMC LAN port, same MAC */ - gcm_ch = 3; /* IMM GCM port, dedicated MAC */ - show_users = 4; - break; - case 0x000C: /*TSRLT2*/ - case 0x001B: /*TIGPR2U*/ - /* fmBMC=0; Intel Sahalee BMC*/ - fsharedMAC = 1; /* shared-MAC BMC LAN port, same MAC */ - break; - case 0x0026: /*S5000 Bridgeport*/ - case 0x0028: /*S5000PAL Alcolu*/ - case 0x0029: /*S5000PSL StarLake*/ - case 0x0811: /*S5000PHB TIGW1U */ - /* fmBMC=0; Intel Sahalee ESB2 BMC*/ - fsharedMAC = 0; /* not-shared BMC LAN port, separate MAC */ - gcm_ch = 3; - parm7 = &iparm7[0]; /*TTL=30*/ - break; - case 0x003E: /*NSN2U or CG2100 Urbanna*/ - fiBMC = 1; /* Intel iBMC */ - fsharedMAC = 0; /* not-shared BMC LAN port, separate MAC */ - // gcm_ch = 3; - parm7 = &iparm7[0]; /*TTL=30*/ - if (fsetarp == 0) - arp_ctl = 0x02; /*grat arp disabled, arp resp enabled */ - arp_interval = 0x00; /*0 sec, since grat arp disabled */ - sol_accum[0] = 0x0c; /*Intel defaults*/ - sol_accum[1] = 0x60; /*Intel defaults*/ - sol_retry[0] = 0x07; /*Intel defaults*/ - sol_retry[1] = 0x32; /*Intel defaults*/ - set_max_kcs_loops(URNLOOPS); /*longer for SetLan cmds (default 300)*/ - break; - case 0x0107: /* Intel Caneland*/ - fsharedMAC = 0; /* not-shared BMC LAN port, separate MAC */ - gcm_ch = 3; - break; - case 0x0100: /*Tiger2 ia64*/ - /* for ia64 set chan_pefon, chan_pefoff accordingly*/ - chan_pefon = CHAN_ACC_PEFON64; - chan_pefoff = CHAN_ACC_PEFOFF64; - /* fall through */ - default: /* else other Intel */ - /* fmBMC = 0; * Intel Sahalee BMC*/ - if (fIPMI20) fsharedMAC = 0; /* recent, not-shared BMC MAC */ - else fsharedMAC = 1; /* usu IPMI 1.x has shared BMC MAC */ - break; - } /*end switch*/ - if (is_romley(vend_id,prod_id)) fRomley = 1; - if (is_grantley(vend_id,prod_id)) fGrantley = 1; - if (fRomley) { - fiBMC = 1; /* Intel iBMC */ - fsharedMAC = 0; /* not-shared BMC LAN port, separate MAC */ - set_max_kcs_loops(URNLOOPS); /*longer for SetLan (default 300)*/ - fipv6 = 1; - if (fsetarp == 0) arp_ctl = 0x03; /*default to both for Romley*/ - } - } else { /* else other vendors */ - if (fIPMI20) fsharedMAC = 0; /* recent, not-shared BMC MAC */ - else fsharedMAC = 1; /* usu IPMI 1.x has shared BMC MAC */ - pefdesc = NULL; /* unknown, see PefDesc() */ - if (pefnum == 12) pefnum = 15; /* change CritStop pefnum to 15? */ - pefmax = 20; - if (!fUserPefNum) fAdjustPefNum = 1; - } - if (fmBMC) show_users = 1; /* mBMC doesn't support more than 1 user */ - } - - if (fshowchan) { - ret = show_channels(); - exit(ret); - } - - ret = GetPefCapabilities(&bset); - if ((ret == 0) && (bset <= MAXPEF)) pefmax = bset; - - /* Get the BMC LAN channel & match it to an OS eth if. */ - i = GetBmcEthDevice(lan_ch_parm,&lan_ch); - if (i == -2) { /* no lan channels found (see lan_ch) */ - if (lan_ch_parm == PARM_INIT) - printf("This system does not support IPMI LAN channels.\n"); - else /*specified a LAN channel*/ - printf("BMC channel %d does not support IPMI LAN.\n",lan_ch_parm); - ret = LAN_ERR_NOTSUPPORT; - goto do_exit; - } else if (i < 0) { /* mac not found, use platform defaults */ - i = 0; /* default to eth0, lan_ch set already. */ - if (vend_id == VENDOR_INTEL) { - if ((prod_id == 0x001B) || (prod_id == 0x000c)) { - /* Intel TIGPR2U or TSRLT2 defaults are special */ - if (lan_ch_parm == 6) - { i = 0; lan_ch = 6; } - else { i = 1; lan_ch = 7; } - ser_ch = 1; - } - } - } - if ((i == gcm_ch) && (gcm_ch != PARM_INIT) && (lan_ch_parm == PARM_INIT)) { - /* Has a GCM, defaulted to it, and user didn't specify -L */ - /* Need this to avoid picking channel 3, the IMM/RMM GCM channel. */ - lan_ch = 1; /*default BMC LAN channel*/ - // i = 0; /*default eth0 (was eth1) */ - } - if (fsetifn == 0) { /*not user specified, use the detected one*/ - // if (lan_ch == gcm_ch) strcpy(ifname,"gcm"); - sprintf(ifname,"%s%d",ifpattn,i); /*eth%d*/ - } - if (fdebug) printf("lan_ch = %d, ifname = %s\n",lan_ch,ifname); - - /* set the lan_user appropriately */ - if (myuser == NULL) { /* if no -u param */ - if (ipmi_reserved_user(vend_id, 1)) lan_user = 2; - else if (flansecure) lan_user = 2; - else lan_user = 1; /*use default null user */ - } else if (usernum != 0) lan_user = usernum; /*use -q specified usernum*/ - /* else use default lan_user (=2) if -u and not -q */ - - if (ftestonly) { /*test only if BMC LAN is configured or not */ - /* TODO: test gcm also, if present */ - ret = GetLanEntry(4, 0, &LanRecord); /*ip addr src*/ - if (ret == 0) { - if ((LanRecord.data[0] == SRC_BIOS) || - (LanRecord.data[0] == SRC_DHCP)) ret = 0; /* DHCP, so ok */ - else { /*static IP*/ - ret = GetLanEntry(3, 0, &LanRecord); /* ip address */ - if (ret == 0) { - if (!IpIsValid(LanRecord.data)) { - printf("invalid BMC IP address\n"); - ret = 1; /* invalid ip */ - } else ret = GetLanEntry(12, 0, &LanRecord); /*gateway ip*/ - if (ret == 0) { - if (!IpIsValid(LanRecord.data)) { - printf("invalid gateway ip\n"); - ret = 2; /*invalid gwy ip*/ - } else ret = GetLanEntry(13, 0, &LanRecord); - if (ret == 0) { - if (!MacIsValid(&LanRecord.data[0])) { - printf("invalid gateway mac\n"); - ret = 3; /*invalid gwy mac */ - } - } - } - } - } - } /*endif GetLanEntry ok*/ - if (ret == 0) printf("BMC LAN already configured\n"); - else printf("BMC LAN not configured\n"); - goto do_exit; - } /*endif ftestonly*/ - - memset(SessInfo,0,sizeof(SessInfo)); - ret = GetSessionInfo(SessInfo,sizeof(SessInfo)); - // rlen = sizeof(SessInfo)); ret = get_session_info(0,0,SessInfo,&rlen); - if (fdebug) printf("GetSessionInfo ret=%d, data: %02x %02x %02x %02x \n", - ret,SessInfo[0],SessInfo[1],SessInfo[2],SessInfo[3]); - if (!freadonly && fipmilan) { /* setting LAN params, and using IPMI LAN */ - if (SessInfo[2] > 1) { /* another session is active also */ - printf("Another session is also active, cannot change IPMI LAN settings now.\n"); - ret = ERR_NOT_ALLOWED; - goto do_exit; - } - } - - if (!fIPMI10) { - if (fcanonical) - { /* canonical/simple output */ - ret = GetPefEntry(0x01, 0,(PEF_RECORD *)&LanRecord); - if (ret != 0) ndest = 0; - else { /*success*/ - j = LanRecord.data[0]; - mystr[0] = 0; - if (j == 0) strcat(mystr,"none "); - else { - if (j & 0x01) strcat(mystr,"PEFenable "); - if (j & 0x02) strcat(mystr,"DoEventMsgs "); - if (j & 0x04) strcat(mystr,"Delay "); - if (j & 0x08) strcat(mystr,"AlertDelay "); - } - printf("PEF Control %s%c %s\n",pspace4,bdelim,mystr); - } - } else { /* normal/full output */ - ret = GetPefEntry(0x01, 0,(PEF_RECORD *)&LanRecord); - if (ret == 0 && (LanRecord.data[0] != 0)) { - fpefok = 1; - bmcpefctl = LanRecord.data[0]; - } else { /* skip PEF rules/params if disabled */ - printf("PEF Control %s%c %s\n",pspace4,bdelim,"none "); - ndest = 0; - fpefok = 0; - } - - if (fpefok) { - printf("%s, GetPefEntry ...\n",progname); - for (idx = 1; idx <= pefmax; idx++) - { - ret = GetPefEntry( 0x06, (ushort)idx, &PefRecord); - if (ret == 0) { // Show the PEF record - pc = (uchar *)&PefRecord; - sz = 21; // sizeof(PEF_RECORD) = 21 - if (PefRecord.sensor_type == 0) { - if (idx <= pefnum) - printf("PEFilter(%02d): empty\n",idx); - memcpy(pef_array[idx-1], &PefRecord, sz); - if (fAdjustPefNum) pefnum = (char)idx; - } else { - memcpy(pef_array[idx-1], &PefRecord, sz); - if (PefRecord.fconfig & 0x80) pb = "enabled"; - else pb = "disabled"; - i = PefRecord.rec_id; - switch(PefRecord.action) { - case 0x01: pa = "alert"; break; - case 0x02: pa = "poweroff"; break; - case 0x04: pa = "reset"; break; - case 0x08: pa = "powercycle"; break; - case 0x10: pa = "OEMaction"; break; - case 0x20: pa = "NMI"; break; - default: pa = "no action"; - } - printf("PEFilter(%02d): %02x %s event - %s for %s\n", - idx, PefRecord.sensor_type, - PefDesc(i,PefRecord.sensor_type), pb,pa); - } - if (fdebug) { /* show raw PEFilter record */ - pc = &PefRecord.rec_id; - printf("raw PEF(%.2d): ",pc[0]); - for (i = 0; i < sz; i++) printf("%02x ",pc[i]); - printf("\n"); - } - } else { - printf("GetPefEntry(%d), ret = %d\n",idx,ret); - if (ret == 0xC1) { /*PEF is not supported, so skip the rest. */ - fpefok = 0; - ndest = 0; /* if no PEF, no alerts & no alert dest */ - break; - } - } - } - } /*endif fpefok*/ - if (fpefok) { - if (fdebug) ShowPef(); - ret = GetPefEntry(0x01, 0,(PEF_RECORD *)&LanRecord); - if (ret == 0) { - j = LanRecord.data[0]; - mystr[0] = 0; - if (j & 0x01) strcat(mystr,"PEFenable "); - if (j & 0x02) strcat(mystr,"DoEventMsgs "); - if (j & 0x04) strcat(mystr,"Delay "); - if (j & 0x08) strcat(mystr,"AlertDelay "); - printf("PEF Control: %02x : %s\n",j, mystr); - } - ret = GetPefEntry(0x02, 0,(PEF_RECORD *)&LanRecord); - if (ret == 0) { - j = LanRecord.data[0]; - mystr[0] = 0; - if (j & 0x01) strcat(mystr,"Alert "); - if (j & 0x02) strcat(mystr,"PwrDn "); - if (j & 0x04) strcat(mystr,"Reset "); - if (j & 0x08) strcat(mystr,"PwrCyc "); - if (j & 0x10) strcat(mystr,"OEM "); - if (j & 0x20) strcat(mystr,"DiagInt "); - printf("PEF Actions: %02x : %s\n",j, mystr); - } - ret = GetPefEntry(0x03, 0,(PEF_RECORD *)&LanRecord); - if (ret == 0) printf("PEF Startup Delay: %02x : %d sec\n", - LanRecord.data[0],LanRecord.data[0]); - if (!fmBMC) { - ret = GetPefEntry(0x04, 0,(PEF_RECORD *)&LanRecord); - if (ret == 0) printf("PEF Alert Startup Delay: %02x: %d sec\n", - LanRecord.data[0],LanRecord.data[0]); - /* fmBMC gets cc=0x80 here */ - } - /* note that ndest should be read from lan param 17 below. */ - for (i = 1; i <= ndest; i++) - { - ret = GetPefEntry(0x09, (ushort)i,(PEF_RECORD *)&LanRecord); - if (ret == 0) { - mystr[0] = 0; - j = LanRecord.data[2]; - if (LanRecord.data[1] & 0x08) { - sprintf(mystr,"Chan[%d] Dest[%d] ",((j & 0xf0) >> 4),(j & 0x0f)); - strcat(mystr,"Enabled "); - } else strcpy(mystr,"Disabled "); - printf("PEF Alert Policy[%d]: %02x %02x %02x %02x : %s\n",i, - LanRecord.data[0], LanRecord.data[1], - LanRecord.data[2], LanRecord.data[3],mystr); - } - } /*endfor ndest*/ - } /*endif fpefok*/ - } /*endif not canonical*/ - - if (fpefenable && !freadonly) { /* fenable or fdisable */ - if (fSetPEFOks) pefadd = 5; - else pefadd = 2; - sz = (pefnum - 1) + pefadd + fCustomPEF; - printf("\n%s, SetPefEntry(1-%d) ...\n",progname,sz); - if (fdebug) printf("pefnum = %d, pefmax = %d\n",pefnum,pefmax); - for (idx = 1; idx <= pefmax; idx++) - { - // Set & Enable all PEF records - memset(&PefRecord.rec_id,0,sizeof(PEF_RECORD)); - PefRecord.rec_id = (uchar)idx; /* next record, or user-specified */ - if (idx < pefnum) { /* pefnum defaults to 12.(0x0c) */ - if (pef_array[idx-1][7] == 0) /*empty pef record, set to default*/ - memcpy(&PefRecord.rec_id,pef_defaults[idx-1],sizeof(PEF_RECORD)); - else { /* set config however it was previously */ - memcpy(&PefRecord.rec_id,pef_array[idx-1],sizeof(PEF_RECORD)); - if (PefRecord.severity == 0) - PefRecord.severity = pef_defaults[idx-1][4]; - } - } else if ((idx == pefnum) && /* new OS Crit Stop entry */ - (PefRecord.sensor_type == 0)) { - // Set PEF values for 0x20, OS Critical Stop event - PefRecord.severity = PEF_SEV_CRIT; - PefRecord.genid1 = 0xff; - PefRecord.genid2 = 0xff; - PefRecord.sensor_type = 0x20; /* OS Critical Stop */ - PefRecord.sensor_no = 0xff; - PefRecord.event_trigger = 0x6f; - PefRecord.data1 = 0xff; - PefRecord.mask1 = 0x00; - } else if ((idx == pefnum+1) && /* new Power Redundancy entry */ - (PefRecord.sensor_type == 0)) { - // Set PEF values for 0x09/0x02/0x0b/0x41, Power Redundancy Lost - PefRecord.severity = PEF_SEV_WARN; - PefRecord.genid1 = 0xff; - PefRecord.genid2 = 0xff; - PefRecord.sensor_type = 0x09; /* Power Unit */ - PefRecord.sensor_no = 0xff; /* usu 01 or 02 */ - PefRecord.event_trigger = 0x0b; /* event trigger */ - PefRecord.data1 = 0x02; /* 02 -> 41=Redundancy Lost */ - PefRecord.mask1 = 0x00; - } else if (fSetPEFOks && idx == (pefnum+2)) { - PefRecord.severity = PEF_SEV_OK; - PefRecord.genid1 = 0xff; - PefRecord.genid2 = 0xff; - PefRecord.sensor_type = 0x09; /* Power Unit, Redund OK */ - PefRecord.sensor_no = 0xff; /* usu 01 or 02 */ - PefRecord.event_trigger = 0x0b; /* event trigger */ - PefRecord.data1 = 0x01; /* 01 -> 40=Redundancy OK */ - PefRecord.mask1 = 0x00; - } else if (fSetPEFOks && idx == (pefnum+3)) { - PefRecord.severity = PEF_SEV_OK; - PefRecord.genid1 = 0xff; - PefRecord.genid2 = 0xff; - PefRecord.sensor_type = 0x01; /* Temp OK */ - PefRecord.sensor_no = 0xff; /* usu 01 or 02 */ - PefRecord.event_trigger = 0x81; /* event trigger */ - PefRecord.data1 = 0x95; /* 95 -> 50(NC),52(Crit) match */ - PefRecord.mask1 = 0x0a; - } else if (fSetPEFOks && idx == (pefnum+4)) { - PefRecord.severity = PEF_SEV_OK; - PefRecord.genid1 = 0xff; - PefRecord.genid2 = 0xff; - PefRecord.sensor_type = 0x02; /* Voltage OK */ - PefRecord.sensor_no = 0xff; /* usu 01 or 02 */ - PefRecord.event_trigger = 0x81; /* event trigger */ - PefRecord.data1 = 0x95; /* 95 -> 50(NC),52(Crit) match */ - PefRecord.mask1 = 0x0a; - } else if (fCustomPEF && idx == (pefnum+pefadd)) { - /* user entered 10 or 18 PEF entry bytes */ - PefRecord.action = custPEF[0]; - PefRecord.policy = custPEF[1]; - PefRecord.severity = custPEF[2]; - PefRecord.genid1 = custPEF[3]; - PefRecord.genid2 = custPEF[4]; - PefRecord.sensor_type = custPEF[5]; - PefRecord.sensor_no = custPEF[6]; - PefRecord.event_trigger = custPEF[7]; - PefRecord.data1 = custPEF[8]; - PefRecord.mask1 = custPEF[9]; - memcpy(&PefRecord.action,custPEF,18); - } else { - memcpy(&PefRecord.rec_id,pef_array[idx-1],sizeof(PEF_RECORD)); - if (PefRecord.sensor_type == 0) continue; /* if reserved, skip it */ - } - if (fdebug && (PefRecord.rec_id != idx)) { - /* memcpy from pef_defaults or pef_array clobbered rec_id */ - printf("Warning: SetPef idx=%d, rec_id=%d\n",idx,PefRecord.rec_id); - PefRecord.rec_id = (uchar)idx; /*fix it*/ - } - if (fdisable) { - /* Disable all PEF rules */ - if (idx >= pefnum) PefRecord.fconfig = 0x00; /*disabled, software*/ - else PefRecord.fconfig = 0x40; /*disabled, preset */ - PefRecord.action = 0x00; - PefRecord.policy = 0x00; - } else { /*fenable*/ - if (PefRecord.sensor_type != 0) { /* not an empty PEF entry */ - /* Enable all non-empty PEF rules */ - if (fCustomPEF && (idx == (pefnum+pefadd))) { - PefRecord.action = custPEF[0]; - PefRecord.policy = custPEF[1]; - } else { - PefRecord.action = 0x01; /*Alert*/ - PefRecord.policy = 0x01; /*see Alert Policy #1*/ - } - if (idx < pefnum) { /* special handling for presets, 1 thru 11 */ - PefRecord.fconfig = 0x80; /* enabled, software */ - ret = SetPefEntry(&PefRecord); - if (fdebug) - printf("SetPefEntry(%d/80) ret=%d\n",PefRecord.rec_id,ret); - // if (ret != 0) { nerrs++; lasterr = ret; } - // else ngood++; - PefRecord.fconfig = 0xC0; /* enabled, preset */ - } else { - PefRecord.fconfig = 0x80; /* enabled, software */ - } - } /*endif not empty*/ - } - { // Show the new PEF record before setting it. - pc = (uchar *)&PefRecord; - sz = 21; - printf("PEFilter(%d): ",PefRecord.rec_id); - for (i = 0; i < sz; i++) printf("%02x ",pc[i]); - printf("\n"); - } - ret = SetPefEntry(&PefRecord); - if (fdebug) - printf("SetPefEntry(%d) ret = %d\n", PefRecord.rec_id,ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } /*end for*/ - } - } /*end if not fIPMI10*/ - - if (!fcanonical) - printf("\n%s, GetLanEntry for channel %d ...\n",progname,lan_ch); - idest = 1; - for (idx = 0; idx < NLAN; idx++) - { - int ival; - if (fcanonical && (canon_param[idx] == 0)) continue; - if (idx == 8 || idx == 9) continue; /* not implemented */ - ival = lanparams[idx].cmd; - if (ival >= 96 && ival <= 98) continue; /* not implemented */ - if (ival >= 102 && ival <= 108) { /*custom IPv6 parameters*/ - if (fipv6 == 0) continue; /*skip these*/ - } - if (ival == 194 && vend_id == VENDOR_KONTRON) { /*oem hostname parm*/ - lanparams[idx].sz = 36; - strcpy(lanparams[idx].desc,"IPMI Hostname"); - } else if (ival >= 192 && ival <= 194) { /*custom DHCP parameters*/ - if (vend_id != VENDOR_INTEL) continue; - if (fmBMC || fiBMC || fcanonical) continue; /*skip these*/ - } - if (ival >= 20 && ival <= 25) { - if (!fIPMI20) continue; /*VLAN params 20-25, fIPMI20 only/opt*/ - } - if ((ndest == 0) && (ival >= 18 && ival <= 19)) continue; /*skip dest*/ - if (ival == 11) { /*grat arp interval*/ - if (vend_id == VENDOR_SUPERMICROX) continue; - if (vend_id == VENDOR_SUPERMICRO) continue; - } - if (ival == 14 || ival == 15) { /*secondary gateway is optional*/ - if (vend_id == VENDOR_KONTRON) continue; - } - if (ival == 201) { /*Get Channel Access*/ - ret = ShowChanAcc(lan_ch); - } else { - if (ival == 18 || ival == 19) { /*dest params*/ - if (ndest == 0) continue; /*skip if ndest==0 */ - bset = (uchar)idest; /* dest id = 1 thru n */ - } else bset = 0; - ret = GetLanEntry((uchar)ival, bset, &LanRecord); - } - if (ret == 0) { // Show the LAN record - pc = (uchar *)&LanRecord; - sz = lanparams[idx].sz; - if (ival == 18) { /*skip if invalid dest type param*/ - if ((idest > 1) && (pc[2] == 0)) { idest = 1; continue; } - } else if (ival == 19) { /*skip if invalid dest addr param*/ - if ((idest > 1) && !IpIsValid(&pc[3])) { idest = 1; continue; } - } - if (ival == 201) ; /* did it above */ - else { - if (fcanonical) { - if ((ival == 19) && (idest > 1)) ; /*skip it*/ - else { - j = strlen_(lanparams[idx].desc); - // (ival < 7) || (ival == 19) || ival == 102) - if (j <= 12) pstr = pspace3; - else pstr = pspace2; - printf("Channel %d %s %s%c ",lan_ch, - lanparams[idx].desc,pstr,bdelim); - } - } else - printf("Lan Param(%d) %s: ",ival,lanparams[idx].desc); - } - if (ival == 1) { - authmask = pc[0]; /* auth type support mask */ - /* if (fmBMC) authmask is usually 0x15, else 0x14 */ - } else if (ival == 3) { - if (IpIsValid(pc)) memcpy(bmcmyip,pc,4); - } else if (ival == 5) { - if (MacIsValid(pc)) memcpy(bmcmymac,pc,MAC_LEN); - } else if (ival == 6) { - if (SubnetIsValid(pc)) memcpy(bmcsubnet,pc,4); - /* else if invalid, leave default as 255.255.255.0 */ - //} else if (ival == 7) { - // if (pc[0] >= 30) memcpy(bparm7,pc,3); - } else if (ival == 17) { /* num dest */ - ndest = pc[0]; /* save the number of destinations */ - } else if (ival == 12) { /* gateway addr */ - if (IpIsValid(pc)) memcpy(bmcgwyip,pc,4); - } else if (ival == 13) { /* gateway mac */ - if (MacIsValid(pc)) memcpy(bmcgwymac,pc,MAC_LEN); - } else if (ival == 19) { /* dest addr */ - if (IpIsValid(&pc[3])) memcpy(bmcdestip,&pc[3],4); - if (MacIsValid(&pc[7])) memcpy(bmcdestmac,&pc[7],MAC_LEN); - } else if (ival == 22) { /*Cipher Suite Support*/ - nciphers = pc[0]; - } - /* now start to display data */ - if (ival == 16) { printf("%s \n",pc); /* string */ - } else if (ival == 194 && vend_id == VENDOR_KONTRON) { - printf("%s \n",pc); /* string */ - } else if (ival == 201) { ; /* did it above */ - } else { /* print results for all other ival's */ - pstr = ""; /*interpreted meaning*/ - if (fcanonical) { - switch(ival) { - case 4: /*param 4, ip src*/ - if (pc[0] == SRC_STATIC) pstr = "Static"; /*0x01*/ - else if (pc[0] == SRC_DHCP) pstr = "DHCP"; /*0x02*/ - else if (pc[0] == SRC_BIOS) pstr = "BIOS"; /*0x03*/ - else pstr = "Other"; - printf("%s\n",pstr); - break; - case 5: /*param 5, mac addr*/ - case 13: /*param 6, def gwy mac*/ - printf("%02x:%02x:%02x:%02x:%02x:%02x\n", - pc[0], pc[1], pc[2], pc[3], pc[4], pc[5]); - break; - case 3: /*param 4, ip address*/ - case 6: /*param 6, subnet mask*/ - case 12: /*param 12, def gwy ip*/ - case 14: /*param 14, sec gwy ip*/ - case 192: /*param 192, DHCP svr ip*/ - printf("%d.%d.%d.%d\n",pc[0], pc[1], pc[2], pc[3]); - break; - case 19: /*param 19, dest address*/ - if (idest == 1) { - printf("IP=%d.%d.%d.%d " - "MAC=%02x:%02x:%02x:%02x:%02x:%02x\n", - pc[3], pc[4], pc[5], pc[6], - pc[7], pc[8], pc[9], pc[10], pc[11], pc[12]); - } - break; - case 102: /*param 102, IPv6 enable*/ - if (pc[0] == 0x01) printf("enabled\n"); - else printf("disabled\n"); - break; - default: - printf("%02x \n",pc[0]); - break; - } - } else { /*not canonical */ - if (ival == 3 || ival == 6 || ival == 12 || ival == 14 - || ival == 192) { - printf("%d.%d.%d.%d",pc[0], pc[1], pc[2], pc[3]); - } else if (ival == 23) { /*Cipher Suites*/ - for (i = 1; i <= nciphers; i++) { - if (pc[i] == 0) ncipher0 = pc[i]; - printf("%2d ",pc[i]); - } - } else if (ival == 24) { /*Cipher Suite Privi Levels*/ - j = 0; - for (i = 1; i < 9; i++) { - char c1, c2; - char *p; - p = parse_priv((pc[i] & 0x0f)); - c1 = p[0]; - p = parse_priv((pc[i] & 0xf0) >> 4); - c2 = p[0]; - rgciphers[j++] = (pc[i] & 0x0f); - rgciphers[j++] = ((pc[i] & 0xf0) >> 4); - if ((i*2) >= nciphers) c2 = ' '; - printf(" %c %c ",c1,c2); - if ((i*2) > nciphers) break; - } -} else - for (i = 0; i < sz; i++) -{ - /* print in hex, decimal, or string, based on ival */ - if (ival == 1) { /* Auth type support */ - pstr = &mystr[0]; - getauthstr(authmask,pstr); - printf("%02x ",authmask); - } else if (ival == 4) { /* IP addr source */ - if (pc[i] == SRC_STATIC) pstr = "Static"; /*0x01*/ - else if (pc[i] == SRC_DHCP) pstr = "DHCP"; /*0x02*/ - else if (pc[i] == SRC_BIOS) pstr = "BIOS"; /*0x03*/ - else pstr = "Other"; - printf("%02x ",pc[i]); - } else if (ival == 10) { /* grat ARP */ - mystr[0] = 0; - if (pc[i] == 0) strcat(mystr,"ARP disabled "); - else if (pc[i] & 0x01) strcat(mystr,"Grat-ARP enabled"); - else strcat(mystr,"Grat-ARP disabled"); - if (pc[i] & 0x02) strcat(mystr,", ARP-resp enabled"); - pstr = &mystr[0]; - printf("%02x ",pc[i]); - } else if (ival == 11) { /* grat ARP interval */ - float f; - f = (float)pc[i] / (float)2; /*500msec increments*/ - sprintf(mystr,"%.1f sec",f); - pstr = &mystr[0]; - printf("%02x ",pc[i]); - } else if (ival == 19) { /* dest addr */ - if (i > 2 && i < 7) { - char *sepstr; - if (i == 3) printf("["); - if (i == 6) sepstr = "] "; - else if (i >=3 && i < 6) sepstr = "."; - else sepstr = " "; - printf("%d%s",pc[i],sepstr); /* IP address in dec */ - } - else printf("%02x ",pc[i]); /* show mac/etc. in hex */ - } - else printf("%02x ",pc[i]); /* show in hex */ - } /*end for*/ -if (ival == 2) { /*Auth type enables*/ - pstr = &mystr[0]; - i = 0; - if (lan_ch > 0) i = lan_ch - 1; - getauthstr(pc[i],pstr); -} - if (pstr[0] != 0) printf(": %s\n",pstr); - else printf("\n"); - } /*end-else not canonical*/ - } /*end-else others*/ - if (ival == 18 || ival == 19) { -if (idest < ndest) { - idest++; - idx--; /* repeat this param*/ -} else idest = 1; - } - } else { /* ret != 0 */ - if (ival >= 20 && ival <= 25) { /*if errors, optional*/ - if (fdebug) printf("GetLanEntry(%d), ret = %d\n",ival,ret); - } else - printf("GetLanEntry(%d), ret = %d\n",ival,ret); - if (ival == 17) ndest = 0; /*error getting num dest*/ - } - } /*end for*/ - if (fRomley || fGrantley) { /*get LAN Failover param*/ - uchar b; - ret = lan_failover_intel(0xFF,(uchar *)&b); - if (ret != 0) - printf("Intel Lan Failover, ret = %d\n",ret); - else { - if (b == 1) pstr = "enabled"; - else pstr = "disabled"; - if (fcanonical) - printf("Intel Lan Failover %s%c %s\n", - pspace3, bdelim,pstr); - else printf("Intel Lan Failover %s%c %02x %c %s\n", - pspace2, bdelim,b,bdelim,pstr); - } - } - if (vend_id == VENDOR_SUPERMICROX || vend_id == VENDOR_SUPERMICRO) { - ret = oem_supermicro_get_lan_port(&bset); - if (ret == 0) { - pstr = oem_supermicro_lan_port_string(bset); - if (fcanonical) - printf("SuperMicro Lan Interface %s%c %s\n", - pspace2, bdelim,pstr); - else printf("SuperMicro Lan Interface %c %02x %c %s\n", - bdelim,bset,bdelim,pstr); - } else { - if (fdebug) printf("oem_supermicro_get_lan_port error %d\n",ret); - ret = 0; /*may not be supported on all smc plaforms*/ - } - } - // if (fmBMC) lan_access = 0x04; /*Admin*/ - // else lan_access = 0x04; /*Admin*/ - if (!fIPMI10) { /* Get SOL params */ - ret = GetSerialOverLan(lan_ch,0,0); - if (ret != 0) printf("GetSOL error %d\n",ret); - } - for (i = 1; i <= show_users; i++) - GetUser((uchar)i,lan_ch); - - if (fgetser && !fcanonical) { - printf("\n%s, GetSerEntry ...\n",progname); - if (fmBMC) /* mBMC doesn't support serial */ - printf("No serial channel support on this platform\n"); - else - for (idx = 0; idx < NSER; idx++) { - int ival; - // if (idx == 9) continue; /* not implemented */ - ival = serparams[idx].cmd; - if (ival == 201) { - ret = GetChanAcc(ser_ch, 0x40, &LanRecord); - } else { - ret = GetSerEntry((uchar)ival, &LanRecord); - } - if (ret == 0) { // Show the SER record - pc = (uchar *)&LanRecord; - sz = serparams[idx].sz; - printf("Serial Param(%d) %s: ",ival,serparams[idx].desc); - if (idx == 10) { /* modem init string */ - pc[sz] = 0; - printf("%02x %s\n",pc[0],&pc[1]); - } - else if ((idx >= 11 && idx <= 13) || idx == 15) { /* strings */ - printf("%s\n",pc); - } - else { - for (i = 0; i < sz; i++) { -printf("%02x ",pc[i]); /* show in hex */ -} - printf("\n"); - } /*end else*/ - } - } /*end for*/ - } /*endif fgetser*/ - - if (!freadonly) /* Set IPMI LAN enable/disable params. */ - { - if (fipmilan) /* Sets not valid via ipmi_lan if same channel. */ - printf("\nWarning: Setting LAN %d params while using a LAN channel.\n", lan_ch); - - { - if (fenable && (fsharedMAC==0) && !lan_dhcp) { - /* must have an IP from -I option */ - if (!IpIsValid(rgmyip)) { /* if not user-specified */ - if (IpIsValid(bmcmyip)) { - memcpy(rgmyip,bmcmyip,4); - if (fdebug) printf("Using current IP %d.%d.%d.%d\n", - bmcmyip[0], bmcmyip[1], - bmcmyip[2], bmcmyip[3]); - } else { - printf("\nNot shared BMC LAN, must specify a unique " - "IP address via -I\n"); - ret = ERR_BAD_PARAM; - goto do_exit; - } - } - } - /* Set LAN parameters. fenable or fdisable */ - printf("\n%s, SetLanEntry for channel %d ...\n",progname,lan_ch); - /* use ifname to resolve MAC addresses below */ - if (fdisable) { - if (!fIPMI10) { - ret = DisablePef(alertnum); - printf("DisablePef, ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } -else ngood++; - } - if (lan_user != 0) { - j = DisableUser(lan_user,lan_ch); /*disable this lan user*/ - printf("DisableUser(%d), ret = %d\n",lan_user,j); - if (j != 0) { nerrs++; lasterr = j; } - else ngood++; - } - LanRecord.data[0] = 0x01; /* static IP address source */ - ret = SetLanEntry(4, &LanRecord, 1); - printf("SetLanEntry(4), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - /* clear the BMC IP address */ - memset(&LanRecord,0,4); - ret = SetLanEntry(3, &LanRecord, 4); - printf("SetLanEntry(3), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - /* clear the gateway IP address */ - memset(&LanRecord,0,4); - ret = SetLanEntry(12, &LanRecord, 4); - printf("SetLanEntry(12), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - /* clear the gateway MAC address */ - memset(&LanRecord,0,6); - ret = SetLanEntry(13, &LanRecord, 6); - printf("SetLanEntry(13), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } else if (fdisableSOL) { - ret = SetupSerialOverLan(0); /*disable*/ - SELprintf("SetupSerialOverLan: ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } else { /*fenable*/ - uchar chanctl; - if (bmcpefctl != 0) chanctl = chan_pefon; /*previously on*/ - else chanctl = chan_pefoff; - ret = SetChanAcc(lan_ch, 0x80, chanctl); - if (fdebug) printf("SetChanAcc(lan/active), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - ret = SetChanAcc(lan_ch, 0x40, chanctl); - if (fdebug) printf("SetChanAcc(lan/nonvol), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - if (flansecure) { - j = DisableUser(0,lan_ch); /*disable the default null user*/ - printf("DisableUser(0), ret = %d\n",j); - } - ret = SetUser(lan_user,myuser,passwordData,lan_ch); - printf("SetUser(%d), ret = %d\n",lan_user,ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - if (fdisable && (vend_id == VENDOR_SUPERMICROX - || vend_id == VENDOR_SUPERMICRO) ) { - failover_enable = 0; /*dedicated*/ - ret = oem_supermicro_set_lan_port(failover_enable); - printf("Set SuperMicro Lan port to %s, ret = %d\n", - oem_supermicro_lan_port_string(failover_enable),ret); - if (ret != 0) { nerrs++; lasterr = ret; } - } - - if (fdisable || fdisableSOL) { -// if (nerrs > 0) printf("Warning: %d errors occurred\n",nerrs); - goto do_exit; - } - - if (authmask == 0) authmask = 0x17; /*if none from GetLanEntry(1)*/ - LanRecord.data[0] = (bAuth & authmask); /*Callback level*/ - LanRecord.data[1] = (bAuth & authmask); /*User level */ - LanRecord.data[2] = (bAuth & authmask); /*Operator level*/ - LanRecord.data[3] = (bAuth & authmask); /*Admin level */ - LanRecord.data[4] = 0; /*OEM level*/ - if (fdebug) printf("SetLanEntry(2): %02x %02x %02x %02x %02x\n", - LanRecord.data[0],LanRecord.data[1],LanRecord.data[2], - LanRecord.data[3],LanRecord.data[4]); - ret = SetLanEntry(2, &LanRecord, 5); - printf("SetLanEntry(2), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - - /* Get the values to use from Linux eth0, etc. */ - ret = Get_IPMac_Addr(); - if (lan_dhcp) { /* use DHCP */ - LanRecord.data[0] = SRC_DHCP; /* BMC running DHCP */ - /* = SRC_BIOS; * address source = BIOS using DHCP */ - ret = SetLanEntry(4, &LanRecord, 1); - printf("SetLanEntry(4), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - if (MacIsValid(rgmymac)) { - memcpy(&LanRecord,rgmymac,6); - ret = SetLanEntry(5, &LanRecord, 6); - if (ret == 0x82) { /*BMC may not allow the MAC to be set*/ - if (fdebug) - printf("SetLanEntry(5), ret = %x cannot modify MAC\n",ret); - } else { - printf("SetLanEntry(5), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - } - - /* DHCP also relates to OEM LAN params 192, 193, 194 */ - if ((vend_id == VENDOR_INTEL) && !fmBMC && !fiBMC) - { /*DHCP params 192-194 are Intel only*/ - if (IpIsValid(rgmyip)) - { - /* Set DHCP Server IP in param 192 from -I param. */ - memcpy(&LanRecord,rgmyip,4); - ret = SetLanEntry(192, &LanRecord, 4); - printf("SetLanEntry(192), ret = %d\n",ret); - if (!MacIsValid(rgdhcpmac)) /* if MAC not set yet */ - ret = Get_Mac(rgmyip,rgdhcpmac,NULL); - if (ret == 0) { - memcpy(&LanRecord,rgdhcpmac,MAC_LEN); - ret = SetLanEntry(193, &LanRecord, MAC_LEN); - printf("SetLanEntry(193), ret = %d\n",ret); - } - } - LanRecord.data[0] = 0x01; /*enable DHCP*/ - ret = SetLanEntry(194, &LanRecord, 1); - printf("SetLanEntry(194), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - } else { /* use static IP */ - printf("LAN%d (%s)\tip=%d.%d.%d.%d mac=%02x:%02x:%02x:%02x:%02x:%02x\n", -lan_ch,ifname, rgmyip[0], rgmyip[1], rgmyip[2], rgmyip[3], -rgmymac[0], rgmymac[1], rgmymac[2], rgmymac[3], -rgmymac[4], rgmymac[5]); - if (IpIsValid(rgmyip)) { - if (lan_ch != gcm_ch) { /*skip if gcm*/ - LanRecord.data[0] = 0x00; /*disable grat arp while setting IP*/ - ret = SetLanEntry(10, &LanRecord, 1); - if (fdebug) printf("SetLanEntry(10,0), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - } - LanRecord.data[0] = 0x01; /* static IP address source */ - ret = SetLanEntry(4, &LanRecord, 1); - printf("SetLanEntry(4), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - memcpy(&LanRecord,rgmyip,4); - ret = SetLanEntry(3, &LanRecord, 4); - printf("SetLanEntry(3), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - if (MacIsValid(rgmymac)) { - memcpy(&LanRecord,rgmymac,6); - ret = SetLanEntry(5, &LanRecord, 6); - if (ret == 0x82) { - - /* Do not show anything, not an error if BMC does not - allow the BMC MAC to be changed. */ - if (fdebug) - - printf("SetLanEntry(5), ret = %x cannot modify MAC\n",ret); - } else { - - printf("SetLanEntry(5), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - } - if (!SubnetIsValid(rgsubnet)) /* not specified, use previous */ - memcpy(rgsubnet,bmcsubnet,4); - memcpy(&LanRecord,rgsubnet,4); - ret = SetLanEntry(6, &LanRecord, 4); - printf("SetLanEntry(6), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - if (vend_id != VENDOR_PEPPERCON) { - /* may want to check bparm7 here */ - LanRecord.data[0] = parm7[0]; /*IPv4 header, TTL */ - LanRecord.data[1] = parm7[1]; /*IPv4 header, Flags */ - LanRecord.data[2] = parm7[2]; /*IPv4 hdr, Precedence/Service */ - ret = SetLanEntry(7, &LanRecord, 3); - printf("SetLanEntry(7), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - /* if lan_ch == 3, gcm gets error setting grat arp (ccode=0xCD) */ - if (lan_ch != gcm_ch) { /*skip if gcm*/ - /* 01=enable grat arp, 02=enable arp resp, 03=both */ - LanRecord.data[0] = arp_ctl; /*grat arp*/ - ret = SetLanEntry(10, &LanRecord, 1); - printf("SetLanEntry(10,%x), ret = %d\n",arp_ctl,ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - LanRecord.data[0] = arp_interval; /*grat arp interval*/ - ret = SetLanEntry(11, &LanRecord, 1); - printf("SetLanEntry(11), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - if ((vend_id == VENDOR_INTEL) && !fmBMC && !fiBMC) { - LanRecord.data[0] = 0x00; /*disable DHCP*/ - ret = SetLanEntry(194, &LanRecord, 1); - printf("SetLanEntry(194), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - } else { /* error, don't continue */ - printf("Missing IP Address, can't continue. Use -I to specify\n"); - ret = ERR_BAD_PARAM; - goto do_exit; - } - if (vend_id == VENDOR_KONTRON && rghostname[0] != 0) { - /* set the IPMI Hostname if specified */ - sz = strlen_(rghostname); - /* LanRecord is larger than rghostname, bounds ok */ - strncpy((char *)&LanRecord.data,rghostname,sz); - ret = SetLanEntry(194, &LanRecord, sz); - printf("SetLanEntry(194), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else { - LanRecord.data[0] = 0x31; - ret = SetLanEntry(195, &LanRecord, 1); /*re-read hostname*/ - // printf("SetLanEntry(195), ret = %d\n",ret); - // if (ret != 0) { nerrs++; lasterr = ret; } - } - } - if (IpIsValid(rggwyip)) { - if (!MacIsValid(rggwymac)) /* if gwy MAC not set by user */ - ret = Get_Mac(rggwyip,rggwymac,NULL); - printf("gateway \tip=%d.%d.%d.%d mac=%02x:%02x:%02x:%02x:%02x:%02x\n", - rggwyip[0], rggwyip[1], rggwyip[2], rggwyip[3], - rggwymac[0], rggwymac[1], rggwymac[2], rggwymac[3], - rggwymac[4], rggwymac[5]); - if (!SubnetIsSame(rgmyip,rggwyip,rgsubnet)) { - printf("WARNING: IP Address and Gateway are not on the same subnet," -" setting Gateway to previous value\n"); - memcpy(rggwyip,bmcgwyip,4); - memcpy(rggwymac,bmcgwymac,6); - } - - /* Set the Default Gateway IP & MAC */ - memcpy(&LanRecord,rggwyip,4); - ret = SetLanEntry(12, &LanRecord, 4); - printf("SetLanEntry(12), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - if (!MacIsValid(rggwymac)) { /* if gwy MAC not resolved */ - printf(" Warning: Gateway MAC address was not resolved! " - "Check %s interface, use -i ethN, or use -H gwymac.\n", - ifname); - memcpy(&LanRecord,bmcgwymac,6); - } else { - memcpy(&LanRecord,rggwymac,6); - } - ret = SetLanEntry(13, &LanRecord, 6); - printf("SetLanEntry(13), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - if (IpIsValid(rggwy2ip)) { - if (!MacIsValid(rggwy2mac)) /* if gwy2 MAC not set by user */ - ret = Get_Mac(rggwy2ip,rggwy2mac,NULL); - /* Set the Secondary Gateway IP & MAC */ - memcpy(&LanRecord,rggwy2ip,4); - ret = SetLanEntry(14, &LanRecord, 4); - printf("SetLanEntry(14), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - memcpy(&LanRecord,rggwy2mac,6); - ret = SetLanEntry(15, &LanRecord, 6); - printf("SetLanEntry(15), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - } /* end-else static IP */ - if (flansecure) { /* disable cipher 0 */ - char c1, c2; - memset(&LanRecord,0,12); - j = 1; - for (i = 0; i < nciphers; i+=2) { - c1 = rgciphers[i]; - c2 = rgciphers[i+1]; - /* 0x0f may be vendor-specific, 0x00 = Reserved/Unused */ - if (i == ncipher0) c1 = 0x00; - if ((i+1) == ncipher0) c2 = 0x00; - LanRecord.data[j++] = (c2 << 4) | c1; - } - ret = SetLanEntry(24, &LanRecord, 9); - printf("SetLanEntry(24) disable cipher0, ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - ret = SetupSerialOverLan(1); /*enable*/ - SELprintf("SetupSerialOverLan: ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - if (!IpIsValid(rgdestip) && IpIsValid(bmcdestip)) { - memcpy(rgdestip,bmcdestip,4); - if (fdebug) printf("Using current dest IP %d.%d.%d.%d\n", - bmcdestip[0], bmcdestip[1], - bmcdestip[2], bmcdestip[3]); - } - if (ndest == 0) { - if (fdebug) printf("ndest==0, anum=%d rgdestip=%d.%d.%d.%d\n", - alertnum, rgdestip[0], rgdestip[1], rgdestip[2], rgdestip[3]); - printf("alert dest \tnot supported\n"); - } else if (!IpIsValid(rgdestip)) { - printf("alert dest \taddress not specified\n"); - } else { /* valid alert dest ip */ - if (!MacIsValid(rgdestmac)) /* if dest MAC not set by user */ - ret = Get_Mac(rgdestip,rgdestmac,NULL); /*try to resolve MAC */ - if (!MacIsValid(rgdestmac)) { /* if dest MAC not resolved */ - printf(" Warning: Alert mac address was not resolved!" - " Check %s interface or use -i.\n",ifname); - /* use existing BMC alert dest mac (as best guess) */ - memcpy(rgdestmac,bmcdestmac,6); - } - /* show destination data */ - printf("alert dest %d\tip=%d.%d.%d.%d mac=%02x:%02x:%02x:%02x:%02x:%02x\n", - alertnum, rgdestip[0], rgdestip[1], rgdestip[2], rgdestip[3], - rgdestmac[0], rgdestmac[1], rgdestmac[2], rgdestmac[3], - rgdestmac[4], rgdestmac[5]); - printf("snmp community \t%s\n",rgcommunity); - /* Only need the SNMP community if there is an Alert Destination */ - memset(&LanRecord.data[0], 0, 18); /* make sure zero-filled */ - strcpy((char *)&LanRecord.data[0],rgcommunity); - ret = SetLanEntry(16, &LanRecord, 18); - printf("SetLanEntry(16), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - /* Set Alert Destination Type */ - LanRecord.data[0] = alertnum; /* dest id = 1 */ - LanRecord.data[1] = 0x00; /* dest type = PET, no ack */ - LanRecord.data[2] = 0x01; /* ack timeout / retry interval */ - LanRecord.data[3] = 0x00; /* no retries */ - // LanRecord.data[4] = 0x69; - ret = SetLanEntry(18, &LanRecord, 4); - printf("SetLanEntry(18), ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - { - /* Set the Alert Destination IP & MAC (param 19) */ - LanRecord.data[0] = alertnum; /* dest id = 1 */ - LanRecord.data[1] = 0x00; - LanRecord.data[2] = 0x00; - memcpy(&LanRecord.data[3],rgdestip,4); - memcpy(&LanRecord.data[7],rgdestmac,6); - ret = SetLanEntry(19, &LanRecord, 13); - printf("SetLanEntry(19), ret = %d\n", ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - } /*endif valid alert*/ - - /* Now enable PEF since we have an Alert destination. */ - if (!fdisable && !fIPMI10 && fpefenable) { /*fpefenable*/ - ret = EnablePef(alertnum); - printf("EnablePef, ret = %d\n",ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - /* ChanAcc changed, so show it again */ - j = ShowChanAcc(lan_ch); - } - - if ((vlan_enable != PARM_INIT) && (fIPMI20)) { - if (vlan_enable == 0) { /*disable vlan*/ - LanRecord.data[0] = 0x00; - LanRecord.data[1] = 0x00; - ret = SetLanEntry(20, &LanRecord, 2); - printf("SetLanEntry(20,disable) ret = %d\n", ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } else { /*vlan_enable == 1, enable vlan with id */ - LanRecord.data[0] = (vlan_id & 0x00ff); - LanRecord.data[1] = ((vlan_id & 0x0f00) >> 8) | 0x80; - ret = SetLanEntry(20, &LanRecord, 2); - printf("SetLanEntry(20,%d), ret = %d\n", vlan_id,ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - LanRecord.data[0] = vlan_prio; - ret = SetLanEntry(21, &LanRecord, 1); - printf("SetLanEntry(21), ret = %d\n", ret); - if (ret != 0) { nerrs++; lasterr = ret; } - else ngood++; - } - } - if (failover_enable != PARM_INIT) { - if (fRomley || fGrantley) { - if (failover_enable > 1) failover_enable = 0; /*default*/ - ret = lan_failover_intel(failover_enable,(uchar *)&i); - printf("Set Intel Lan Failover (%d), ret = %d\n", - failover_enable,ret); - if (ret != 0) { nerrs++; lasterr = ret; } - } else if (vend_id == VENDOR_SUPERMICROX - || vend_id == VENDOR_SUPERMICRO) { - if (failover_enable > 2) failover_enable = 2; /*default*/ - ret = oem_supermicro_set_lan_port(failover_enable); - printf("Set SuperMicro Lan port to %s, ret = %d\n", - oem_supermicro_lan_port_string(failover_enable),ret); - if (ret != 0) { nerrs++; lasterr = ret; } - } - } /*endif failover specified*/ - } /*end-else not via ipmi_lan*/ - } /*endif not readonly*/ - - if (flanstats) - { /* get BMC LAN Statistics */ -#ifdef METACOMMAND - j = get_lan_stats(lan_ch); -#else - uchar idata[2]; - uchar rdata[20]; - int rlen; - uchar cc; - idata[0] = lan_ch; - idata[1] = 0x00; /*do not clear stats*/ - rlen = sizeof(rdata); - j = ipmi_cmd(GET_LAN_STATS, idata,2, rdata,&rlen, &cc, fdebug); - if (j == 0) { /*show BMC LAN stats*/ - ushort *rw; - rw = (ushort *)&rdata[0]; - printf("IPMI LAN channel %d statistics: \n",lan_ch); - printf(" \tReceived IP Packets = %d\n",rw[0]); - printf(" \tRecvd IP Header errors = %d\n",rw[1]); - printf(" \tRecvd IP Address errors = %d\n",rw[2]); - printf(" \tRecvd IP Fragments = %d\n",rw[3]); - printf(" \tTransmitted IP Packets = %d\n",rw[4]); - printf(" \tReceived UDP Packets = %d\n",rw[5]); - printf(" \tReceived Valid RMCP Pkts = %d\n",rw[6]); - printf(" \tReceived UDP Proxy Pkts = %d\n",rw[7]); - printf(" \tDropped UDP Proxy Pkts = %d\n",rw[8]); - } -#endif - } - -do_exit: - ipmi_close_(); - if (foptmsg) { - if (fset_ip != 0) - printf("WARNING: IP address options were specified, but no -e,-l,-d option.\n"); - else - printf("WARNING: %d options were specified, but no -e,-l,-d option.\n", -nopts); - printf("Read-only usage assumed.\n"); - } - if (nerrs > 0) { - printf("Warning: %d ok, %d errors occurred, last error = %d\n",ngood,nerrs,lasterr); - ret = lasterr; - } - // show_outcome(progname,ret); - return(ret); -} /* end main()*/ - -/* end ilan.c */ |