summaryrefslogtreecommitdiffstats
path: root/src/usr/errl/plugins
diff options
context:
space:
mode:
authorMatt Derksen <mderkse1@us.ibm.com>2017-07-18 16:14:51 -0500
committerWilliam G. Hoffa <wghoffa@us.ibm.com>2017-07-28 16:27:18 -0400
commite7955db9ace86b83313545014a805c9678034839 (patch)
tree2f453735fa33ab699e2afa28e10765ba0f40ea05 /src/usr/errl/plugins
parentf85d893d45c80ceec577cdd22e74bf89302af4e1 (diff)
downloadtalos-hostboot-e7955db9ace86b83313545014a805c9678034839.tar.gz
talos-hostboot-e7955db9ace86b83313545014a805c9678034839.zip
Add fault sensor information into IPMI error logs
Fault sensor number, FRU ID, and priority added to hardware callouts. Change-Id: I8e4d815a4a3b26db29f852d6160dcf4b12452660 RTC:134069 Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/43604 Reviewed-by: Martin Gloff <mgloff@us.ibm.com> Tested-by: Jenkins Server <pfd-jenkins+hostboot@us.ibm.com> Tested-by: Jenkins OP Build CI <op-jenkins+hostboot@us.ibm.com> Tested-by: Jenkins OP HW <op-hw-jenkins+hostboot@us.ibm.com> Tested-by: FSP CI Jenkins <fsp-CI-jenkins+hostboot@us.ibm.com> Reviewed-by: Christian R. Geddes <crgeddes@us.ibm.com> Reviewed-by: Matt Derksen <mderkse1@us.ibm.com> Reviewed-by: William G. Hoffa <wghoffa@us.ibm.com>
Diffstat (limited to 'src/usr/errl/plugins')
-rw-r--r--src/usr/errl/plugins/errludcallout.H2
-rw-r--r--src/usr/errl/plugins/errludparserfactoryerrl.H6
-rw-r--r--src/usr/errl/plugins/errludsensor.H125
3 files changed, 132 insertions, 1 deletions
diff --git a/src/usr/errl/plugins/errludcallout.H b/src/usr/errl/plugins/errludcallout.H
index f13570ab3..95e147083 100644
--- a/src/usr/errl/plugins/errludcallout.H
+++ b/src/usr/errl/plugins/errludcallout.H
@@ -322,6 +322,8 @@ case HWAS::_type: i_parser.PrintString( "Priority", #_type); break;
#undef case_PRIORITY
} // parse
+ friend class ErrlUserDetailsParserSensor;
+
private:
// Disabled
ErrlUserDetailsParserCallout(const ErrlUserDetailsParserCallout &);
diff --git a/src/usr/errl/plugins/errludparserfactoryerrl.H b/src/usr/errl/plugins/errludparserfactoryerrl.H
index 608be0577..1db49a8dc 100644
--- a/src/usr/errl/plugins/errludparserfactoryerrl.H
+++ b/src/usr/errl/plugins/errludparserfactoryerrl.H
@@ -5,7 +5,9 @@
/* */
/* OpenPOWER HostBoot Project */
/* */
-/* COPYRIGHT International Business Machines Corp. 2012,2014 */
+/* Contributors Listed Below - COPYRIGHT 2012,2017 */
+/* [+] International Business Machines Corp. */
+/* */
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); */
/* you may not use this file except in compliance with the License. */
@@ -35,6 +37,7 @@
#include "errludattribute.H"
#include "errludlogregister.H"
#include "errludcallout.H"
+#include "errludsensor.H"
namespace ERRORLOG
{
@@ -60,6 +63,7 @@ public:
registerParser<ErrlUserDetailsParserAttribute>(ERRL_UDT_ATTRIBUTE);
registerParser<ErrlUserDetailsParserLogRegister>(ERRL_UDT_LOGREGISTER);
registerParser<ErrlUserDetailsParserCallout>(ERRL_UDT_CALLOUT);
+ registerParser<ErrlUserDetailsParserSensor>(ERRL_UDT_SENSOR);
}
private:
diff --git a/src/usr/errl/plugins/errludsensor.H b/src/usr/errl/plugins/errludsensor.H
new file mode 100644
index 000000000..cdca6631e
--- /dev/null
+++ b/src/usr/errl/plugins/errludsensor.H
@@ -0,0 +1,125 @@
+/* IBM_PROLOG_BEGIN_TAG */
+/* This is an automatically generated prolog. */
+/* */
+/* $Source: src/usr/errl/plugins/errludsensor.H $ */
+/* */
+/* OpenPOWER HostBoot Project */
+/* */
+/* Contributors Listed Below - COPYRIGHT 2017 */
+/* [+] International Business Machines Corp. */
+/* */
+/* */
+/* Licensed under the Apache License, Version 2.0 (the "License"); */
+/* you may not use this file except in compliance with the License. */
+/* You may obtain a copy of the License at */
+/* */
+/* http://www.apache.org/licenses/LICENSE-2.0 */
+/* */
+/* Unless required by applicable law or agreed to in writing, software */
+/* distributed under the License is distributed on an "AS IS" BASIS, */
+/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or */
+/* implied. See the License for the specific language governing */
+/* permissions and limitations under the License. */
+/* */
+/* IBM_PROLOG_END_TAG */
+#ifndef ERRL_UDSENSOR_H
+#define ERRL_UDSENSOR_H
+
+/**
+ * @file errludsensor.H
+ *
+ * Defines the ErrlUserDetailsParserSensor class that parses faulty
+ * sensor user detail in an error log
+ */
+
+#include "errluserdetails.H"
+#include <targeting/common/target.H>
+
+namespace ERRORLOG
+{
+
+/**
+ * @class ErrlUserDetailsParserSensor
+ *
+ * Parses Faulty sensor type and number user detail in an error log
+ */
+class ErrlUserDetailsParserSensor :public ErrlUserDetailsParser
+{
+public:
+ /**
+ * @brief Constructor
+ */
+ ErrlUserDetailsParserSensor() {}
+
+ /**
+ * @brief Destructor
+ */
+ virtual ~ErrlUserDetailsParserSensor() {}
+
+ /**
+ * @brief Parses sensor user detail data from an error log
+ *
+ * @param i_version Version of the data
+ * @param i_parse ErrlUsrParser object for outputting information
+ * @param i_pBuffer Pointer to buffer containing sesnor detail data
+ * @param i_buflen Length of the buffer
+ */
+ virtual void parse(errlver_t i_version,
+ ErrlUsrParser & i_parser,
+ void * i_pBuffer,
+ const uint32_t i_buflen) const
+ {
+ typedef struct {
+ TARGETING::ATTR_FRU_ID_type fru;
+ uint8_t pad[3];
+ uint8_t sensorNum;
+ HWAS::callOutPriority priority;
+ } sensorDetails_t;
+
+ if(i_buflen == sizeof(sensorDetails_t))
+ {
+ sensorDetails_t* outputData =
+ static_cast<sensorDetails_t*>(i_pBuffer);
+ i_parser.PrintNumber("Faulty FRU ID", "0x%02X",
+ ntohl(outputData->fru));
+ i_parser.PrintNumber("Faulty Sensor Number", "0x%02X",
+ outputData->sensorNum);
+
+ switch (ntohl(outputData->priority))
+ {
+#define case_PRIORITY(_type) \
+case HWAS::_type: i_parser.PrintString( "Priority", #_type); break;
+ case_PRIORITY(SRCI_PRIORITY_NONE)
+ case_PRIORITY(SRCI_PRIORITY_LOW)
+ case_PRIORITY(SRCI_PRIORITY_MEDC)
+ case_PRIORITY(SRCI_PRIORITY_MEDB)
+ case_PRIORITY(SRCI_PRIORITY_MEDA)
+ case_PRIORITY(SRCI_PRIORITY_MED)
+ case_PRIORITY(SRCI_PRIORITY_HIGH)
+ default:
+ i_parser.PrintNumber( "Priority", "UNKNOWN: 0x%X",
+ ntohl(outputData->priority) );
+ break;
+ } // switch priority
+#undef case_PRIORITY
+
+ }
+ else
+ {
+ i_parser.PrintNumber("Sensor Buffer length", "0x%X", i_buflen);
+ i_parser.PrintNumber("Expected length", "0x%X",
+ sizeof(sensorDetails_t));
+ i_parser.PrintHexDump(i_pBuffer, i_buflen);
+ }
+ }
+
+private:
+ // Disabled
+ ErrlUserDetailsParserSensor(const ErrlUserDetailsParserSensor &);
+ ErrlUserDetailsParserSensor & operator=(
+ const ErrlUserDetailsParserSensor &);
+};
+
+}
+
+#endif
OpenPOWER on IntegriCloud