summaryrefslogtreecommitdiffstats
path: root/src/usr/diag/attn/test/attnfakegfir.H
diff options
context:
space:
mode:
authorBrad Bishop <bradleyb@us.ibm.com>2012-07-11 20:19:58 -0500
committerA. Patrick Williams III <iawillia@us.ibm.com>2012-08-29 12:33:34 -0500
commitebf064b38b4f494f21913ed77808317909840464 (patch)
tree3a98c2f3de58c4fb77a925f48f7ed68dff411082 /src/usr/diag/attn/test/attnfakegfir.H
parent988dacf944579556cca7f8aafbb4b7fda8b17176 (diff)
downloadtalos-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.H145
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
OpenPOWER on IntegriCloud