summaryrefslogtreecommitdiffstats
path: root/src/usr/diag/prdf/plat/pegasus/prdfPegasusConfigurator.H
diff options
context:
space:
mode:
authorZane Shelley <zshelle@us.ibm.com>2012-09-20 12:18:46 -0500
committerA. Patrick Williams III <iawillia@us.ibm.com>2012-11-07 16:13:29 -0600
commit63aca27a47a3b60ca107c12cad8d132a0cfeb64c (patch)
treee3e38fb25b6986223f8ba8f617f04697f4801b2d /src/usr/diag/prdf/plat/pegasus/prdfPegasusConfigurator.H
parent1190a8872faeac22924a4528c9fbeabdafe9fad6 (diff)
downloadtalos-hostboot-63aca27a47a3b60ca107c12cad8d132a0cfeb64c.tar.gz
talos-hostboot-63aca27a47a3b60ca107c12cad8d132a0cfeb64c.zip
Initial port of PRD to Hostboot
Change-Id: I7ee2673131d4891d482e99a403a36300b79e547e Reviewed-on: http://gfw160.austin.ibm.com:8080/gerrit/1853 Tested-by: Jenkins Server Reviewed-by: A. Patrick Williams III <iawillia@us.ibm.com>
Diffstat (limited to 'src/usr/diag/prdf/plat/pegasus/prdfPegasusConfigurator.H')
-rw-r--r--src/usr/diag/prdf/plat/pegasus/prdfPegasusConfigurator.H86
1 files changed, 86 insertions, 0 deletions
diff --git a/src/usr/diag/prdf/plat/pegasus/prdfPegasusConfigurator.H b/src/usr/diag/prdf/plat/pegasus/prdfPegasusConfigurator.H
new file mode 100644
index 000000000..8e638e64d
--- /dev/null
+++ b/src/usr/diag/prdf/plat/pegasus/prdfPegasusConfigurator.H
@@ -0,0 +1,86 @@
+/* IBM_PROLOG_BEGIN_TAG */
+/* This is an automatically generated prolog. */
+/* */
+/* $Source: src/usr/diag/prdf/plat/pegasus/prdfPegasusConfigurator.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 otherwise */
+/* divested of its trade secrets, irrespective of what has been */
+/* deposited with the U.S. Copyright Office. */
+/* */
+/* Origin: 30 */
+/* */
+/* IBM_PROLOG_END_TAG */
+
+#ifndef prdfPegasusConfigurator_H
+#define prdfPegasusConfigurator_H
+
+/** @file prdfPegasusConfigurator.H
+ * @brief Builds the PRD system model for Pegasus (P8 based systems).
+ */
+
+#include <iipConfigurator.h>
+#include <iipCallAttnResolution.h> // For CallAttnResolution
+#include <prdfRuleChipDomain.H>
+
+/** @brief PRD configurator for Pegasus (P8 systems) */
+class PrdfPegasusConfigurator : public Configurator
+{
+ public:
+
+ /**
+ * @brief Constructor
+ */
+ PrdfPegasusConfigurator() :
+ Configurator( PrdfRuleChipDomain::TOTAL_CHIPS,
+ PrdfRuleChipDomain::TOTAL_DOMAINS )
+ {}
+
+ /**
+ * @brief Destructor
+ * @note This configurator does not delete the objects it created during
+ * build(); that is the responsibility of the system object.
+ */
+ ~PrdfPegasusConfigurator() {}
+
+ /**
+ * @brief Create the PRD system object, all chip instances, and all domain
+ * instances.
+ * @return Pointer to configured system.
+ * @note The caller of this function owns the responsiblity of deleting
+ * the system object created.
+ */
+ virtual System * build();
+
+ private: // functions
+
+ /** @brief Copy not allowed. */
+ PrdfPegasusConfigurator( const PrdfPegasusConfigurator & right );
+
+ /** @brief Assignment not allowed. */
+ const PrdfPegasusConfigurator & operator=( const PrdfPegasusConfigurator & right );
+
+ /**
+ * @brief Will add all chips of a given type to a domain.
+ * @parm i_type The specified target type.
+ * @parm io_domain The associated domain.
+ */
+ void addDomainChips( TARGETING::TYPE i_type,
+ PrdfRuleChipDomain * io_domain );
+
+ private: // data
+
+ static CallAttnResolution noAttnResolution;
+
+};
+
+#endif
OpenPOWER on IntegriCloud