/* IBM_PROLOG_BEGIN_TAG */ /* This is an automatically generated prolog. */ /* */ /* $Source: src/usr/mbox/plugins/mboxUdParser.H $ */ /* */ /* OpenPOWER HostBoot Project */ /* */ /* COPYRIGHT International Business Machines Corp. 2012,2014 */ /* */ /* 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 */ #if !defined(_MBOXUDPARSER) #define _MBOXUDPARSER #include "errluserdetails.H" namespace MBOX { /** * Parses mbox message user detail in an error log */ class UserDetailsParserMboxMsg : public ERRORLOG::ErrlUserDetailsParser { public: /** * Constructor */ UserDetailsParserMboxMsg() {} /** * Destructor */ virtual ~UserDetailsParserMboxMsg() {} /** * Parses a mbox msg in an error log. * * @param[in] i_version Version of the data * @param[in] i_parse ErrlUsrParser object for the output info * @param[in] i_pBuffer Pointer to the buffer containing detail data * @param[in] 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 { uint32_t * b32 = static_cast(i_pBuffer); uint64_t * b64 = reinterpret_cast(b32 + 4); uint32_t msg_id = ntohl(*b32); uint32_t msg_q_id = ntohl(*(b32+1)); uint32_t msg_type = ntohl(*(b32+2)); uint32_t msg_flag = ntohl(*(b32+3)); uint64_t msg_dta0 = ntohll(*(b64)); uint64_t msg_dta1 = ntohll(*(b64+1)); uint64_t msg_extd = ntohll(*(b64+2)); i_parser.PrintNumber("MBOX message id","0x%08x",msg_id); i_parser.PrintNumber("MBOX queue id","0x%08x",msg_q_id); i_parser.PrintNumber("MBOX message type","0x%08x",msg_type); if(msg_flag & 0x80000000) { i_parser.PrintString(NULL, "MBOX mesage is synchronous"); } else { i_parser.PrintString(NULL, "MBOX message is asynchronous"); } i_parser.PrintNumber("MBOX data[0]","0x%016lx",msg_dta0); i_parser.PrintNumber("MBOX data[1]","0x%016lx",msg_dta1); i_parser.PrintNumber("MBOX Extra data pointer","0x%016lx",msg_extd); if(msg_extd != 0 && i_buflen > 40) { i_parser.PrintString(NULL, "MBOX extra data:"); uint8_t * b08 = reinterpret_cast(b64 + 3); size_t len = i_buflen - 40; i_parser.PrintHexDump(b08,len); } } }; } #endif