diff options
author | Brad Bishop <bradleyb@us.ibm.com> | 2012-07-11 20:19:58 -0500 |
---|---|---|
committer | A. Patrick Williams III <iawillia@us.ibm.com> | 2012-08-29 12:33:34 -0500 |
commit | ebf064b38b4f494f21913ed77808317909840464 (patch) | |
tree | 3a98c2f3de58c4fb77a925f48f7ed68dff411082 /src/usr/diag/attn/test/attnfakegfir.H | |
parent | 988dacf944579556cca7f8aafbb4b7fda8b17176 (diff) | |
download | talos-hostboot-ebf064b38b4f494f21913ed77808317909840464.tar.gz talos-hostboot-ebf064b38b4f494f21913ed77808317909840464.zip |
Attention handler fake processor implementation.
Fake GFIR and IPOLL register behavior for unit testing.
RTC: 41445
Change-Id: Ic9e9cc018207904d4f25710bad9aa3b936f67985
Reviewed-on: http://gfw160.austin.ibm.com:8080/gerrit/1360
Tested-by: Jenkins Server
Reviewed-by: Zane Shelley <zshelle@us.ibm.com>
Reviewed-by: LARINA M. DSOUZA <larsouza@in.ibm.com>
Reviewed-by: A. Patrick Williams III <iawillia@us.ibm.com>
Diffstat (limited to 'src/usr/diag/attn/test/attnfakegfir.H')
-rw-r--r-- | src/usr/diag/attn/test/attnfakegfir.H | 145 |
1 files changed, 145 insertions, 0 deletions
diff --git a/src/usr/diag/attn/test/attnfakegfir.H b/src/usr/diag/attn/test/attnfakegfir.H new file mode 100644 index 000000000..638cdd46f --- /dev/null +++ b/src/usr/diag/attn/test/attnfakegfir.H @@ -0,0 +1,145 @@ +/* IBM_PROLOG_BEGIN_TAG + * This is an automatically generated prolog. + * + * $Source: src/usr/diag/attn/test/attnfakegfir.H $ + * + * IBM CONFIDENTIAL + * + * COPYRIGHT International Business Machines Corp. 2012 + * + * p1 + * + * Object Code Only (OCO) source materials + * Licensed Internal Code Source Materials + * IBM HostBoot Licensed Internal Code + * + * The source code for this program is not published or other- + * wise divested of its trade secrets, irrespective of what has + * been deposited with the U.S. Copyright Office. + * + * Origin: 30 + * + * IBM_PROLOG_END_TAG + */ +#ifndef __TEST_ATTNFAKEGFIR_H +#define __TEST_ATTNFAKEGFIR_H + +/** + * @file attnfakegfir.H + * + * @brief HBATTN fake global FIR class definitions. + */ + +#include "attnfakeelement.H" + +namespace ATTN +{ + +/** + * @brief FakeGfir Fake global FIR class definition. + * + * Attach logic to GFIR register modifications and + * Proc local fir attentions. + */ +class FakeGfir : public FakeReg, public FakeSource +{ + public: + + /** + * @brief ctor + * + * @param[in] i_type The type of the GFIR to be monitored. + */ + explicit FakeGfir(PRDF::ATTENTION_VALUE_TYPE i_type); + + /** + * @brief dtor + */ + ~FakeGfir() {} + + /** + * @brief install + * + * Register this object with the provided system for + * the appropriate callbacks. + * + * @param[in] i_system The system in which to register callbacks. + */ + void install(FakeSystem & i_system); + + /** + * @brief processPutReg Process modified register content. + * + * Fake implemenation of GFIR. Turns GFIR on when + * local attentions are present. + * + * @param[in] i_sys System that modified register content. + * @param[in] i_target Target whose registers were modified. + * @param[in] i_address Address of register that was modified. + * @param[in] i_new Register content after modification. + * @param[in] i_old Register content before modification. + * + * @retval[0] No error occurred. + * @retval[!0] Unexpected error occurred. + */ + errlHndl_t processPutReg( + FakeSystem & i_sys, + TARGETING::TargetHandle_t i_target, + uint64_t i_address, + uint64_t i_new, + uint64_t i_old); + + /** + * @brief processPutAttention Process injected attention. + * + * Fake implemenation of local Firs. Turns GFIR on. + * + * @param[in] i_sys System on which attention was injected. + * @param[in] i_attn Attention that was injected. + * @param[in] i_count number of attentions currently present. + * + * @retval[0] No error occurred. + * @retval[!0] Unexpected error occurred. + */ + errlHndl_t processPutAttention( + FakeSystem & i_sys, + const PRDF::AttnData & i_attn, + uint64_t i_count); + + /** + * @brief processClearAttention Process cleared attention. + * + * Fake implemenation of local Firs. Clears GFIR + * when appropriate. + * + * @param[in] i_sys System on which attention was cleared. + * @param[in] i_attn Attention that was cleared. + * @param[in] i_count number of attentions currently present. + * + * @retval[0] No error occurred. + * @retval[!0] Unexpected error occurred. + */ + errlHndl_t processClearAttention( + FakeSystem & i_sys, + const PRDF::AttnData & i_attn, + uint64_t i_count); + + private: + + /** + * @brief iv_type The GFIR instance associated with this element. + */ + PRDF::ATTENTION_VALUE_TYPE iv_type; + + /** + * @brief iv_address GFIR address for type. + */ + uint64_t iv_address; + + /** + * @brief iv_writebits GFIR checkbits for type. + */ + uint64_t iv_writebits; +}; +} +#endif |