diff options
author | Brad Bishop <bradleyb@us.ibm.com> | 2012-07-12 15:35:56 -0500 |
---|---|---|
committer | A. Patrick Williams III <iawillia@us.ibm.com> | 2012-08-15 12:48:21 -0500 |
commit | d268066a67809fa018b840f53163805f583aadcd (patch) | |
tree | d30c1fb836ae07b8f5770ff9ec13f3a80c6d543f /src/usr/diag/attn/test/attnfakeelement.H | |
parent | 122f4ba48151f29cfb8be1d411509a219bd1df12 (diff) | |
download | talos-hostboot-d268066a67809fa018b840f53163805f583aadcd.tar.gz talos-hostboot-d268066a67809fa018b840f53163805f583aadcd.zip |
Attention handler fake system.
A fake hardware implementation framework for unit testing.
Change-Id: I596c26d4c10a0f707c9eab29419b36e8ed11ac6b
RTC: 41428
Reviewed-on: http://gfw160.austin.ibm.com:8080/gerrit/1356
Tested-by: Jenkins Server
Reviewed-by: LARINA M. DSOUZA <larsouza@in.ibm.com>
Reviewed-by: Sachin Gupta <sgupta2m@in.ibm.com>
Reviewed-by: A. Patrick Williams III <iawillia@us.ibm.com>
Diffstat (limited to 'src/usr/diag/attn/test/attnfakeelement.H')
-rw-r--r-- | src/usr/diag/attn/test/attnfakeelement.H | 110 |
1 files changed, 110 insertions, 0 deletions
diff --git a/src/usr/diag/attn/test/attnfakeelement.H b/src/usr/diag/attn/test/attnfakeelement.H new file mode 100644 index 000000000..1d13406fa --- /dev/null +++ b/src/usr/diag/attn/test/attnfakeelement.H @@ -0,0 +1,110 @@ +/* IBM_PROLOG_BEGIN_TAG + * This is an automatically generated prolog. + * + * $Source: src/usr/diag/attn/test/attnfakeelement.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_ATTNFAKEELEMENT_H +#define __TEST_ATTNFAKEELEMENT_H + +/** + * @file attnfakeelement.H + * + * @brief HBATTN fake system element class definitions. + */ + +#include "attntest.H" + +namespace ATTN +{ + +/** + * @brief FakeSource Attention source interface. + * + * Interface definition for classes wishing to attach logic + * to FakeSystem error injections. + */ +class FakeSource +{ + public: + + /** + * @brief dtor + */ + virtual ~FakeSource() {} + + /** + * @brief processPutAttention Process injected attention. + * + * @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. + */ + virtual errlHndl_t processPutAttention( + FakeSystem & i_sys, + const PRDF::AttnData & i_attn, + uint64_t i_count) = 0; + + /** + * @brief processClearAttention Process cleared attention. + * + * @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. + */ + virtual errlHndl_t processClearAttention( + FakeSystem & i_sys, + const PRDF::AttnData & i_attn, + uint64_t i_count) = 0; +}; + +/** + * @brief FakeReg Register interface. + * + * Interface definition for classes wishing to attach logic + * to FakeSystem register modifications. + */ +class FakeReg +{ + public: + + /** + * @brief dtor + */ + virtual ~FakeReg() {} + + /** + * @brief processPutReg Process modified register content. + * + * @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. + */ + virtual errlHndl_t processPutReg( + FakeSystem & i_sys, + TARGETING::TargetHandle_t i_target, + uint64_t i_address, + uint64_t i_new, + uint64_t i_old) = 0; +}; +} +#endif |