diff options
author | spashabk-in <shakeebbk@in.ibm.com> | 2018-01-24 02:40:02 -0600 |
---|---|---|
committer | Sachin Gupta <sgupta2m@in.ibm.com> | 2018-02-02 22:59:58 -0500 |
commit | 7be7840a672ab35234738a6287c95d312a5b3bc9 (patch) | |
tree | aa28205fd8cc6e4f56b7973b25cb445b2cfe8580 /src/sbefw/core/sbeSpMsg.C | |
parent | 035b8ccbe617bd2fa82498c185ea83eb62f02404 (diff) | |
download | talos-sbe-7be7840a672ab35234738a6287c95d312a5b3bc9.tar.gz talos-sbe-7be7840a672ab35234738a6287c95d312a5b3bc9.zip |
Store SBE failed rc for async FFDC
Store the SBE rc for failed command in globals
Change-Id: I673ee6929fc1941233d5235d18412a747e596508
Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/52511
Tested-by: Jenkins Server <pfd-jenkins+hostboot@us.ibm.com>
Tested-by: FSP CI Jenkins <fsp-CI-jenkins+hostboot@us.ibm.com>
Reviewed-by: RAJA DAS <rajadas2@in.ibm.com>
Reviewed-by: Sachin Gupta <sgupta2m@in.ibm.com>
Diffstat (limited to 'src/sbefw/core/sbeSpMsg.C')
-rw-r--r-- | src/sbefw/core/sbeSpMsg.C | 43 |
1 files changed, 37 insertions, 6 deletions
diff --git a/src/sbefw/core/sbeSpMsg.C b/src/sbefw/core/sbeSpMsg.C index b6afb700..294a9675 100644 --- a/src/sbefw/core/sbeSpMsg.C +++ b/src/sbefw/core/sbeSpMsg.C @@ -5,7 +5,8 @@ /* */ /* OpenPOWER sbe Project */ /* */ -/* Contributors Listed Below - COPYRIGHT 2017 */ +/* Contributors Listed Below - COPYRIGHT 2017,2018 */ +/* [+] International Business Machines Corp. */ /* */ /* */ /* Licensed under the Apache License, Version 2.0 (the "License"); */ @@ -28,9 +29,39 @@ void sbeRespGenHdr_t::init(void) { - magicCode = 0xC0DE; - cmdClass = SBE_GLOBAL->sbeFifoCmdHdr.cmdClass; - command = SBE_GLOBAL->sbeFifoCmdHdr.command; - primaryStatus = SBE_PRI_OPERATION_SUCCESSFUL; - secondaryStatus = SBE_SEC_OPERATION_SUCCESSFUL; + _magicCode = 0xC0DE; + _cmdClass = SBE_GLOBAL->sbeFifoCmdHdr.cmdClass; + _command = SBE_GLOBAL->sbeFifoCmdHdr.command; + _primaryStatus = SBE_PRI_OPERATION_SUCCESSFUL; + _secondaryStatus = SBE_SEC_OPERATION_SUCCESSFUL; +} + +void sbeCmdRespHdr_t::setStatus(const uint16_t i_prim, + const uint16_t i_sec) +{ + prim_status = i_prim; + sec_status = i_sec; + if(i_prim != SBE_PRI_OPERATION_SUCCESSFUL) + { + SBE_GLOBAL->failedPrimStatus = i_prim; + SBE_GLOBAL->failedSecStatus = i_sec; + SBE_GLOBAL->failedSeqId = 0; + SBE_GLOBAL->failedCmdClass = SBE_GLOBAL->sbeFifoCmdHdr.cmdClass; + SBE_GLOBAL->failedCmd = SBE_GLOBAL->sbeFifoCmdHdr.command; + } +} + +void sbeRespGenHdr_t::setStatus( const uint16_t i_prim, const uint16_t i_sec) +{ + _primaryStatus = i_prim; + _secondaryStatus = i_sec; + + if(i_prim != SBE_PRI_OPERATION_SUCCESSFUL) + { + SBE_GLOBAL->failedPrimStatus = _primaryStatus; + SBE_GLOBAL->failedSecStatus = _secondaryStatus; + SBE_GLOBAL->failedSeqId = 0; + SBE_GLOBAL->failedCmdClass = _cmdClass; + SBE_GLOBAL->failedCmd = _command; + } } |