diff options
author | Matt Derksen <mderkse1@us.ibm.com> | 2017-07-18 16:14:51 -0500 |
---|---|---|
committer | William G. Hoffa <wghoffa@us.ibm.com> | 2017-07-28 16:27:18 -0400 |
commit | e7955db9ace86b83313545014a805c9678034839 (patch) | |
tree | 2f453735fa33ab699e2afa28e10765ba0f40ea05 /src/usr/errl/plugins | |
parent | f85d893d45c80ceec577cdd22e74bf89302af4e1 (diff) | |
download | talos-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.H | 2 | ||||
-rw-r--r-- | src/usr/errl/plugins/errludparserfactoryerrl.H | 6 | ||||
-rw-r--r-- | src/usr/errl/plugins/errludsensor.H | 125 |
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 |