1931 lines
70 KiB
1931 lines
70 KiB
From 6df63fe455745d8d74010d9ad4f85a30f40b5c08 Mon Sep 17 00:00:00 2001 |
|
From: Frederic Bohe <fbohe-guest@alioth.debian.org> |
|
Date: Mon, 10 Sep 2012 13:28:35 +0000 |
|
Subject: [PATCH] [nut-scanner] Fix a crash when no start IP is provided. |
|
|
|
Fossil-ID: SVN r3722 |
|
--- |
|
tools/nut-scanner/nut-scanner.c | 2 ++ |
|
1 file changed, 2 insertions(+) |
|
|
|
diff --git a/tools/nut-scanner/nut-scanner.c b/tools/nut-scanner/nut-scanner.c |
|
index db582be..52e0da7 100644 |
|
--- a/tools/nut-scanner/nut-scanner.c |
|
+++ b/tools/nut-scanner/nut-scanner.c |
|
@@ -371,6 +371,7 @@ display_help: |
|
if( allow_snmp && nutscan_avail_snmp ) { |
|
if( start_ip == NULL ) { |
|
printq(quiet,"No start IP, skipping SNMP\n"); |
|
+ nutscan_avail_snmp = 0; |
|
} |
|
else { |
|
printq(quiet,"Scanning SNMP bus.\n"); |
|
@@ -398,6 +399,7 @@ display_help: |
|
if( allow_oldnut && nutscan_avail_nut) { |
|
if( start_ip == NULL ) { |
|
printq(quiet,"No start IP, skipping NUT bus (old connect method)\n"); |
|
+ nutscan_avail_nut = 0; |
|
} |
|
else { |
|
printq(quiet,"Scanning NUT bus (old connect method).\n"); |
|
-- |
|
1.7.10.2 |
|
|
|
|
|
From dc729c5c3da7efb4632f7d9f7a031108540282d9 Mon Sep 17 00:00:00 2001 |
|
From: Arnaud Quette <arnaud.quette@free.fr> |
|
Date: Wed, 19 Sep 2012 19:35:45 +0000 |
|
Subject: [PATCH] Support for FreeIPMI 1.1.x and 1.2.x (#2) |
|
|
|
Prepare for supporting API changes in FreeIPMI 1.1.x and 1.2.x. This 2nd |
|
patch, which completes [[SVN:3675]], addresses FRU API changes, and removes |
|
code redundancy. This code has been tested with FreeIPMI 0.8.12 and |
|
the latest [[FreeIPMI SVN]] trunk r9505 (reported as 1.2.0.beta2 by pkgconfig) |
|
|
|
[[SVN:3675]] = 2012-07-16T13:18:18Z!arnaud.quette@free.fr |
|
|
|
Fossil-ID: SVN r3733 |
|
--- |
|
drivers/nut-libfreeipmi.c | 375 ++++++++++++++--------------------------- |
|
m4/nut_check_libfreeipmi.m4 | 1 - |
|
tools/nut-scanner/scan_ipmi.c | 103 +++++++---- |
|
3 files changed, 192 insertions(+), 287 deletions(-) |
|
|
|
diff --git a/drivers/nut-libfreeipmi.c b/drivers/nut-libfreeipmi.c |
|
index 1539e75..dd06369 100644 |
|
--- a/drivers/nut-libfreeipmi.c |
|
+++ b/drivers/nut-libfreeipmi.c |
|
@@ -42,10 +42,12 @@ |
|
#include <stdlib.h> |
|
#include <string.h> |
|
#include "timehead.h" |
|
+#include "common.h" |
|
#include <freeipmi/freeipmi.h> |
|
#include <ipmi_monitoring.h> |
|
+#if HAVE_FREEIPMI_MONITORING |
|
#include <ipmi_monitoring_bitmasks.h> |
|
-#include "common.h" |
|
+#endif |
|
#include "nut-ipmi.h" |
|
#include "dstate.h" |
|
|
|
@@ -57,18 +59,46 @@ |
|
|
|
/* FreeIPMI contexts and configuration*/ |
|
ipmi_ctx_t ipmi_ctx = NULL; |
|
-ipmi_fru_parse_ctx_t fru_parse_ctx = NULL; |
|
ipmi_monitoring_ctx_t mon_ctx = NULL; |
|
struct ipmi_monitoring_ipmi_config ipmi_config; |
|
+ |
|
/* SDR management API has changed with 1.1.X and later */ |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
ipmi_sdr_ctx_t sdr_ctx = NULL; |
|
+ ipmi_fru_ctx_t fru_ctx = NULL; |
|
+ #define SDR_PARSE_CTX sdr_ctx |
|
#else |
|
- ipmi_sdr_cache_ctx_t sdr_cache_ctx = NULL; |
|
+ ipmi_sdr_cache_ctx_t sdr_ctx = NULL; |
|
ipmi_sdr_parse_ctx_t sdr_parse_ctx = NULL; |
|
-#ifndef IPMI_SDR_MAX_RECORD_LENGTH |
|
- #define IPMI_SDR_MAX_RECORD_LENGTH IPMI_SDR_CACHE_MAX_SDR_RECORD_LENGTH |
|
-#endif |
|
+ #define SDR_PARSE_CTX sdr_parse_ctx |
|
+ ipmi_fru_parse_ctx_t fru_ctx = NULL; |
|
+ /* Functions remapping */ |
|
+ #define ipmi_sdr_ctx_create ipmi_sdr_cache_ctx_create |
|
+ #define ipmi_sdr_ctx_destroy ipmi_sdr_cache_ctx_destroy |
|
+ #define ipmi_sdr_ctx_errnum ipmi_sdr_cache_ctx_errnum |
|
+ #define ipmi_sdr_ctx_errormsg ipmi_sdr_cache_ctx_errormsg |
|
+ #define ipmi_fru_ctx_create ipmi_fru_parse_ctx_create |
|
+ #define ipmi_fru_ctx_destroy ipmi_fru_parse_ctx_destroy |
|
+ #define ipmi_fru_ctx_set_flags ipmi_fru_parse_ctx_set_flags |
|
+ #define ipmi_fru_ctx_strerror ipmi_fru_parse_ctx_strerror |
|
+ #define ipmi_fru_ctx_errnum ipmi_fru_parse_ctx_errnum |
|
+ #define ipmi_fru_open_device_id ipmi_fru_parse_open_device_id |
|
+ #define ipmi_fru_close_device_id ipmi_fru_parse_close_device_id |
|
+ #define ipmi_fru_ctx_errormsg ipmi_fru_parse_ctx_errormsg |
|
+ #define ipmi_fru_read_data_area ipmi_fru_parse_read_data_area |
|
+ #define ipmi_fru_next ipmi_fru_parse_next |
|
+ #define ipmi_fru_type_length_field_to_string ipmi_fru_parse_type_length_field_to_string |
|
+ #define ipmi_fru_multirecord_power_supply_information ipmi_fru_parse_multirecord_power_supply_information |
|
+ #define ipmi_fru_board_info_area ipmi_fru_parse_board_info_area |
|
+ #define ipmi_fru_field_t ipmi_fru_parse_field_t |
|
+ /* Constants */ |
|
+ #define IPMI_SDR_MAX_RECORD_LENGTH IPMI_SDR_CACHE_MAX_SDR_RECORD_LENGTH |
|
+ #define IPMI_SDR_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST IPMI_SDR_CACHE_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST |
|
+ #define IPMI_FRU_AREA_SIZE_MAX IPMI_FRU_PARSE_AREA_SIZE_MAX |
|
+ #define IPMI_FRU_FLAGS_SKIP_CHECKSUM_CHECKS IPMI_FRU_PARSE_FLAGS_SKIP_CHECKSUM_CHECKS |
|
+ #define IPMI_FRU_AREA_TYPE_BOARD_INFO_AREA IPMI_FRU_PARSE_AREA_TYPE_BOARD_INFO_AREA |
|
+ #define IPMI_FRU_AREA_TYPE_MULTIRECORD_POWER_SUPPLY_INFORMATION IPMI_FRU_PARSE_AREA_TYPE_MULTIRECORD_POWER_SUPPLY_INFORMATION |
|
+ #define IPMI_FRU_AREA_STRING_MAX IPMI_FRU_PARSE_AREA_STRING_MAX |
|
#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
/* FIXME: freeipmi auto selects a cache based on the hostname you are |
|
@@ -78,7 +108,7 @@ struct ipmi_monitoring_ipmi_config ipmi_config; |
|
|
|
/* Support functions */ |
|
static const char* libfreeipmi_getfield (uint8_t language_code, |
|
- ipmi_fru_parse_field_t *field); |
|
+ ipmi_fru_field_t *field); |
|
|
|
static void libfreeipmi_cleanup(); |
|
|
|
@@ -97,7 +127,7 @@ static int libfreeipmi_get_sensors_info (IPMIDevice_t *ipmi_dev); |
|
int nut_ipmi_open(int ipmi_id, IPMIDevice_t *ipmi_dev) |
|
{ |
|
int ret = -1; |
|
- uint8_t areabuf[IPMI_FRU_PARSE_AREA_SIZE_MAX+1]; |
|
+ uint8_t areabuf[IPMI_FRU_AREA_SIZE_MAX+1]; |
|
unsigned int area_type = 0; |
|
unsigned int area_length = 0; |
|
|
|
@@ -134,26 +164,26 @@ int nut_ipmi_open(int ipmi_id, IPMIDevice_t *ipmi_dev) |
|
upsdebugx(1, "FreeIPMI initialized..."); |
|
|
|
/* Parse FRU information */ |
|
- if (!(fru_parse_ctx = ipmi_fru_parse_ctx_create (ipmi_ctx))) |
|
+ if (!(fru_ctx = ipmi_fru_ctx_create (ipmi_ctx))) |
|
{ |
|
libfreeipmi_cleanup(); |
|
- fatal_with_errno(EXIT_FAILURE, "ipmi_fru_parse_ctx_create()"); |
|
+ fatal_with_errno(EXIT_FAILURE, "ipmi_fru_ctx_create()"); |
|
} |
|
|
|
/* lots of motherboards calculate checksums incorrectly */ |
|
- if (ipmi_fru_parse_ctx_set_flags (fru_parse_ctx, IPMI_FRU_PARSE_FLAGS_SKIP_CHECKSUM_CHECKS) < 0) |
|
+ if (ipmi_fru_ctx_set_flags (fru_ctx, IPMI_FRU_FLAGS_SKIP_CHECKSUM_CHECKS) < 0) |
|
{ |
|
libfreeipmi_cleanup(); |
|
- fatalx(EXIT_FAILURE, "ipmi_fru_parse_ctx_set_flags: %s\n", |
|
- ipmi_fru_parse_ctx_strerror (ipmi_fru_parse_ctx_errnum (fru_parse_ctx))); |
|
+ fatalx(EXIT_FAILURE, "ipmi_fru_ctx_set_flags: %s\n", |
|
+ ipmi_fru_ctx_strerror (ipmi_fru_ctx_errnum (fru_ctx))); |
|
} |
|
|
|
/* Now open the requested (local) PSU */ |
|
- if (ipmi_fru_parse_open_device_id (fru_parse_ctx, ipmi_id) < 0) |
|
+ if (ipmi_fru_open_device_id (fru_ctx, ipmi_id) < 0) |
|
{ |
|
libfreeipmi_cleanup(); |
|
- fatalx(EXIT_FAILURE, "ipmi_fru_parse_open_device_id: %s\n", |
|
- ipmi_fru_parse_ctx_errormsg (fru_parse_ctx)); |
|
+ fatalx(EXIT_FAILURE, "ipmi_fru_open_device_id: %s\n", |
|
+ ipmi_fru_ctx_errormsg (fru_ctx)); |
|
} |
|
|
|
/* Set IPMI identifier */ |
|
@@ -164,19 +194,19 @@ int nut_ipmi_open(int ipmi_id, IPMIDevice_t *ipmi_dev) |
|
/* clear fields */ |
|
area_type = 0; |
|
area_length = 0; |
|
- memset (areabuf, '\0', IPMI_FRU_PARSE_AREA_SIZE_MAX + 1); |
|
+ memset (areabuf, '\0', IPMI_FRU_AREA_SIZE_MAX + 1); |
|
|
|
/* parse FRU buffer */ |
|
- if (ipmi_fru_parse_read_data_area (fru_parse_ctx, |
|
+ if (ipmi_fru_read_data_area (fru_ctx, |
|
&area_type, |
|
&area_length, |
|
areabuf, |
|
- IPMI_FRU_PARSE_AREA_SIZE_MAX) < 0) |
|
+ IPMI_FRU_AREA_SIZE_MAX) < 0) |
|
{ |
|
libfreeipmi_cleanup(); |
|
fatal_with_errno(EXIT_FAILURE, |
|
- "ipmi_fru_parse_open_device_id: %s\n", |
|
- ipmi_fru_parse_ctx_errormsg (fru_parse_ctx)); |
|
+ "ipmi_fru_read_data_area: %s\n", |
|
+ ipmi_fru_ctx_errormsg (fru_ctx)); |
|
} |
|
|
|
if (area_length) |
|
@@ -184,7 +214,7 @@ int nut_ipmi_open(int ipmi_id, IPMIDevice_t *ipmi_dev) |
|
switch (area_type) |
|
{ |
|
/* get generic board information */ |
|
- case IPMI_FRU_PARSE_AREA_TYPE_BOARD_INFO_AREA: |
|
+ case IPMI_FRU_AREA_TYPE_BOARD_INFO_AREA: |
|
|
|
if(libfreeipmi_get_board_info (areabuf, area_length, |
|
ipmi_dev) < 0) |
|
@@ -193,7 +223,7 @@ int nut_ipmi_open(int ipmi_id, IPMIDevice_t *ipmi_dev) |
|
} |
|
break; |
|
/* get specific PSU information */ |
|
- case IPMI_FRU_PARSE_AREA_TYPE_MULTIRECORD_POWER_SUPPLY_INFORMATION: |
|
+ case IPMI_FRU_AREA_TYPE_MULTIRECORD_POWER_SUPPLY_INFORMATION: |
|
|
|
if(libfreeipmi_get_psu_info (areabuf, area_length, ipmi_dev) < 0) |
|
{ |
|
@@ -205,13 +235,13 @@ int nut_ipmi_open(int ipmi_id, IPMIDevice_t *ipmi_dev) |
|
break; |
|
} |
|
} |
|
- } while ((ret = ipmi_fru_parse_next (fru_parse_ctx)) == 1); |
|
+ } while ((ret = ipmi_fru_next (fru_ctx)) == 1); |
|
|
|
/* check for errors */ |
|
if (ret < 0) { |
|
libfreeipmi_cleanup(); |
|
- fatal_with_errno(EXIT_FAILURE, "ipmi_fru_parse_next: %s", |
|
- ipmi_fru_parse_ctx_errormsg (fru_parse_ctx)); |
|
+ fatal_with_errno(EXIT_FAILURE, "ipmi_fru_next: %s", |
|
+ ipmi_fru_ctx_errormsg (fru_ctx)); |
|
} |
|
else { |
|
/* Get all related sensors information */ |
|
@@ -232,25 +262,25 @@ void nut_ipmi_close(void) |
|
} |
|
|
|
static const char* libfreeipmi_getfield (uint8_t language_code, |
|
- ipmi_fru_parse_field_t *field) |
|
+ ipmi_fru_field_t *field) |
|
{ |
|
- static char strbuf[IPMI_FRU_PARSE_AREA_STRING_MAX + 1]; |
|
- unsigned int strbuflen = IPMI_FRU_PARSE_AREA_STRING_MAX; |
|
+ static char strbuf[IPMI_FRU_AREA_STRING_MAX + 1]; |
|
+ unsigned int strbuflen = IPMI_FRU_AREA_STRING_MAX; |
|
|
|
if (!field->type_length_field_length) |
|
return NULL; |
|
|
|
- memset (strbuf, '\0', IPMI_FRU_PARSE_AREA_STRING_MAX + 1); |
|
+ memset (strbuf, '\0', IPMI_FRU_AREA_STRING_MAX + 1); |
|
|
|
- if (ipmi_fru_parse_type_length_field_to_string (fru_parse_ctx, |
|
+ if (ipmi_fru_type_length_field_to_string (fru_ctx, |
|
field->type_length_field, |
|
field->type_length_field_length, |
|
language_code, |
|
strbuf, |
|
&strbuflen) < 0) |
|
{ |
|
- upsdebugx (2, "ipmi_fru_parse_type_length_field_to_string: %s", |
|
- ipmi_fru_parse_ctx_errormsg (fru_parse_ctx)); |
|
+ upsdebugx (2, "ipmi_fru_type_length_field_to_string: %s", |
|
+ ipmi_fru_ctx_errormsg (fru_ctx)); |
|
return NULL; |
|
} |
|
|
|
@@ -279,24 +309,20 @@ static float libfreeipmi_get_voltage (uint8_t voltage_code) |
|
static void libfreeipmi_cleanup() |
|
{ |
|
/* cleanup */ |
|
- if (fru_parse_ctx) { |
|
- ipmi_fru_parse_close_device_id (fru_parse_ctx); |
|
- ipmi_fru_parse_ctx_destroy (fru_parse_ctx); |
|
+ if (fru_ctx) { |
|
+ ipmi_fru_close_device_id (fru_ctx); |
|
+ ipmi_fru_ctx_destroy (fru_ctx); |
|
} |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
if (sdr_ctx) { |
|
ipmi_sdr_ctx_destroy (sdr_ctx); |
|
} |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- if (sdr_cache_ctx) { |
|
- ipmi_sdr_cache_ctx_destroy (sdr_cache_ctx); |
|
- } |
|
|
|
+#ifndef HAVE_FREEIPMI_11X_12X |
|
if (sdr_parse_ctx) { |
|
ipmi_sdr_parse_ctx_destroy (sdr_parse_ctx); |
|
} |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
+#endif |
|
|
|
if (ipmi_ctx) { |
|
ipmi_ctx_close (ipmi_ctx); |
|
@@ -342,7 +368,7 @@ static int libfreeipmi_get_psu_info (const void *areabuf, |
|
|
|
upsdebugx(1, "entering libfreeipmi_get_psu_info()"); |
|
|
|
- if (ipmi_fru_parse_multirecord_power_supply_information (fru_parse_ctx, |
|
+ if (ipmi_fru_multirecord_power_supply_information (fru_ctx, |
|
areabuf, |
|
area_length, |
|
&overall_capacity, |
|
@@ -368,8 +394,8 @@ static int libfreeipmi_get_psu_info (const void *areabuf, |
|
&total_combined_wattage, |
|
&predictive_fail_tachometer_lower_threshold) < 0) |
|
{ |
|
- fatalx(EXIT_FAILURE, "ipmi_fru_parse_multirecord_power_supply_information: %s", |
|
- ipmi_fru_parse_ctx_errormsg (fru_parse_ctx)); |
|
+ fatalx(EXIT_FAILURE, "ipmi_fru_multirecord_power_supply_information: %s", |
|
+ ipmi_fru_ctx_errormsg (fru_ctx)); |
|
} |
|
|
|
ipmi_dev->overall_capacity = overall_capacity; |
|
@@ -383,6 +409,8 @@ static int libfreeipmi_get_psu_info (const void *areabuf, |
|
|
|
ipmi_dev->voltage = libfreeipmi_get_voltage(voltage_1); |
|
|
|
+ upsdebugx(1, "libfreeipmi_get_psu_info() retrieved successfully"); |
|
+ |
|
return (0); |
|
} |
|
|
|
@@ -392,12 +420,12 @@ static int libfreeipmi_get_board_info (const void *areabuf, |
|
{ |
|
uint8_t language_code; |
|
uint32_t mfg_date_time; |
|
- ipmi_fru_parse_field_t board_manufacturer; |
|
- ipmi_fru_parse_field_t board_product_name; |
|
- ipmi_fru_parse_field_t board_serial_number; |
|
- ipmi_fru_parse_field_t board_part_number; |
|
- ipmi_fru_parse_field_t board_fru_file_id; |
|
- ipmi_fru_parse_field_t board_custom_fields[IPMI_FRU_CUSTOM_FIELDS]; |
|
+ ipmi_fru_field_t board_manufacturer; |
|
+ ipmi_fru_field_t board_product_name; |
|
+ ipmi_fru_field_t board_serial_number; |
|
+ ipmi_fru_field_t board_part_number; |
|
+ ipmi_fru_field_t board_fru_file_id; |
|
+ ipmi_fru_field_t board_custom_fields[IPMI_FRU_CUSTOM_FIELDS]; |
|
const char *string = NULL; |
|
time_t timetmp; |
|
struct tm mfg_date_time_tm; |
|
@@ -406,15 +434,15 @@ static int libfreeipmi_get_board_info (const void *areabuf, |
|
upsdebugx(1, "entering libfreeipmi_get_board_info()"); |
|
|
|
/* clear fields */ |
|
- memset (&board_manufacturer, '\0', sizeof (ipmi_fru_parse_field_t)); |
|
- memset (&board_product_name, '\0', sizeof (ipmi_fru_parse_field_t)); |
|
- memset (&board_serial_number, '\0', sizeof (ipmi_fru_parse_field_t)); |
|
- memset (&board_fru_file_id, '\0', sizeof (ipmi_fru_parse_field_t)); |
|
+ memset (&board_manufacturer, '\0', sizeof (ipmi_fru_field_t)); |
|
+ memset (&board_product_name, '\0', sizeof (ipmi_fru_field_t)); |
|
+ memset (&board_serial_number, '\0', sizeof (ipmi_fru_field_t)); |
|
+ memset (&board_fru_file_id, '\0', sizeof (ipmi_fru_field_t)); |
|
memset (&board_custom_fields[0], '\0', |
|
- sizeof (ipmi_fru_parse_field_t) * IPMI_FRU_CUSTOM_FIELDS); |
|
+ sizeof (ipmi_fru_field_t) * IPMI_FRU_CUSTOM_FIELDS); |
|
|
|
/* parse FRU buffer */ |
|
- if (ipmi_fru_parse_board_info_area (fru_parse_ctx, |
|
+ if (ipmi_fru_board_info_area (fru_ctx, |
|
areabuf, |
|
area_length, |
|
&language_code, |
|
@@ -428,8 +456,8 @@ static int libfreeipmi_get_board_info (const void *areabuf, |
|
IPMI_FRU_CUSTOM_FIELDS) < 0) |
|
{ |
|
libfreeipmi_cleanup(); |
|
- fatalx(EXIT_FAILURE, "ipmi_fru_parse_board_info_area: %s", |
|
- ipmi_fru_parse_ctx_errormsg (fru_parse_ctx)); |
|
+ fatalx(EXIT_FAILURE, "ipmi_fru_board_info_area: %s", |
|
+ ipmi_fru_ctx_errormsg (fru_ctx)); |
|
} |
|
|
|
|
|
@@ -498,113 +526,64 @@ static int libfreeipmi_get_sensors_info (IPMIDevice_t *ipmi_dev) |
|
ipmi_dev->sensors_count = 0; |
|
memset(ipmi_dev->sensors_id_list, 0, sizeof(ipmi_dev->sensors_id_list)); |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
if (!(sdr_ctx = ipmi_sdr_ctx_create ())) |
|
{ |
|
libfreeipmi_cleanup(); |
|
fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_ctx_create()"); |
|
} |
|
|
|
- if (ipmi_sdr_cache_open (sdr_ctx, ipmi_ctx, CACHE_LOCATION) < 0) |
|
- { |
|
- if (ipmi_sdr_ctx_errnum (sdr_ctx) != IPMI_SDR_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST) |
|
- { |
|
- libfreeipmi_cleanup(); |
|
- fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_cache_open: %s", |
|
- ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
- } |
|
- } |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- if (!(sdr_cache_ctx = ipmi_sdr_cache_ctx_create ())) |
|
- { |
|
- libfreeipmi_cleanup(); |
|
- fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_cache_ctx_create()"); |
|
- } |
|
- |
|
+#ifndef HAVE_FREEIPMI_11X_12X |
|
if (!(sdr_parse_ctx = ipmi_sdr_parse_ctx_create ())) |
|
{ |
|
libfreeipmi_cleanup(); |
|
fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_parse_ctx_create()"); |
|
} |
|
+#endif |
|
|
|
- if (ipmi_sdr_cache_open (sdr_cache_ctx, ipmi_ctx, CACHE_LOCATION) < 0) |
|
+ if (ipmi_sdr_cache_open (sdr_ctx, ipmi_ctx, CACHE_LOCATION) < 0) |
|
{ |
|
- if (ipmi_sdr_cache_ctx_errnum (sdr_cache_ctx) != IPMI_SDR_CACHE_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST) |
|
+ if (ipmi_sdr_ctx_errnum (sdr_ctx) != IPMI_SDR_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST) |
|
{ |
|
libfreeipmi_cleanup(); |
|
fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_cache_open: %s", |
|
- ipmi_sdr_cache_ctx_errormsg (sdr_cache_ctx)); |
|
+ ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
} |
|
} |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
if (ipmi_sdr_ctx_errnum (sdr_ctx) == IPMI_SDR_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST) |
|
{ |
|
if (ipmi_sdr_cache_create (sdr_ctx, |
|
ipmi_ctx, CACHE_LOCATION, |
|
IPMI_SDR_CACHE_CREATE_FLAGS_DEFAULT, |
|
+#ifndef HAVE_FREEIPMI_11X_12X |
|
+ IPMI_SDR_CACHE_VALIDATION_FLAGS_DEFAULT, |
|
+#endif |
|
NULL, NULL) < 0) |
|
{ |
|
libfreeipmi_cleanup(); |
|
fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_cache_create: %s", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
} |
|
- if (ipmi_sdr_cache_open (sdr_ctx, |
|
- ipmi_ctx, CACHE_LOCATION) < 0) |
|
+ if (ipmi_sdr_cache_open (sdr_ctx, ipmi_ctx, CACHE_LOCATION) < 0) |
|
{ |
|
if (ipmi_sdr_ctx_errnum (sdr_ctx) != IPMI_SDR_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST) |
|
{ |
|
- libfreeipmi_cleanup(); |
|
- fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_cache_open: %s", |
|
- ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
- } |
|
- } |
|
- } |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- if (ipmi_sdr_cache_ctx_errnum (sdr_cache_ctx) == IPMI_SDR_CACHE_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST) |
|
- { |
|
- if (ipmi_sdr_cache_create (sdr_cache_ctx, |
|
- ipmi_ctx, CACHE_LOCATION, |
|
- IPMI_SDR_CACHE_CREATE_FLAGS_DEFAULT, |
|
- IPMI_SDR_CACHE_VALIDATION_FLAGS_DEFAULT, |
|
- NULL, NULL) < 0) |
|
- { |
|
- libfreeipmi_cleanup(); |
|
- fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_cache_create: %s", |
|
- ipmi_sdr_cache_ctx_errormsg (sdr_cache_ctx)); |
|
- } |
|
- if (ipmi_sdr_cache_open (sdr_cache_ctx, |
|
- ipmi_ctx, CACHE_LOCATION) < 0) |
|
- { |
|
- if (ipmi_sdr_cache_ctx_errnum (sdr_cache_ctx) != IPMI_SDR_CACHE_ERR_CACHE_READ_CACHE_DOES_NOT_EXIST) |
|
- { |
|
- libfreeipmi_cleanup(); |
|
- fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_cache_open: %s", |
|
- ipmi_sdr_cache_ctx_errormsg (sdr_cache_ctx)); |
|
+ libfreeipmi_cleanup(); |
|
+ fatal_with_errno(EXIT_FAILURE, "ipmi_sdr_cache_open: %s", |
|
+ ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
} |
|
} |
|
} |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
- if (ipmi_sdr_cache_record_count (sdr_ctx, &record_count) < 0) { |
|
+ if (ipmi_sdr_cache_record_count (sdr_ctx, &record_count) < 0) { |
|
fprintf (stderr, |
|
- "ipmi_sdr_cache_record_count: %s", |
|
+ "ipmi_sdr_cache_record_count: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
-#else |
|
- if (ipmi_sdr_cache_record_count (sdr_cache_ctx, &record_count) < 0) |
|
- { |
|
- fprintf (stderr, |
|
- "ipmi_sdr_cache_record_count: %s", |
|
- ipmi_sdr_cache_ctx_errormsg (sdr_cache_ctx)); |
|
- goto cleanup; |
|
- } |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
+ upsdebugx(3, "Found %i records in SDR cache", record_count); |
|
+ |
|
for (i = 0; i < record_count; i++, ipmi_sdr_cache_next (sdr_ctx)) |
|
{ |
|
memset (sdr_record, '\0', IPMI_SDR_MAX_RECORD_LENGTH); |
|
@@ -613,50 +592,29 @@ static int libfreeipmi_get_sensors_info (IPMIDevice_t *ipmi_dev) |
|
sdr_record, |
|
IPMI_SDR_MAX_RECORD_LENGTH)) < 0) |
|
{ |
|
- fprintf (stderr, "ipmi_sdr_cache_record_read: %s", |
|
+ fprintf (stderr, "ipmi_sdr_cache_record_read: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
- if (ipmi_sdr_parse_record_id_and_type (sdr_ctx, |
|
+ if (ipmi_sdr_parse_record_id_and_type (SDR_PARSE_CTX, |
|
sdr_record, |
|
sdr_record_len, |
|
NULL, |
|
&record_type) < 0) |
|
{ |
|
- fprintf (stderr, "ipmi_sdr_parse_record_id_and_type: %s", |
|
+ fprintf (stderr, "ipmi_sdr_parse_record_id_and_type: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
-#else |
|
- for (i = 0; i < record_count; i++, ipmi_sdr_cache_next (sdr_cache_ctx)) |
|
- { |
|
- memset (sdr_record, '\0', IPMI_SDR_MAX_RECORD_LENGTH); |
|
|
|
- if ((sdr_record_len = ipmi_sdr_cache_record_read (sdr_cache_ctx, |
|
- sdr_record, |
|
- IPMI_SDR_MAX_RECORD_LENGTH)) < 0) |
|
- { |
|
- fprintf (stderr, "ipmi_sdr_cache_record_read: %s", |
|
- ipmi_sdr_cache_ctx_errormsg (sdr_cache_ctx)); |
|
- goto cleanup; |
|
- } |
|
- if (ipmi_sdr_parse_record_id_and_type (sdr_parse_ctx, |
|
- sdr_record, |
|
- sdr_record_len, |
|
- NULL, |
|
- &record_type) < 0) |
|
- { |
|
- fprintf (stderr, "ipmi_sdr_parse_record_id_and_type: %s", |
|
- ipmi_sdr_parse_ctx_errormsg (sdr_parse_ctx)); |
|
- goto cleanup; |
|
- } |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
+ upsdebugx (5, "Checking record %i (/%i)", i, record_count); |
|
|
|
- if (record_type != IPMI_SDR_FORMAT_FRU_DEVICE_LOCATOR_RECORD) |
|
+ if (record_type != IPMI_SDR_FORMAT_FRU_DEVICE_LOCATOR_RECORD) { |
|
+ upsdebugx(1, "=======> not device locator (%i)!!", record_type); |
|
continue; |
|
+ } |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
- if (ipmi_sdr_parse_fru_device_locator_parameters (sdr_ctx, |
|
+ if (ipmi_sdr_parse_fru_device_locator_parameters (SDR_PARSE_CTX, |
|
sdr_record, |
|
sdr_record_len, |
|
NULL, |
|
@@ -666,86 +624,49 @@ static int libfreeipmi_get_sensors_info (IPMIDevice_t *ipmi_dev) |
|
&logical_physical_fru_device, |
|
NULL) < 0) |
|
{ |
|
- fprintf (stderr, "ipmi_sdr_parse_fru_device_locator_parameters: %s", |
|
+ fprintf (stderr, "ipmi_sdr_parse_fru_device_locator_parameters: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- if (ipmi_sdr_parse_fru_device_locator_parameters (sdr_parse_ctx, |
|
- sdr_record, |
|
- sdr_record_len, |
|
- NULL, |
|
- &logical_fru_device_device_slave_address, |
|
- NULL, |
|
- NULL, |
|
- &logical_physical_fru_device, |
|
- NULL) < 0) |
|
- { |
|
- fprintf (stderr, "ipmi_sdr_parse_fru_device_locator_parameters: %s", |
|
- ipmi_sdr_parse_ctx_errormsg (sdr_parse_ctx)); |
|
- goto cleanup; |
|
- } |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
+ |
|
+ upsdebugx(2, "Checking device %i/%i", logical_physical_fru_device, |
|
+ logical_fru_device_device_slave_address); |
|
|
|
if (logical_physical_fru_device |
|
&& logical_fru_device_device_slave_address == ipmi_dev->ipmi_id) |
|
{ |
|
found_device_id++; |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
- if (ipmi_sdr_parse_fru_entity_id_and_instance (sdr_ctx, |
|
+ if (ipmi_sdr_parse_fru_entity_id_and_instance (SDR_PARSE_CTX, |
|
sdr_record, |
|
sdr_record_len, |
|
&entity_id, |
|
&entity_instance) < 0) |
|
{ |
|
fprintf (stderr, |
|
- "ipmi_sdr_parse_fru_entity_id_and_instance: %s", |
|
+ "ipmi_sdr_parse_fru_entity_id_and_instance: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- if (ipmi_sdr_parse_fru_entity_id_and_instance (sdr_parse_ctx, |
|
- sdr_record, |
|
- sdr_record_len, |
|
- &entity_id, |
|
- &entity_instance) < 0) |
|
- { |
|
- fprintf (stderr, |
|
- "ipmi_sdr_parse_fru_entity_id_and_instance: %s", |
|
- ipmi_sdr_parse_ctx_errormsg (sdr_parse_ctx)); |
|
- goto cleanup; |
|
- } |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
break; |
|
} |
|
} |
|
|
|
if (!found_device_id) |
|
{ |
|
- fprintf (stderr, "Couldn't find device id %d", ipmi_dev->ipmi_id); |
|
+ fprintf (stderr, "Couldn't find device id %d\n", ipmi_dev->ipmi_id); |
|
goto cleanup; |
|
} |
|
else |
|
upsdebugx(1, "Found device id %d", ipmi_dev->ipmi_id); |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
if (ipmi_sdr_cache_first (sdr_ctx) < 0) |
|
{ |
|
- fprintf (stderr, "ipmi_sdr_cache_first: %s", |
|
+ fprintf (stderr, "ipmi_sdr_cache_first: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- if (ipmi_sdr_cache_first (sdr_cache_ctx) < 0) |
|
- { |
|
- fprintf (stderr, "ipmi_sdr_cache_first: %s", |
|
- ipmi_sdr_cache_ctx_errormsg (sdr_cache_ctx)); |
|
- goto cleanup; |
|
- } |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
for (i = 0; i < record_count; i++, ipmi_sdr_cache_next (sdr_ctx)) |
|
{ |
|
/* uint8_t sdr_record[IPMI_SDR_CACHE_MAX_SDR_RECORD_LENGTH]; |
|
@@ -757,49 +678,21 @@ static int libfreeipmi_get_sensors_info (IPMIDevice_t *ipmi_dev) |
|
sdr_record, |
|
IPMI_SDR_MAX_RECORD_LENGTH)) < 0) |
|
{ |
|
- fprintf (stderr, "ipmi_sdr_cache_record_read: %s", |
|
+ fprintf (stderr, "ipmi_sdr_cache_record_read: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
|
|
- if (ipmi_sdr_parse_record_id_and_type (sdr_ctx, |
|
+ if (ipmi_sdr_parse_record_id_and_type (SDR_PARSE_CTX, |
|
sdr_record, |
|
sdr_record_len, |
|
&record_id, |
|
&record_type) < 0) |
|
{ |
|
- fprintf (stderr, "ipmi_sdr_parse_record_id_and_type: %s", |
|
+ fprintf (stderr, "ipmi_sdr_parse_record_id_and_type: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- for (i = 0; i < record_count; i++, ipmi_sdr_cache_next (sdr_cache_ctx)) |
|
- { |
|
- /* uint8_t sdr_record[IPMI_SDR_CACHE_MAX_SDR_RECORD_LENGTH]; |
|
- uint8_t record_type, tmp_entity_id, tmp_entity_instance; |
|
- int sdr_record_len; */ |
|
- |
|
- memset (sdr_record, '\0', IPMI_SDR_MAX_RECORD_LENGTH); |
|
- if ((sdr_record_len = ipmi_sdr_cache_record_read (sdr_cache_ctx, |
|
- sdr_record, |
|
- IPMI_SDR_MAX_RECORD_LENGTH)) < 0) |
|
- { |
|
- fprintf (stderr, "ipmi_sdr_cache_record_read: %s", |
|
- ipmi_sdr_cache_ctx_errormsg (sdr_cache_ctx)); |
|
- goto cleanup; |
|
- } |
|
- |
|
- if (ipmi_sdr_parse_record_id_and_type (sdr_parse_ctx, |
|
- sdr_record, |
|
- sdr_record_len, |
|
- &record_id, |
|
- &record_type) < 0) |
|
- { |
|
- fprintf (stderr, "ipmi_sdr_parse_record_id_and_type: %s", |
|
- ipmi_sdr_parse_ctx_errormsg (sdr_parse_ctx)); |
|
- goto cleanup; |
|
- } |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
upsdebugx (5, "Checking record %i (/%i)", record_id, record_count); |
|
|
|
@@ -809,31 +702,17 @@ static int libfreeipmi_get_sensors_info (IPMIDevice_t *ipmi_dev) |
|
continue; |
|
} |
|
|
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
- if (ipmi_sdr_parse_entity_id_instance_type (sdr_ctx, |
|
+ if (ipmi_sdr_parse_entity_id_instance_type (SDR_PARSE_CTX, |
|
sdr_record, |
|
sdr_record_len, |
|
&tmp_entity_id, |
|
&tmp_entity_instance, |
|
NULL) < 0) |
|
{ |
|
- fprintf (stderr, "ipmi_sdr_parse_entity_instance_type: %s", |
|
+ fprintf (stderr, "ipmi_sdr_parse_entity_instance_type: %s\n", |
|
ipmi_sdr_ctx_errormsg (sdr_ctx)); |
|
goto cleanup; |
|
} |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- if (ipmi_sdr_parse_entity_id_instance_type (sdr_parse_ctx, |
|
- sdr_record, |
|
- sdr_record_len, |
|
- &tmp_entity_id, |
|
- &tmp_entity_instance, |
|
- NULL) < 0) |
|
- { |
|
- fprintf (stderr, "ipmi_sdr_parse_entity_instance_type: %s", |
|
- ipmi_sdr_parse_ctx_errormsg (sdr_parse_ctx)); |
|
- goto cleanup; |
|
- } |
|
-#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
if (tmp_entity_id == entity_id |
|
&& tmp_entity_instance == entity_instance) |
|
@@ -850,15 +729,11 @@ static int libfreeipmi_get_sensors_info (IPMIDevice_t *ipmi_dev) |
|
|
|
cleanup: |
|
/* Cleanup */ |
|
-#ifdef HAVE_FREEIPMI_11X_12X |
|
if (sdr_ctx) { |
|
ipmi_sdr_ctx_destroy (sdr_ctx); |
|
} |
|
-#else /* HAVE_FREEIPMI_11X_12X */ |
|
- if (sdr_cache_ctx) { |
|
- ipmi_sdr_cache_ctx_destroy (sdr_cache_ctx); |
|
- } |
|
|
|
+#ifndef HAVE_FREEIPMI_11X_12X |
|
if (sdr_parse_ctx) { |
|
ipmi_sdr_parse_ctx_destroy (sdr_parse_ctx); |
|
} |
|
diff --git a/m4/nut_check_libfreeipmi.m4 b/m4/nut_check_libfreeipmi.m4 |
|
index 72e7819..5b2eae9 100644 |
|
--- a/m4/nut_check_libfreeipmi.m4 |
|
+++ b/m4/nut_check_libfreeipmi.m4 |
|
@@ -66,7 +66,6 @@ if test -z "${nut_have_libfreeipmi_seen}"; then |
|
dnl when version cannot be tested (prior to 1.0.5, with no pkg-config) |
|
dnl we have to check for some specific functions |
|
AC_SEARCH_LIBS([ipmi_ctx_find_inband], [freeipmi], [], [nut_have_freeipmi=no]) |
|
- AC_SEARCH_LIBS([ipmi_fru_parse_ctx_create], [freeipmi], [], [nut_have_freeipmi=no]) |
|
|
|
AC_SEARCH_LIBS([ipmi_monitoring_init], [ipmimonitoring], [nut_have_freeipmi_monitoring=yes], [nut_have_freeipmi_monitoring=no]) |
|
AC_SEARCH_LIBS([ipmi_monitoring_sensor_read_record_id], [ipmimonitoring], [], [nut_have_freeipmi_monitoring=no]) |
|
diff --git a/tools/nut-scanner/scan_ipmi.c b/tools/nut-scanner/scan_ipmi.c |
|
index d650efa..c1ec78a 100644 |
|
--- a/tools/nut-scanner/scan_ipmi.c |
|
+++ b/tools/nut-scanner/scan_ipmi.c |
|
@@ -34,24 +34,51 @@ static char * libname = "libfreeipmi"; |
|
static lt_dlhandle dl_handle = NULL; |
|
static const char *dl_error = NULL; |
|
|
|
-static int (*nut_ipmi_fru_parse_close_device_id) (ipmi_fru_parse_ctx_t ctx); |
|
-static void (*nut_ipmi_fru_parse_ctx_destroy) (ipmi_fru_parse_ctx_t ctx); |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
-static void (*nut_ipmi_sdr_ctx_destroy) (ipmi_sdr_ctx_t ctx); |
|
+ /* Functions symbols remapping */ |
|
+ #define IPMI_FRU_CLOSE_DEVICE_ID "ipmi_fru_close_device_id" |
|
+ #define IPMI_FRU_CTX_DESTROY "ipmi_fru_ctx_destroy" |
|
+ #define IPMI_FRU_CTX_CREATE "ipmi_fru_ctx_create" |
|
+ #define IPMI_FRU_CTX_SET_FLAGS "ipmi_fru_ctx_set_flags" |
|
+ #define IPMI_FRU_OPEN_DEVICE_ID "ipmi_fru_open_device_id" |
|
+ #define IPMI_FRU_CTX_ERRORMSG "ipmi_fru_ctx_errormsg" |
|
+ #define IPMI_FRU_READ_DATA_AREA "ipmi_fru_read_data_area" |
|
+ #define IPMI_FRU_PARSE_NEXT "ipmi_fru_next" |
|
+ typedef ipmi_fru_ctx_t ipmi_fru_parse_ctx_t; |
|
+ typedef ipmi_sdr_ctx_t ipmi_sdr_cache_ctx_t; |
|
+ /* Functions remapping */ |
|
+ static void (*nut_ipmi_sdr_ctx_destroy) (ipmi_sdr_ctx_t ctx); |
|
#else /* HAVE_FREEIPMI_11X_12X */ |
|
-static void (*nut_ipmi_sdr_cache_ctx_destroy) (ipmi_sdr_cache_ctx_t ctx); |
|
-static void (*nut_ipmi_sdr_parse_ctx_destroy) (ipmi_sdr_parse_ctx_t ctx); |
|
+ #define IPMI_FRU_AREA_SIZE_MAX IPMI_FRU_PARSE_AREA_SIZE_MAX |
|
+ #define IPMI_FRU_FLAGS_SKIP_CHECKSUM_CHECKS IPMI_FRU_PARSE_FLAGS_SKIP_CHECKSUM_CHECKS |
|
+ #define IPMI_FRU_AREA_TYPE_MULTIRECORD_POWER_SUPPLY_INFORMATION IPMI_FRU_PARSE_AREA_TYPE_MULTIRECORD_POWER_SUPPLY_INFORMATION |
|
+ /* Functions symbols remapping */ |
|
+ #define IPMI_FRU_CLOSE_DEVICE_ID "ipmi_fru_parse_close_device_id" |
|
+ #define IPMI_FRU_CTX_DESTROY "ipmi_fru_parse_ctx_destroy" |
|
+ #define IPMI_FRU_CTX_CREATE "ipmi_fru_parse_ctx_create" |
|
+ #define IPMI_FRU_CTX_SET_FLAGS "ipmi_fru_parse_ctx_set_flags" |
|
+ #define IPMI_FRU_OPEN_DEVICE_ID "ipmi_fru_parse_open_device_id" |
|
+ #define IPMI_FRU_CTX_ERRORMSG "ipmi_fru_parse_ctx_errormsg" |
|
+ #define IPMI_FRU_READ_DATA_AREA "ipmi_fru_parse_read_data_area" |
|
+ #define IPMI_FRU_PARSE_NEXT "ipmi_fru_parse_next" |
|
+ /* Functions remapping */ |
|
+ static void (*nut_ipmi_sdr_cache_ctx_destroy) (ipmi_sdr_cache_ctx_t ctx); |
|
+ static void (*nut_ipmi_sdr_parse_ctx_destroy) (ipmi_sdr_parse_ctx_t ctx); |
|
#endif /* HAVE_FREEIPMI_11X_12X */ |
|
-static ipmi_fru_parse_ctx_t (*nut_ipmi_fru_parse_ctx_create) (ipmi_ctx_t ipmi_ctx); |
|
-static int (*nut_ipmi_fru_parse_ctx_set_flags) (ipmi_fru_parse_ctx_t ctx, unsigned int flags); |
|
-static int (*nut_ipmi_fru_parse_open_device_id) (ipmi_fru_parse_ctx_t ctx, uint8_t fru_device_id); |
|
-static char * (*nut_ipmi_fru_parse_ctx_errormsg) (ipmi_fru_parse_ctx_t ctx); |
|
-static int (*nut_ipmi_fru_parse_read_data_area) (ipmi_fru_parse_ctx_t ctx, |
|
+ |
|
+ |
|
+static int (*nut_ipmi_fru_close_device_id) (ipmi_fru_parse_ctx_t ctx); |
|
+static void (*nut_ipmi_fru_ctx_destroy) (ipmi_fru_parse_ctx_t ctx); |
|
+static ipmi_fru_parse_ctx_t (*nut_ipmi_fru_ctx_create) (ipmi_ctx_t ipmi_ctx); |
|
+static int (*nut_ipmi_fru_ctx_set_flags) (ipmi_fru_parse_ctx_t ctx, unsigned int flags); |
|
+static int (*nut_ipmi_fru_open_device_id) (ipmi_fru_parse_ctx_t ctx, uint8_t fru_device_id); |
|
+static char * (*nut_ipmi_fru_ctx_errormsg) (ipmi_fru_parse_ctx_t ctx); |
|
+static int (*nut_ipmi_fru_read_data_area) (ipmi_fru_parse_ctx_t ctx, |
|
unsigned int *area_type, |
|
unsigned int *area_length, |
|
void *areabuf, |
|
unsigned int areabuflen); |
|
-static int (*nut_ipmi_fru_parse_next) (ipmi_fru_parse_ctx_t ctx); |
|
+static int (*nut_ipmi_fru_next) (ipmi_fru_parse_ctx_t ctx); |
|
static ipmi_ctx_t (*nut_ipmi_ctx_create) (void); |
|
static int (*nut_ipmi_ctx_find_inband) (ipmi_ctx_t ctx, |
|
ipmi_driver_type_t *driver_type, |
|
@@ -92,12 +119,12 @@ int nutscan_load_ipmi_library() |
|
/* Clear any existing error */ |
|
lt_dlerror(); |
|
|
|
- *(void **) (&nut_ipmi_fru_parse_close_device_id) = lt_dlsym(dl_handle, "ipmi_fru_parse_close_device_id"); |
|
+ *(void **) (&nut_ipmi_fru_close_device_id) = lt_dlsym(dl_handle, IPMI_FRU_CLOSE_DEVICE_ID); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
} |
|
|
|
- *(void **) (&nut_ipmi_fru_parse_ctx_destroy) = lt_dlsym(dl_handle, "ipmi_fru_parse_ctx_destroy"); |
|
+ *(void **) (&nut_ipmi_fru_ctx_destroy) = lt_dlsym(dl_handle, IPMI_FRU_CTX_DESTROY); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
} |
|
@@ -122,32 +149,32 @@ int nutscan_load_ipmi_library() |
|
} |
|
#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
- *(void **) (&nut_ipmi_fru_parse_ctx_create) = lt_dlsym(dl_handle, "ipmi_fru_parse_ctx_create"); |
|
+ *(void **) (&nut_ipmi_fru_ctx_create) = lt_dlsym(dl_handle, IPMI_FRU_CTX_CREATE); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
} |
|
|
|
- *(void **) (&nut_ipmi_fru_parse_ctx_set_flags) = lt_dlsym(dl_handle, "ipmi_fru_parse_ctx_set_flags"); |
|
+ *(void **) (&nut_ipmi_fru_ctx_set_flags) = lt_dlsym(dl_handle, IPMI_FRU_CTX_SET_FLAGS); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
} |
|
|
|
- *(void **) (&nut_ipmi_fru_parse_open_device_id) = lt_dlsym(dl_handle, "ipmi_fru_parse_open_device_id"); |
|
+ *(void **) (&nut_ipmi_fru_open_device_id) = lt_dlsym(dl_handle, IPMI_FRU_OPEN_DEVICE_ID); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
} |
|
|
|
- *(void **) (&nut_ipmi_fru_parse_ctx_errormsg) = lt_dlsym(dl_handle, "ipmi_fru_parse_ctx_errormsg"); |
|
+ *(void **) (&nut_ipmi_fru_ctx_errormsg) = lt_dlsym(dl_handle, IPMI_FRU_CTX_ERRORMSG); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
} |
|
|
|
- *(void **) (&nut_ipmi_fru_parse_read_data_area) = lt_dlsym(dl_handle, "ipmi_fru_parse_read_data_area"); |
|
+ *(void **) (&nut_ipmi_fru_read_data_area) = lt_dlsym(dl_handle, IPMI_FRU_READ_DATA_AREA); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
} |
|
|
|
- *(void **) (&nut_ipmi_fru_parse_next) = lt_dlsym(dl_handle, "ipmi_fru_parse_next"); |
|
+ *(void **) (&nut_ipmi_fru_next) = lt_dlsym(dl_handle, IPMI_FRU_PARSE_NEXT); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
} |
|
@@ -179,7 +206,7 @@ int nutscan_load_ipmi_library() |
|
|
|
return 1; |
|
err: |
|
- fprintf(stderr, "Cannot load IPMI library (%s) : %s. IPMI search disabled.\n", libname, dl_error); |
|
+ fprintf(stderr, "Cannot load IPMI library (%s) : %s. IPMI search disabled.\n", libname, dl_error); |
|
dl_handle = (void *)1; |
|
lt_dlexit(); |
|
return 0; |
|
@@ -197,8 +224,8 @@ static void nut_freeipmi_cleanup(ipmi_fru_parse_ctx_t fru_parse_ctx, |
|
#endif /* HAVE_FREEIPMI_11X_12X */ |
|
{ |
|
if (fru_parse_ctx) { |
|
- (*nut_ipmi_fru_parse_close_device_id) (fru_parse_ctx); |
|
- (*nut_ipmi_fru_parse_ctx_destroy) (fru_parse_ctx); |
|
+ (*nut_ipmi_fru_close_device_id) (fru_parse_ctx); |
|
+ (*nut_ipmi_fru_ctx_destroy) (fru_parse_ctx); |
|
} |
|
|
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
@@ -226,7 +253,7 @@ int is_ipmi_device_supported(ipmi_ctx_t ipmi_ctx, int ipmi_id) |
|
int ret = -1; |
|
unsigned int area_type = 0; |
|
unsigned int area_length = 0; |
|
- uint8_t areabuf[IPMI_FRU_PARSE_AREA_SIZE_MAX+1]; |
|
+ uint8_t areabuf[IPMI_FRU_AREA_SIZE_MAX+1]; |
|
ipmi_fru_parse_ctx_t fru_parse_ctx = NULL; |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
ipmi_sdr_ctx_t sdr_ctx = NULL; |
|
@@ -236,14 +263,14 @@ int is_ipmi_device_supported(ipmi_ctx_t ipmi_ctx, int ipmi_id) |
|
#endif /* HAVE_FREEIPMI_11X_12X */ |
|
|
|
/* Parse FRU information */ |
|
- if (!(fru_parse_ctx = (*nut_ipmi_fru_parse_ctx_create) (ipmi_ctx))) |
|
+ if (!(fru_parse_ctx = (*nut_ipmi_fru_ctx_create) (ipmi_ctx))) |
|
{ |
|
fprintf(stderr, "ipmi_fru_parse_ctx_create()\n"); |
|
return 0; |
|
} |
|
- |
|
+fprintf(stdout, "There.1\n"); |
|
/* lots of motherboards calculate checksums incorrectly */ |
|
- if ((*nut_ipmi_fru_parse_ctx_set_flags) (fru_parse_ctx, IPMI_FRU_PARSE_FLAGS_SKIP_CHECKSUM_CHECKS) < 0) |
|
+ if ((*nut_ipmi_fru_ctx_set_flags) (fru_parse_ctx, IPMI_FRU_FLAGS_SKIP_CHECKSUM_CHECKS) < 0) |
|
{ |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
nut_freeipmi_cleanup(fru_parse_ctx, sdr_ctx); |
|
@@ -252,8 +279,8 @@ int is_ipmi_device_supported(ipmi_ctx_t ipmi_ctx, int ipmi_id) |
|
#endif /* HAVE_FREEIPMI_11X_12X */ |
|
return 0; |
|
} |
|
- |
|
- if ((*nut_ipmi_fru_parse_open_device_id) (fru_parse_ctx, ipmi_id) < 0) |
|
+fprintf(stdout, "There.2\n"); |
|
+ if ((*nut_ipmi_fru_open_device_id) (fru_parse_ctx, ipmi_id) < 0) |
|
{ |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
nut_freeipmi_cleanup(fru_parse_ctx, sdr_ctx); |
|
@@ -265,17 +292,18 @@ int is_ipmi_device_supported(ipmi_ctx_t ipmi_ctx, int ipmi_id) |
|
|
|
do |
|
{ |
|
+fprintf(stdout, "There.3\n"); |
|
/* clear fields */ |
|
area_type = 0; |
|
area_length = 0; |
|
- memset (areabuf, '\0', IPMI_FRU_PARSE_AREA_SIZE_MAX + 1); |
|
+ memset (areabuf, '\0', IPMI_FRU_AREA_SIZE_MAX + 1); |
|
|
|
/* parse FRU buffer */ |
|
- if ((*nut_ipmi_fru_parse_read_data_area) (fru_parse_ctx, |
|
+ if ((*nut_ipmi_fru_read_data_area) (fru_parse_ctx, |
|
&area_type, |
|
&area_length, |
|
areabuf, |
|
- IPMI_FRU_PARSE_AREA_SIZE_MAX) < 0) |
|
+ IPMI_FRU_AREA_SIZE_MAX) < 0) |
|
{ |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
nut_freeipmi_cleanup(fru_parse_ctx, sdr_ctx); |
|
@@ -287,7 +315,7 @@ int is_ipmi_device_supported(ipmi_ctx_t ipmi_ctx, int ipmi_id) |
|
|
|
if (area_length) |
|
{ |
|
- if (area_type == IPMI_FRU_PARSE_AREA_TYPE_MULTIRECORD_POWER_SUPPLY_INFORMATION) |
|
+ if (area_type == IPMI_FRU_AREA_TYPE_MULTIRECORD_POWER_SUPPLY_INFORMATION) |
|
{ |
|
/* Found a POWER_SUPPLY record */ |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
@@ -298,7 +326,7 @@ int is_ipmi_device_supported(ipmi_ctx_t ipmi_ctx, int ipmi_id) |
|
return 1; |
|
} |
|
} |
|
- } while ((ret = (*nut_ipmi_fru_parse_next) (fru_parse_ctx)) == 1); |
|
+ } while ((ret = (*nut_ipmi_fru_next) (fru_parse_ctx)) == 1); |
|
|
|
/* No need for further errors checking */ |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
@@ -322,7 +350,7 @@ nutscan_device_t * nutscan_scan_ipmi() |
|
if( !nutscan_avail_ipmi ) { |
|
return NULL; |
|
} |
|
- |
|
+fprintf(stdout, "There1\n"); |
|
/* Initialize the FreeIPMI library. */ |
|
if (!(ipmi_ctx = (*nut_ipmi_ctx_create) ())) |
|
{ |
|
@@ -331,6 +359,7 @@ nutscan_device_t * nutscan_scan_ipmi() |
|
return NULL; |
|
} |
|
|
|
+fprintf(stdout, "There2\n"); |
|
if ((ret = (*nut_ipmi_ctx_find_inband) (ipmi_ctx, |
|
NULL, |
|
0, /* don't disable auto-probe */ |
|
@@ -338,7 +367,7 @@ nutscan_device_t * nutscan_scan_ipmi() |
|
0, |
|
NULL, |
|
0, /* workaround flags, none by default */ |
|
- 0 /* flags */ |
|
+ IPMI_FLAGS_NONBLOCKING /* flags */ |
|
)) < 0) |
|
{ |
|
fprintf(stderr, "ipmi_ctx_find_inband: %s\n", |
|
@@ -350,12 +379,14 @@ nutscan_device_t * nutscan_scan_ipmi() |
|
/* No local IPMI device detected */ |
|
return NULL; |
|
} |
|
+fprintf(stdout, "There3 (ret = %i)\n", ret); |
|
|
|
/* Loop through all possible components */ |
|
for (ipmi_id = 0 ; ipmi_id <= IPMI_FRU_DEVICE_ID_MAX ; ipmi_id++) { |
|
- |
|
+fprintf(stdout, "There4\n"); |
|
if (is_ipmi_device_supported(ipmi_ctx, ipmi_id)) { |
|
|
|
+fprintf(stdout, "There4.%i\n", ipmi_id); |
|
if ( (nut_dev = nutscan_new_device()) == NULL ) { |
|
fprintf(stderr,"Memory allocation error\n"); |
|
nutscan_free_device(current_nut_dev); |
|
-- |
|
1.7.10.2 |
|
|
|
|
|
From 64add831fe9cd779f125f52782c4c58cbd62d64b Mon Sep 17 00:00:00 2001 |
|
From: Arnaud Quette <arnaud.quette@free.fr> |
|
Date: Thu, 4 Oct 2012 22:50:52 +0000 |
|
Subject: [PATCH] Support power supplies scan over the network |
|
|
|
nut-scanner can now scan for power supplies with IPMI over LAN. This is |
|
currently limited to IPMI 1.5 only |
|
|
|
Fossil-ID: SVN r3739 |
|
--- |
|
docs/man/nut-scanner.txt | 108 +++++++++-------- |
|
drivers/nut-ipmipsu.c | 15 ++- |
|
tools/nut-scanner/nut-scan.h | 39 ++++++- |
|
tools/nut-scanner/nut-scanner.c | 74 +++++++++++- |
|
tools/nut-scanner/scan_ipmi.c | 243 ++++++++++++++++++++++++++++++++++----- |
|
5 files changed, 388 insertions(+), 91 deletions(-) |
|
|
|
diff --git a/docs/man/nut-scanner.txt b/docs/man/nut-scanner.txt |
|
index 6948449..efe0e58 100644 |
|
--- a/docs/man/nut-scanner.txt |
|
+++ b/docs/man/nut-scanner.txt |
|
@@ -36,118 +36,128 @@ DISPLAY OPTIONS |
|
--------------- |
|
|
|
*-N* | *--disp_nut_conf*:: |
|
- |
|
- Display result in the 'ups.conf' format. |
|
+Display result in the 'ups.conf' format. |
|
|
|
*-P* | *--disp_parsable*:: |
|
- |
|
- Display result in a parsable format. |
|
+Display result in a parsable format. |
|
|
|
BUS OPTIONS |
|
----------- |
|
|
|
*-C* | *--complete_scan*:: |
|
- |
|
- Scan all available communication buses (default behavior) |
|
+Scan all available communication buses (default behavior) |
|
|
|
*-U* | *--usb_scan*:: |
|
- |
|
- List all NUT-compatible USB devices currently plugged in. |
|
+List all NUT-compatible USB devices currently plugged in. |
|
|
|
*-S* | *--snmp_scan*:: |
|
- |
|
- Scan SNMP devices. Requires at least a 'start IP', and optionally, an 'end IP'. See specific SNMP OPTIONS for community and security settings. |
|
+Scan SNMP devices. Requires at least a 'start IP', and optionally, an 'end IP'. See specific SNMP OPTIONS for community and security settings. |
|
|
|
*-M* | *--xml_scan*:: |
|
- |
|
- Scan XML/HTTP devices. Broadcast a network message on the current network interfaces to retrieve XML/HTTP capable devices. No IP required. |
|
+Scan XML/HTTP devices. Broadcast a network message on the current network interfaces to retrieve XML/HTTP capable devices. No IP required. |
|
|
|
*-O* | *--oldnut_scan*:: |
|
- |
|
- Scan NUT devices (i.e. upsd daemon) on IP ranging from 'start IP' to 'end IP'. |
|
+Scan NUT devices (i.e. upsd daemon) on IP ranging from 'start IP' to 'end IP'. |
|
|
|
*-A* | *--avahi_scan*:: |
|
- |
|
- Scan NUT servers using Avahi request on the current network interfaces. No IP required. |
|
+Scan NUT servers using Avahi request on the current network interfaces. No IP required. |
|
|
|
*-I* | *--ipmi_scan*:: |
|
- |
|
- Scan NUT compatible devices available via IPMI on the current host. |
|
+Scan NUT compatible power supplies available via IPMI on the current host, or over the network. |
|
|
|
NETWORK OPTIONS |
|
--------------- |
|
|
|
*-t* | *--timeout* 'timeout':: |
|
- |
|
- Set the network timeout in seconds. Default timeout is 5 seconds. |
|
+Set the network timeout in seconds. Default timeout is 5 seconds. |
|
|
|
*-s* | *--start_ip* 'start IP':: |
|
- |
|
- Set the first IP (IPv4 or IPv6) when a range of IP is required (SNMP, old_nut). |
|
+Set the first IP (IPv4 or IPv6) when a range of IP is required (SNMP, old_nut). |
|
|
|
*-e* | *--end_ip* 'end IP':: |
|
- |
|
- Set the last IP (IPv4 or IPv6) when a range of IP is required (SNMP, old_nut). If this parameter is omitted, only the 'start IP' is scanned. If 'end IP' is less than 'start IP', both parameters are internally permuted. |
|
+Set the last IP (IPv4 or IPv6) when a range of IP is required (SNMP, old_nut). If this parameter is omitted, only the 'start IP' is scanned. If 'end IP' is less than 'start IP', both parameters are internally permuted. |
|
|
|
*-m* | *--mask_cidr* 'IP address/mask':: |
|
- |
|
- Set a range of IP using CIDR notation. |
|
+Set a range of IP using CIDR notation. |
|
|
|
NUT DEVICE OPTION |
|
----------------- |
|
|
|
*-p* | *--port* 'port number':: |
|
- |
|
- Set the port number of scanned NUT devices (default 3493). |
|
+Set the port number of scanned NUT devices (default 3493). |
|
|
|
SNMP V1 OPTION |
|
-------------- |
|
|
|
*-c* | *--community* 'community':: |
|
- |
|
- Set SNMP v1 community name (default = public). |
|
+Set SNMP v1 community name (default = public). |
|
|
|
SNMP V3 OPTIONS |
|
--------------- |
|
|
|
*-l* | *--secLevel* 'security level':: |
|
- |
|
- Set the 'security level' used for SNMPv3 messages. Allowed values are: noAuthNoPriv, authNoPriv and authPriv. |
|
+Set the 'security level' used for SNMPv3 messages. Allowed values are: noAuthNoPriv, authNoPriv and authPriv. |
|
|
|
*-u* | *--secName* 'security name':: |
|
- |
|
- Set the 'security name' used for authenticated SNMPv3 messages. This parameter is mandatory if you set 'security level'. |
|
+Set the 'security name' used for authenticated SNMPv3 messages. This parameter is mandatory if you set 'security level'. |
|
|
|
*-w* | *--authProtocol* 'authentication protocol':: |
|
- |
|
- Set the 'authentication protocol' used for authenticated SNMPv3 messages. Allowed values are MD5 or SHA. Default value is MD5. |
|
+Set the 'authentication protocol' used for authenticated SNMPv3 messages. Allowed values are MD5 or SHA. Default value is MD5. |
|
|
|
*-W* | *--authPassword* 'authentication pass phrase':: |
|
- |
|
- Set the 'authentication pass phrase' used for authenticated SNMPv3 messages. This parameter is mandatory if you set 'security level' to authNoPriv or authPriv. |
|
+Set the 'authentication pass phrase' used for authenticated SNMPv3 messages. This parameter is mandatory if you set 'security level' to authNoPriv or authPriv. |
|
|
|
*-x* | *--privProtocol* 'privacy protocol':: |
|
- |
|
- Set the 'privacy protocol' used for encrypted SNMPv3 messages. Allowed values are DES or AES. Default value is DES. |
|
+Set the 'privacy protocol' used for encrypted SNMPv3 messages. Allowed values are DES or AES. Default value is DES. |
|
|
|
*-X* | *--privPassword* 'privacy pass phrase':: |
|
+Set the 'privacy pass phrase' used for encrypted SNMPv3 messages. This parameter is mandatory if you set 'security level' to authPriv. |
|
|
|
- Set the 'privacy pass phrase' used for encrypted SNMPv3 messages. This parameter is mandatory if you set 'security level' to authPriv. |
|
+IPMI OPTIONS |
|
+------------ |
|
+ |
|
+*-b* | *--username* 'username':: |
|
+Set the username used for authenticating IPMI over LAN connections (mandatory for IPMI over LAN. No default). |
|
+ |
|
+*-B* | *--password* 'password':: |
|
+Specify the password to use when authenticationg with the remote host (mandatory for IPMI over LAN. No default). |
|
+ |
|
+*-d* | *--authType* 'authentication type':: |
|
+Specify the IPMI 1.5 authentication type to use (NONE, STRAIGHT_PASSWORD_KEY, MD2, and MD5) with the remote host (default=MD5). |
|
+This forces connection through the 'lan' IPMI interface , thus in IPMI 1.5 mode. |
|
+ |
|
+*-D* | *--cipher_suite_id* 'cipher suite identifier':: |
|
+Specify the IPMI 2.0 cipher suite ID to use. The Cipher Suite ID identifies a set of authentication, integrity, and |
|
+confidentiality algorithms to use for IPMI 2.0 communication. The authentication algorithm identifies the algorithm |
|
+to use for session setup, the integrity algorithm identifies the algorithm to use for session packet signatures, and the |
|
+confidentiality algorithm identifies the algorithm to use for payload encryption (default=3). |
|
++ |
|
+The following cipher suite ids are currently supported (Authentication; Integrity; Confidentiality): |
|
+ |
|
+- *0*: None; None; None |
|
+- *1*: HMAC-SHA1; None; None |
|
+- *2*: HMAC-SHA1; HMAC-SHA1-96; None |
|
+- *3*: HMAC-SHA1; HMAC-SHA1-96; AES-CBC-128 |
|
+- *6*: HMAC-MD5; None; None |
|
+- *7*: HMAC-MD5; HMAC-MD5-128; None |
|
+- *8*: HMAC-MD5; HMAC-MD5-128; AES-CBC-128 |
|
+- *11*: HMAC-MD5; MD5-128; None |
|
+- *12*: HMAC-MD5; MD5-128; AES-CBC-128 |
|
+- *15*: HMAC-SHA256; None; None |
|
+- *16*: HMAC-SHA256; HMAC_SHA256_128; None |
|
+- *17*: HMAC-SHA256; HMAC_SHA256_128; AES-CBC-128 |
|
|
|
MISCELLANEOUS OPTIONS |
|
--------------------- |
|
|
|
*-V* | *--version*:: |
|
- |
|
- Display NUT version. |
|
+Display NUT version. |
|
|
|
*-a* | *--available*:: |
|
- |
|
- Display available bus that can be scanned , depending on how the binary has been compiled. (OLDNUT, USB, SNMP, XML, AVAHI, IPMI). |
|
+Display available bus that can be scanned , depending on how the binary has been compiled. (OLDNUT, USB, SNMP, XML, AVAHI, IPMI). |
|
|
|
*-q* | *--quiet*:: |
|
- |
|
- Display only scan result. No information on currently scanned bus is displayed. |
|
+Display only scan result. No information on currently scanned bus is displayed. |
|
|
|
EXAMPLES |
|
-------- |
|
@@ -168,6 +178,10 @@ To scan NUT servers with a timeout of 10 seconds on IP range 192.168.0.0 to 192. |
|
|
|
*nut-scanner -O -t 10 -m 192.168.0.0/25* |
|
|
|
+To scan for power supplies, through IPMI (1.5 mode) over the network, on address range 192.168.0.0 to 192.168.0.255: |
|
+ |
|
+*nut-scanner -I -m 192.168.0.0/24 -b username -B password* |
|
+ |
|
SEE ALSO |
|
-------- |
|
|
|
diff --git a/drivers/nut-ipmipsu.c b/drivers/nut-ipmipsu.c |
|
index b7382a8..2991cfc 100644 |
|
--- a/drivers/nut-ipmipsu.c |
|
+++ b/drivers/nut-ipmipsu.c |
|
@@ -27,7 +27,7 @@ |
|
#include "nut-ipmi.h" |
|
|
|
#define DRIVER_NAME "IPMI PSU driver" |
|
-#define DRIVER_VERSION "0.07" |
|
+#define DRIVER_VERSION "0.30" |
|
|
|
/* driver description structure */ |
|
upsdrv_info_t upsdrv_info = { |
|
@@ -183,17 +183,20 @@ void upsdrv_makevartable(void) |
|
"Type of the device to match ('psu' for \"Power Supply\")"); |
|
|
|
addvar(VAR_VALUE, "serial", "Serial number to match a specific device"); |
|
- addvar(VAR_VALUE, "fruid", "FRU identifier to match a specific device"); |
|
- addvar(VAR_VALUE, "sensorid", "Sensor identifier to match a specific device"); */ |
|
+ addvar(VAR_VALUE, "fruid", "FRU identifier to match a specific device"); */ |
|
} |
|
|
|
void upsdrv_initups(void) |
|
{ |
|
upsdebugx(1, "upsdrv_initups..."); |
|
|
|
- /* port can be expressed using: |
|
- * "id?" for device (FRU) ID 0x? |
|
- * "psu?" for PSU number ? |
|
+ /* port can be expressed in various forms: |
|
+ * - inband: |
|
+ * "id?" for device (FRU) ID 0x? |
|
+ * "psu?" for PSU number ? |
|
+ * - out of band |
|
+ * "id?@host" |
|
+ * "host" => requires serial or ... |
|
*/ |
|
if (!strncmp( device_path, "id", 2)) |
|
{ |
|
diff --git a/tools/nut-scanner/nut-scan.h b/tools/nut-scanner/nut-scan.h |
|
index affcc77..8b9f1ab 100644 |
|
--- a/tools/nut-scanner/nut-scan.h |
|
+++ b/tools/nut-scanner/nut-scan.h |
|
@@ -1,6 +1,8 @@ |
|
/* nut-scan.h: detect NUT services |
|
* |
|
- * Copyright (C) 2011 - Frederic Bohe <fredericbohe@eaton.com> |
|
+ * Copyright (C) |
|
+ * 2011 - Frederic Bohe <fredericbohe@eaton.com> |
|
+ * 2012 - Arnaud Quette <arnaud.quette@free.fr> |
|
* |
|
* This program is free software; you can redistribute it and/or modify |
|
* it under the terms of the GNU General Public License as published by |
|
@@ -16,6 +18,7 @@ |
|
* along with this program; if not, write to the Free Software |
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
*/ |
|
+ |
|
#ifndef NUT_SCAN_H |
|
#define NUT_SCAN_H |
|
|
|
@@ -23,6 +26,10 @@ |
|
#include <nutscan-device.h> |
|
#include <nutscan-ip.h> |
|
|
|
+#ifdef WITH_IPMI |
|
+#include <freeipmi/freeipmi.h> |
|
+#endif |
|
+ |
|
/* SNMP structure */ |
|
typedef struct nutscan_snmp { |
|
char * community; |
|
@@ -36,8 +43,34 @@ typedef struct nutscan_snmp { |
|
void * handle; |
|
} nutscan_snmp_t; |
|
|
|
+/* IPMI structure */ |
|
+/* Settings for OutofBand (remote) connection */ |
|
+typedef struct nutscan_ipmi { |
|
+ char* username; /* IPMI 1.5 and 2.0 */ |
|
+ char* password; /* IPMI 1.5 and 2.0 */ |
|
+ int authentication_type; /* IPMI 1.5 */ |
|
+ int cipher_suite_id; /* IPMI 2.0 */ |
|
+ char* K_g_BMC_key; /* IPMI 2.0, optional key for 2 key auth. */ |
|
+ int privilege_level; /* for both */ |
|
+ unsigned int workaround_flags; /* for both */ |
|
+ int ipmi_version; /* IPMI 1.5 or 2.0? */ |
|
+} nutscan_ipmi_t; |
|
+ |
|
+/* IPMI auth defines, simply using FreeIPMI defines */ |
|
+#ifndef IPMI_AUTHENTICATION_TYPE_NONE |
|
+ #define IPMI_AUTHENTICATION_TYPE_NONE 0x00 |
|
+ #define IPMI_AUTHENTICATION_TYPE_MD2 0x01 |
|
+ #define IPMI_AUTHENTICATION_TYPE_MD5 0x02 |
|
+ #define IPMI_AUTHENTICATION_TYPE_STRAIGHT_PASSWORD_KEY 0x04 |
|
+ #define IPMI_AUTHENTICATION_TYPE_OEM_PROP 0x05 |
|
+ #define IPMI_AUTHENTICATION_TYPE_RMCPPLUS 0x06 |
|
+#endif /* IPMI_AUTHENTICATION_TYPE_NONE */ |
|
+ |
|
+#define IPMI_1_5 1 |
|
+#define IPMI_2_0 0 |
|
+ |
|
/* Scanning */ |
|
-nutscan_device_t * nutscan_scan_snmp(const char * start_ip,const char * stop_ip,long usec_timeout, nutscan_snmp_t * sec); |
|
+nutscan_device_t * nutscan_scan_snmp(const char * start_ip, const char * stop_ip, long usec_timeout, nutscan_snmp_t * sec); |
|
|
|
nutscan_device_t * nutscan_scan_usb(); |
|
|
|
@@ -47,7 +80,7 @@ nutscan_device_t * nutscan_scan_nut(const char * startIP, const char * stopIP, c |
|
|
|
nutscan_device_t * nutscan_scan_avahi(long usec_timeout); |
|
|
|
-nutscan_device_t * nutscan_scan_ipmi(void); |
|
+nutscan_device_t * nutscan_scan_ipmi(const char * startIP, const char * stopIP, nutscan_ipmi_t * sec); |
|
|
|
/* Display functions */ |
|
void nutscan_display_ups_conf(nutscan_device_t * device); |
|
diff --git a/tools/nut-scanner/nut-scanner.c b/tools/nut-scanner/nut-scanner.c |
|
index 52e0da7..7ca1554 100644 |
|
--- a/tools/nut-scanner/nut-scanner.c |
|
+++ b/tools/nut-scanner/nut-scanner.c |
|
@@ -35,7 +35,7 @@ |
|
|
|
#define ERR_BAD_OPTION (-1) |
|
|
|
-const char optstring[] = "?ht:s:e:c:l:u:W:X:w:x:p:CUSMOAm:NPqIVa"; |
|
+const char optstring[] = "?ht:s:e:c:l:u:W:X:w:x:p:b:B:d:D:CUSMOAm:NPqIVa"; |
|
|
|
#ifdef HAVE_GETOPT_LONG |
|
const struct option longopts[] = |
|
@@ -50,6 +50,10 @@ const struct option longopts[] = |
|
{ "privPassword",required_argument,NULL,'X' }, |
|
{ "authProtocol",required_argument,NULL,'w' }, |
|
{ "privProtocol",required_argument,NULL,'x' }, |
|
+ { "username",required_argument,NULL,'b' }, |
|
+ { "password",required_argument,NULL,'B' }, |
|
+ { "authType",required_argument,NULL,'d' }, |
|
+ { "cipher_suite_id",required_argument,NULL,'D' }, |
|
{ "port",required_argument,NULL,'p' }, |
|
{ "complete_scan",no_argument,NULL,'C' }, |
|
{ "usb_scan",no_argument,NULL,'U' }, |
|
@@ -110,7 +114,9 @@ static void * run_avahi(void * arg) |
|
} |
|
static void * run_ipmi(void * arg) |
|
{ |
|
- dev[TYPE_IPMI] = nutscan_scan_ipmi(); |
|
+ nutscan_ipmi_t * sec = (nutscan_ipmi_t *)arg; |
|
+ |
|
+ dev[TYPE_IPMI] = nutscan_scan_ipmi(start_ip,end_ip,sec); |
|
return NULL; |
|
} |
|
#endif /* HAVE_PTHREAD */ |
|
@@ -133,6 +139,7 @@ static int printq(int quiet,const char *fmt, ...) |
|
int main(int argc, char *argv[]) |
|
{ |
|
nutscan_snmp_t snmp_sec; |
|
+ nutscan_ipmi_t ipmi_sec; |
|
int opt_ret; |
|
char * cidr = NULL; |
|
int allow_all = 0; |
|
@@ -147,6 +154,12 @@ int main(int argc, char *argv[]) |
|
int ret_code = EXIT_SUCCESS; |
|
|
|
memset(&snmp_sec, 0, sizeof(snmp_sec)); |
|
+ memset(&ipmi_sec, 0, sizeof(ipmi_sec)); |
|
+ /* Set the default values for IPMI */ |
|
+ ipmi_sec.authentication_type = IPMI_AUTHENTICATION_TYPE_MD5; |
|
+ ipmi_sec.ipmi_version = IPMI_1_5; /* default to IPMI 1.5, if not otherwise specified */ |
|
+ ipmi_sec.cipher_suite_id = 3; /* default to HMAC-SHA1; HMAC-SHA1-96; AES-CBC-128 */ |
|
+ ipmi_sec.privilege_level = IPMI_PRIVILEGE_LEVEL_ADMIN; /* should be sufficient */ |
|
|
|
nutscan_init(); |
|
|
|
@@ -220,6 +233,45 @@ int main(int argc, char *argv[]) |
|
} |
|
allow_snmp = 1; |
|
break; |
|
+ case 'b': |
|
+ if(!nutscan_avail_ipmi) { |
|
+ goto display_help; |
|
+ } |
|
+ ipmi_sec.username = strdup(optarg); |
|
+ break; |
|
+ case 'B': |
|
+ if(!nutscan_avail_ipmi) { |
|
+ goto display_help; |
|
+ } |
|
+ ipmi_sec.password = strdup(optarg); |
|
+ break; |
|
+ case 'd': |
|
+ if(!nutscan_avail_ipmi) { |
|
+ goto display_help; |
|
+ } |
|
+ if (!strcmp(optarg, "NONE")) { |
|
+ ipmi_sec.authentication_type = IPMI_AUTHENTICATION_TYPE_NONE; |
|
+ } |
|
+ else if (!strcmp(optarg, "STRAIGHT_PASSWORD_KEY")) { |
|
+ ipmi_sec.authentication_type = IPMI_AUTHENTICATION_TYPE_STRAIGHT_PASSWORD_KEY; |
|
+ } |
|
+ else if (!strcmp(optarg, "MD2")) { |
|
+ ipmi_sec.authentication_type = IPMI_AUTHENTICATION_TYPE_MD2; |
|
+ } |
|
+ else if (!strcmp(optarg, "MD5")) { |
|
+ ipmi_sec.authentication_type = IPMI_AUTHENTICATION_TYPE_MD5; |
|
+ } |
|
+ else { |
|
+ fprintf(stderr,"Unknown authentication type (%s). Defaulting to MD5\n", optarg); |
|
+ } |
|
+ break; |
|
+ case 'D': |
|
+ if(!nutscan_avail_ipmi) { |
|
+ goto display_help; |
|
+ } |
|
+ ipmi_sec.cipher_suite_id = atoi(optarg); |
|
+ /* Force IPMI 2.0! */ |
|
+ ipmi_sec.ipmi_version = IPMI_2_0; |
|
case 'p': |
|
port = strdup(optarg); |
|
break; |
|
@@ -307,6 +359,8 @@ display_help: |
|
if( nutscan_avail_ipmi ) { |
|
printf(" -I, --ipmi_scan: Scan IPMI devices.\n"); |
|
} |
|
+ |
|
+ printf("\nNetwork specific options:\n"); |
|
printf(" -t, --timeout <timeout in seconds>: network operation timeout (default %d).\n",DEFAULT_TIMEOUT); |
|
printf(" -s, --start_ip <IP address>: First IP address to scan.\n"); |
|
printf(" -e, --end_ip <IP address>: Last IP address to scan.\n"); |
|
@@ -325,6 +379,18 @@ display_help: |
|
printf(" -X, --privPassword <privacy pass phrase>: Set the privacy pass phrase used for encrypted SNMPv3 messages (mandatory if you set secLevel to authPriv)\n"); |
|
} |
|
|
|
+ if( nutscan_avail_ipmi ) { |
|
+ printf("\nIPMI over LAN specific options:\n"); |
|
+ printf(" -b, --username <username>: Set the username used for authenticating IPMI over LAN connections (mandatory for IPMI over LAN. No default)\n"); |
|
+ /* Specify the username to use when authenticating with the remote host. If not specified, a null (i.e. anonymous) username is assumed. The user must have |
|
+ * at least ADMIN privileges in order for this tool to operate fully. */ |
|
+ printf(" -B, --password <password>: Specify the password to use when authenticationg with the remote host (mandatory for IPMI over LAN. No default)\n"); |
|
+ /* Specify the password to use when authenticationg with the remote host. If not specified, a null password is assumed. Maximum password length is 16 for IPMI |
|
+ * 1.5 and 20 for IPMI 2.0. */ |
|
+ printf(" -d, --authType <authentication type>: Specify the IPMI 1.5 authentication type to use (NONE, STRAIGHT_PASSWORD_KEY, MD2, and MD5) with the remote host (default=MD5)\n"); |
|
+ printf(" -D, --cipher_suite_id <cipher suite id>: Specify the IPMI 2.0 cipher suite ID to use, for authentication, integrity, and confidentiality (default=3)\n"); |
|
+ } |
|
+ |
|
printf("\nNUT specific options:\n"); |
|
printf(" -p, --port <port number>: Port number of remote NUT upsd\n"); |
|
printf("\ndisplay specific options:\n"); |
|
@@ -427,11 +493,11 @@ display_help: |
|
if( allow_ipmi && nutscan_avail_ipmi) { |
|
printq(quiet,"Scanning IPMI bus.\n"); |
|
#ifdef HAVE_PTHREAD |
|
- if(pthread_create(&thread[TYPE_IPMI],NULL,run_ipmi,NULL)) { |
|
+ if(pthread_create(&thread[TYPE_IPMI],NULL,run_ipmi,&ipmi_sec)) { |
|
nutscan_avail_ipmi = 0; |
|
} |
|
#else |
|
- dev[TYPE_IPMI] = nutscan_scan_ipmi(); |
|
+ dev[TYPE_IPMI] = nutscan_scan_ipmi(start_ip,end_ip,timeout,&ipmi_sec); |
|
#endif /* HAVE_PTHREAD */ |
|
} |
|
|
|
diff --git a/tools/nut-scanner/scan_ipmi.c b/tools/nut-scanner/scan_ipmi.c |
|
index c1ec78a..0288ad4 100644 |
|
--- a/tools/nut-scanner/scan_ipmi.c |
|
+++ b/tools/nut-scanner/scan_ipmi.c |
|
@@ -29,6 +29,11 @@ |
|
|
|
#define NUT_IPMI_DRV_NAME "nut-ipmipsu" |
|
|
|
+/* IPMI defines */ |
|
+/* 5 seconds for establishing an IPMI connection */ |
|
+#define IPMI_SESSION_TIMEOUT_LENGTH_DEFAULT 5000 |
|
+#define IPMI_RETRANSMISSION_TIMEOUT_LENGTH_DEFAULT 250 |
|
+ |
|
/* dynamic link library stuff */ |
|
static char * libname = "libfreeipmi"; |
|
static lt_dlhandle dl_handle = NULL; |
|
@@ -88,10 +93,23 @@ static int (*nut_ipmi_ctx_find_inband) (ipmi_ctx_t ctx, |
|
const char *driver_device, |
|
unsigned int workaround_flags, |
|
unsigned int flags); |
|
+static int (*nut_ipmi_ctx_open_outofband) (ipmi_ctx_t ctx, |
|
+ const char *hostname, |
|
+ const char *username, |
|
+ const char *password, |
|
+ uint8_t authentication_type, |
|
+ uint8_t privilege_level, |
|
+ unsigned int session_timeout, |
|
+ unsigned int retransmission_timeout, |
|
+ unsigned int workaround_flags, |
|
+ unsigned int flags); |
|
+static int (*nut_ipmi_ctx_errnum) (ipmi_ctx_t ctx); |
|
static char * (*nut_ipmi_ctx_errormsg) (ipmi_ctx_t ctx); |
|
static int (*nut_ipmi_ctx_close) (ipmi_ctx_t ctx); |
|
static void (*nut_ipmi_ctx_destroy) (ipmi_ctx_t ctx); |
|
|
|
+/* Internal functions */ |
|
+static nutscan_device_t * nutscan_scan_ipmi_device(const char * IPaddr, nutscan_ipmi_t * sec); |
|
|
|
/* Return 0 on error */ |
|
int nutscan_load_ipmi_library() |
|
@@ -189,6 +207,16 @@ int nutscan_load_ipmi_library() |
|
goto err; |
|
} |
|
|
|
+ *(void **) (&nut_ipmi_ctx_open_outofband) = lt_dlsym(dl_handle, "ipmi_ctx_open_outofband"); |
|
+ if ((dl_error = lt_dlerror()) != NULL) { |
|
+ goto err; |
|
+ } |
|
+ |
|
+ *(void **) (&nut_ipmi_ctx_errnum) = lt_dlsym(dl_handle, "ipmi_ctx_errnum"); |
|
+ if ((dl_error = lt_dlerror()) != NULL) { |
|
+ goto err; |
|
+ } |
|
+ |
|
*(void **) (&nut_ipmi_ctx_errormsg) = lt_dlsym(dl_handle, "ipmi_ctx_errormsg"); |
|
if ((dl_error = lt_dlerror()) != NULL) { |
|
goto err; |
|
@@ -265,10 +293,10 @@ int is_ipmi_device_supported(ipmi_ctx_t ipmi_ctx, int ipmi_id) |
|
/* Parse FRU information */ |
|
if (!(fru_parse_ctx = (*nut_ipmi_fru_ctx_create) (ipmi_ctx))) |
|
{ |
|
- fprintf(stderr, "ipmi_fru_parse_ctx_create()\n"); |
|
+ fprintf(stderr, "Error with %s(): %s\n", IPMI_FRU_CTX_CREATE, (*nut_ipmi_ctx_errormsg)(ipmi_ctx)); |
|
return 0; |
|
} |
|
-fprintf(stdout, "There.1\n"); |
|
+ |
|
/* lots of motherboards calculate checksums incorrectly */ |
|
if ((*nut_ipmi_fru_ctx_set_flags) (fru_parse_ctx, IPMI_FRU_FLAGS_SKIP_CHECKSUM_CHECKS) < 0) |
|
{ |
|
@@ -279,7 +307,7 @@ fprintf(stdout, "There.1\n"); |
|
#endif /* HAVE_FREEIPMI_11X_12X */ |
|
return 0; |
|
} |
|
-fprintf(stdout, "There.2\n"); |
|
+ |
|
if ((*nut_ipmi_fru_open_device_id) (fru_parse_ctx, ipmi_id) < 0) |
|
{ |
|
#ifdef HAVE_FREEIPMI_11X_12X |
|
@@ -292,7 +320,6 @@ fprintf(stdout, "There.2\n"); |
|
|
|
do |
|
{ |
|
-fprintf(stdout, "There.3\n"); |
|
/* clear fields */ |
|
area_type = 0; |
|
area_length = 0; |
|
@@ -337,20 +364,21 @@ fprintf(stdout, "There.3\n"); |
|
return 0; |
|
} |
|
|
|
-/* return NULL on error */ |
|
-nutscan_device_t * nutscan_scan_ipmi() |
|
+/* Check for IPMI support on a specific (local or remote) system |
|
+ * Return NULL on error, or a valid nutscan_device_t otherwise */ |
|
+nutscan_device_t * nutscan_scan_ipmi_device(const char * IPaddr, nutscan_ipmi_t * ipmi_sec) |
|
{ |
|
ipmi_ctx_t ipmi_ctx = NULL; |
|
nutscan_device_t * nut_dev = NULL; |
|
nutscan_device_t * current_nut_dev = NULL; |
|
int ret = -1; |
|
int ipmi_id = 0; |
|
- char port_id[10]; |
|
+ char port_id[64]; |
|
|
|
if( !nutscan_avail_ipmi ) { |
|
return NULL; |
|
} |
|
-fprintf(stdout, "There1\n"); |
|
+ |
|
/* Initialize the FreeIPMI library. */ |
|
if (!(ipmi_ctx = (*nut_ipmi_ctx_create) ())) |
|
{ |
|
@@ -359,34 +387,138 @@ fprintf(stdout, "There1\n"); |
|
return NULL; |
|
} |
|
|
|
-fprintf(stdout, "There2\n"); |
|
- if ((ret = (*nut_ipmi_ctx_find_inband) (ipmi_ctx, |
|
- NULL, |
|
- 0, /* don't disable auto-probe */ |
|
- 0, |
|
- 0, |
|
- NULL, |
|
- 0, /* workaround flags, none by default */ |
|
- IPMI_FLAGS_NONBLOCKING /* flags */ |
|
- )) < 0) |
|
+ /* Are we scanning locally, or over the network? */ |
|
+ if (IPaddr == NULL) |
|
{ |
|
- fprintf(stderr, "ipmi_ctx_find_inband: %s\n", |
|
- (*nut_ipmi_ctx_errormsg) (ipmi_ctx)); |
|
- return NULL; |
|
+ /* FIXME: we need root right to access local IPMI! |
|
+ if (!ipmi_is_root ()) { |
|
+ fprintf(stderr, "IPMI scan: %s\n", ipmi_ctx_strerror (IPMI_ERR_PERMISSION)); |
|
+ } */ |
|
+ |
|
+ if ((ret = (*nut_ipmi_ctx_find_inband) (ipmi_ctx, |
|
+ NULL, |
|
+ 0, /* don't disable auto-probe */ |
|
+ 0, |
|
+ 0, |
|
+ NULL, |
|
+ 0, /* workaround flags, none by default */ |
|
+ 0 /* flags */ |
|
+ )) < 0) |
|
+ { |
|
+ fprintf(stderr, "ipmi_ctx_find_inband: %s\n", |
|
+ (*nut_ipmi_ctx_errormsg) (ipmi_ctx)); |
|
+ return NULL; |
|
+ } |
|
+ if (!ret) |
|
+ { |
|
+ /* No local IPMI device detected */ |
|
+ return NULL; |
|
+ } |
|
} |
|
- if (!ret) |
|
- { |
|
- /* No local IPMI device detected */ |
|
- return NULL; |
|
+ else { |
|
+ |
|
+#if 0 |
|
+ if (ipmi_sec->ipmi_version == IPMI_2_0) { |
|
+ |
|
+ /* FIXME: need processing?! |
|
+ * int parse_kg (void *out, unsigned int outlen, const char *in) |
|
+ * if ((rv = parse_kg (common_cmd_args_config->k_g, IPMI_MAX_K_G_LENGTH + 1, data->string)) < 0) |
|
+ * { |
|
+ * fprintf (stderr, "Config File Error: k_g input formatted incorrectly\n"); |
|
+ * exit (EXIT_FAILURE); |
|
+ * }*/ |
|
+ if ((ret = (*nut_ipmi_ctx_open_outofband_2_0) (ipmi_ctx, |
|
+ IPaddr, |
|
+ ipmi_sec->username, |
|
+ ipmi_sec->password, |
|
+ ipmi_sec->K_g_BMC_key, |
|
+??? (ipmi_sec->K_g_BMC_key) ? config->k_g_len : 0, |
|
+ ipmi_sec->privilege_level, |
|
+ ipmi_sec->cipher_suite_id, |
|
+ IPMI_SESSION_TIMEOUT_LENGTH_DEFAULT, |
|
+ IPMI_RETRANSMISSION_TIMEOUT_LENGTH_DEFAULT, |
|
+ ipmi_dev->workaround_flags, |
|
+ flags) < 0) |
|
+ { |
|
+ IPMI_MONITORING_DEBUG (("ipmi_ctx_open_outofband_2_0: %s", ipmi_ctx_errormsg (c->ipmi_ctx))); |
|
+ if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_USERNAME_INVALID) |
|
+ c->errnum = IPMI_MONITORING_ERR_USERNAME_INVALID; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_PASSWORD_INVALID) |
|
+ c->errnum = IPMI_MONITORING_ERR_PASSWORD_INVALID; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_PRIVILEGE_LEVEL_INSUFFICIENT) |
|
+ c->errnum = IPMI_MONITORING_ERR_PRIVILEGE_LEVEL_INSUFFICIENT; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_PRIVILEGE_LEVEL_CANNOT_BE_OBTAINED) |
|
+ c->errnum = IPMI_MONITORING_ERR_PRIVILEGEL_LEVEL_CANNOT_BE_OBTAINED; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_K_G_INVALID) |
|
+ c->errnum = IPMI_MONITORING_ERR_K_G_INVALID; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_CIPHER_SUITE_ID_UNAVAILABLE) |
|
+ c->errnum = IPMI_MONITORING_ERR_CIPHER_SUITE_ID_UNAVAILABLE; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_PASSWORD_VERIFICATION_TIMEOUT) |
|
+ c->errnum = IPMI_MONITORING_ERR_PASSWORD_VERIFICATION_TIMEOUT; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_IPMI_2_0_UNAVAILABLE) |
|
+ c->errnum = IPMI_MONITORING_ERR_IPMI_2_0_UNAVAILABLE; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_CONNECTION_TIMEOUT) |
|
+ c->errnum = IPMI_MONITORING_ERR_CONNECTION_TIMEOUT; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_SESSION_TIMEOUT) |
|
+ c->errnum = IPMI_MONITORING_ERR_SESSION_TIMEOUT; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_BAD_COMPLETION_CODE |
|
+ || ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_IPMI_ERROR) |
|
+ c->errnum = IPMI_MONITORING_ERR_IPMI_ERROR; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_BMC_BUSY) |
|
+ c->errnum = IPMI_MONITORING_ERR_BMC_BUSY; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_OUT_OF_MEMORY) |
|
+ c->errnum = IPMI_MONITORING_ERR_OUT_OF_MEMORY; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_HOSTNAME_INVALID) |
|
+ c->errnum = IPMI_MONITORING_ERR_HOSTNAME_INVALID; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_PARAMETERS) |
|
+ c->errnum = IPMI_MONITORING_ERR_PARAMETERS; |
|
+ else if (ipmi_ctx_errnum (c->ipmi_ctx) == IPMI_ERR_SYSTEM_ERROR) |
|
+ c->errnum = IPMI_MONITORING_ERR_SYSTEM_ERROR; |
|
+ else |
|
+ c->errnum = IPMI_MONITORING_ERR_INTERNAL_ERROR; |
|
+ return (-1); |
|
+ } |
|
+ } |
|
+ else { /* Not IPMI 2.0 */ |
|
+ |
|
+#endif /* 0 */ |
|
+ |
|
+ /* Fall back to IPMI 1.5 */ |
|
+ if ((ret = (*nut_ipmi_ctx_open_outofband) (ipmi_ctx, |
|
+ IPaddr, |
|
+ ipmi_sec->username, |
|
+ ipmi_sec->password, |
|
+ ipmi_sec->authentication_type, |
|
+ ipmi_sec->privilege_level, |
|
+ IPMI_SESSION_TIMEOUT_LENGTH_DEFAULT, |
|
+ IPMI_RETRANSMISSION_TIMEOUT_LENGTH_DEFAULT, |
|
+ ipmi_sec->workaround_flags, |
|
+ IPMI_FLAGS_DEFAULT |
|
+ )) < 0) |
|
+ { |
|
+ /* No IPMI device detected on this host! |
|
+ if ((*nut_ipmi_ctx_errnum) (ipmi_ctx) == IPMI_ERR_USERNAME_INVALID |
|
+ || (*nut_ipmi_ctx_errnum) (ipmi_ctx) == IPMI_ERR_PASSWORD_INVALID |
|
+ || (*nut_ipmi_ctx_errnum) (ipmi_ctx) == IPMI_ERR_PRIVILEGE_LEVEL_INSUFFICIENT |
|
+ || (*nut_ipmi_ctx_errnum) (ipmi_ctx) == IPMI_ERR_PRIVILEGE_LEVEL_CANNOT_BE_OBTAINED |
|
+ || (*nut_ipmi_ctx_errnum) (ipmi_ctx) == IPMI_ERR_AUTHENTICATION_TYPE_UNAVAILABLE |
|
+ || (*nut_ipmi_ctx_errnum) (ipmi_ctx) == IPMI_ERR_PASSWORD_VERIFICATION_TIMEOUT |
|
+ || (*nut_ipmi_ctx_errnum) (ipmi_ctx) == IPMI_ERR_HOSTNAME_INVALID |
|
+ || (*nut_ipmi_ctx_errnum) (ipmi_ctx) == IPMI_ERR_CONNECTION_TIMEOUT) { */ |
|
+ |
|
+ /* FIXME: don't log timeout errors */ |
|
+ fprintf(stderr, "nut_ipmi_ctx_open_outofband: %s\n", |
|
+ (*nut_ipmi_ctx_errormsg) (ipmi_ctx)); |
|
+ return NULL; |
|
+ /*}*/ |
|
+ } |
|
} |
|
-fprintf(stdout, "There3 (ret = %i)\n", ret); |
|
|
|
/* Loop through all possible components */ |
|
for (ipmi_id = 0 ; ipmi_id <= IPMI_FRU_DEVICE_ID_MAX ; ipmi_id++) { |
|
-fprintf(stdout, "There4\n"); |
|
+ |
|
if (is_ipmi_device_supported(ipmi_ctx, ipmi_id)) { |
|
|
|
-fprintf(stdout, "There4.%i\n", ipmi_id); |
|
if ( (nut_dev = nutscan_new_device()) == NULL ) { |
|
fprintf(stderr,"Memory allocation error\n"); |
|
nutscan_free_device(current_nut_dev); |
|
@@ -396,9 +528,17 @@ fprintf(stdout, "There4.%i\n", ipmi_id); |
|
/* Fill the device structure (sufficient with driver and port) */ |
|
nut_dev->type = TYPE_IPMI; |
|
nut_dev->driver = strdup(NUT_IPMI_DRV_NAME); |
|
- sprintf(port_id, "id%x", ipmi_id); |
|
+ if (IPaddr == NULL) { |
|
+ sprintf(port_id, "id%x", ipmi_id); |
|
+ } |
|
+ else { |
|
+ /* FIXME: also check against "localhost" and its IPv{4,6} */ |
|
+ sprintf(port_id, "id%x@%s", ipmi_id, IPaddr); |
|
+ } |
|
nut_dev->port = strdup(port_id); |
|
- |
|
+ /* FIXME: also dump device.serial? |
|
+ * using drivers/libfreeipmi_get_board_info() */ |
|
+ |
|
current_nut_dev = nutscan_add_device_to_device( |
|
current_nut_dev, |
|
nut_dev); |
|
@@ -415,9 +555,50 @@ fprintf(stdout, "There4.%i\n", ipmi_id); |
|
|
|
return current_nut_dev; |
|
} |
|
+ |
|
+/* General IPMI scan entry point: scan 1 to n devices, local or remote, |
|
+ * for IPMI support |
|
+ * Return NULL on error, or a valid nutscan_device_t otherwise */ |
|
+nutscan_device_t * nutscan_scan_ipmi(const char * start_ip, const char * stop_ip, nutscan_ipmi_t * sec) |
|
+{ |
|
+ nutscan_ip_iter_t ip; |
|
+ char * ip_str = NULL; |
|
+ nutscan_ipmi_t * tmp_sec; |
|
+ nutscan_device_t * nut_dev = NULL; |
|
+ nutscan_device_t * current_nut_dev = NULL; |
|
+ |
|
+ if( !nutscan_avail_ipmi ) { |
|
+ return NULL; |
|
+ } |
|
+ |
|
+ |
|
+ /* Are we scanning locally, or through the network? */ |
|
+ if (start_ip == NULL) |
|
+ { |
|
+ /* Local PSU scan */ |
|
+ current_nut_dev = nutscan_scan_ipmi_device(NULL, NULL); |
|
+ } |
|
+ else { |
|
+ ip_str = nutscan_ip_iter_init(&ip, start_ip, stop_ip); |
|
+ |
|
+ while(ip_str != NULL) { |
|
+ tmp_sec = malloc(sizeof(nutscan_ipmi_t)); |
|
+ memcpy(tmp_sec, sec, sizeof(nutscan_ipmi_t)); |
|
+ |
|
+ if ((current_nut_dev = nutscan_scan_ipmi_device(ip_str, tmp_sec)) != NULL) { |
|
+ /* Store the positive result */ |
|
+ current_nut_dev = nutscan_add_device_to_device(current_nut_dev, nut_dev); |
|
+ } |
|
+ /* Prepare the next iteration */ |
|
+ ip_str = nutscan_ip_iter_inc(&ip); |
|
+ }; |
|
+ } |
|
+ |
|
+ return current_nut_dev; |
|
+} |
|
#else /* WITH_IPMI */ |
|
/* stub function */ |
|
-nutscan_device_t * nutscan_scan_ipmi() |
|
+nutscan_device_t * nutscan_scan_ipmi(const char * startIP, const char * stopIP, nutscan_ipmi_t * sec) |
|
{ |
|
return NULL; |
|
} |
|
-- |
|
1.7.10.2 |
|
|
|
|
|
From 3d0002653a506f2acb24be2201724e7b785de784 Mon Sep 17 00:00:00 2001 |
|
From: Arnaud Quette <arnaud.quette@free.fr> |
|
Date: Fri, 5 Oct 2012 10:27:55 +0000 |
|
Subject: [PATCH] Fix compilation error |
|
|
|
Define IPMI_PRIVILEGE_LEVEL_ADMIN value, in case FreeIPMI is not |
|
available |
|
|
|
Fossil-ID: SVN r3741 |
|
--- |
|
tools/nut-scanner/nut-scan.h | 5 ++++- |
|
1 file changed, 4 insertions(+), 1 deletion(-) |
|
|
|
diff --git a/tools/nut-scanner/nut-scan.h b/tools/nut-scanner/nut-scan.h |
|
index 8b9f1ab..b853d96 100644 |
|
--- a/tools/nut-scanner/nut-scan.h |
|
+++ b/tools/nut-scanner/nut-scan.h |
|
@@ -64,7 +64,10 @@ typedef struct nutscan_ipmi { |
|
#define IPMI_AUTHENTICATION_TYPE_STRAIGHT_PASSWORD_KEY 0x04 |
|
#define IPMI_AUTHENTICATION_TYPE_OEM_PROP 0x05 |
|
#define IPMI_AUTHENTICATION_TYPE_RMCPPLUS 0x06 |
|
-#endif /* IPMI_AUTHENTICATION_TYPE_NONE */ |
|
+#endif |
|
+#ifndef IPMI_PRIVILEGE_LEVEL_ADMIN |
|
+ #define IPMI_PRIVILEGE_LEVEL_ADMIN 0x04 |
|
+#endif |
|
|
|
#define IPMI_1_5 1 |
|
#define IPMI_2_0 0 |
|
-- |
|
1.7.10.2 |
|
|
|
|
|
From 605ef0a46fbb8519b849683028f7e6cf35eb2fdd Mon Sep 17 00:00:00 2001 |
|
From: Arnaud Quette <arnaud.quette@free.fr> |
|
Date: Thu, 11 Apr 2013 23:15:51 +0200 |
|
Subject: [PATCH] Set USB timeout to 5 seconds |
|
|
|
Set the low level USB timeout back to the standard |
|
5 seconds. This was set to 4 seconds, for performance |
|
reasons, but is now causing issues with some devices |
|
(reported by Stefan "stevenbg", GitHub issue #23) |
|
--- |
|
drivers/libusb.c | 7 +++---- |
|
1 file changed, 3 insertions(+), 4 deletions(-) |
|
|
|
diff --git a/drivers/libusb.c b/drivers/libusb.c |
|
index 50bfc7f..234b9f1 100644 |
|
--- a/drivers/libusb.c |
|
+++ b/drivers/libusb.c |
|
@@ -33,12 +33,11 @@ |
|
#include "usb-common.h" |
|
#include "libusb.h" |
|
|
|
-/* USB standard state 5000, but we've decreased it to |
|
- * improve reactivity */ |
|
-#define USB_TIMEOUT 4000 |
|
+/* USB standard timeout */ |
|
+#define USB_TIMEOUT 5000 |
|
|
|
#define USB_DRIVER_NAME "USB communication driver" |
|
-#define USB_DRIVER_VERSION "0.31" |
|
+#define USB_DRIVER_VERSION "0.32" |
|
|
|
/* driver description structure */ |
|
upsdrv_info_t comm_upsdrv_info = { |
|
-- |
|
1.7.10.2 |
|
|
|
|