summaryrefslogtreecommitdiffstats
path: root/src/usr/hwpf/hwp/occ
diff options
context:
space:
mode:
authorDan Crowell <dcrowell@us.ibm.com>2015-02-10 19:59:36 -0600
committerA. Patrick Williams III <iawillia@us.ibm.com>2015-02-18 14:20:36 -0600
commit84023756531d9c48d2e4939326f4048f2dadbe28 (patch)
treef8f86a2f2bcf75453555929eb3fb33e48b2b0620 /src/usr/hwpf/hwp/occ
parent7c5d303237f2bec25b7072ec3119d6d4fef875fc (diff)
downloadtalos-hostboot-84023756531d9c48d2e4939326f4048f2dadbe28.tar.gz
talos-hostboot-84023756531d9c48d2e4939326f4048f2dadbe28.zip
Set FIR master in HOMER config data
Change-Id: I14efac59ce36e838f9438facd729b296ac9c552f RTC: 108820 Reviewed-on: http://gfw160.aus.stglabs.ibm.com:8080/gerrit/15657 Tested-by: Jenkins Server Reviewed-by: Joshua P. Rispoli <jprispol@us.ibm.com> Reviewed-by: Corey V. Swenson <cswenson@us.ibm.com> Reviewed-by: A. Patrick Williams III <iawillia@us.ibm.com>
Diffstat (limited to 'src/usr/hwpf/hwp/occ')
-rw-r--r--src/usr/hwpf/hwp/occ/occ.C2
-rw-r--r--src/usr/hwpf/hwp/occ/occ_common.C46
-rw-r--r--src/usr/hwpf/hwp/occ/runtime/rt_occ.C2
3 files changed, 20 insertions, 30 deletions
diff --git a/src/usr/hwpf/hwp/occ/occ.C b/src/usr/hwpf/hwp/occ/occ.C
index f56c90925..ac2f4b126 100644
--- a/src/usr/hwpf/hwp/occ/occ.C
+++ b/src/usr/hwpf/hwp/occ/occ.C
@@ -133,7 +133,7 @@ namespace HBOCC
(i_homerVirtAddrBase) +
tmpOffset + HOMER_OFFSET_TO_OCC_HOST_DATA;
void* occHostVirt = reinterpret_cast<void*>(i_homerHostVirtAddr);
- l_errl = HBOCC::loadHostDataToHomer(occHostVirt);
+ l_errl = HBOCC::loadHostDataToHomer(i_target,occHostVirt);
if( l_errl != NULL )
{
TRACFCOMP( g_fapiImpTd, ERR_MRK"loading Host Data Area failed!" );
diff --git a/src/usr/hwpf/hwp/occ/occ_common.C b/src/usr/hwpf/hwp/occ/occ_common.C
index 97d36f48f..e444b26d4 100644
--- a/src/usr/hwpf/hwp/occ/occ_common.C
+++ b/src/usr/hwpf/hwp/occ/occ_common.C
@@ -119,14 +119,9 @@ namespace HBOCC
/**
* @brief Sets up OCC Host data
- *
- * @param[in] i_occHostDataVirtAddr Virtual
- * address of current
- * proc's Host data area.
- *
- * @return errlHndl_t Error log Host data setup failed
*/
- errlHndl_t loadHostDataToHomer(void* i_occHostDataVirtAddr)
+ errlHndl_t loadHostDataToHomer( TARGETING::Target* i_proc,
+ void* i_occHostDataVirtAddr)
{
TRACUCOMP( g_fapiTd,
ENTER_MRK"loadHostDataToHomer(%p)",
@@ -161,6 +156,22 @@ namespace HBOCC
config_data->interruptType = USE_PSIHB_COMPLEX;
}
+#ifdef CONFIG_ENABLE_CHECKSTOP_ANALYSIS
+ // Figure out the FIR master
+ TARGETING::Target* masterproc = NULL;
+ tS.masterProcChipTargetHandle( masterproc );
+ if( masterproc == i_proc )
+ {
+ config_data->firMaster = IS_FIR_MASTER;
+ }
+ else
+ {
+ config_data->firMaster = NOT_FIR_MASTER;
+ }
+#else
+ config_data->firMaster = 0;
+#endif
+
TRACUCOMP( g_fapiTd,
EXIT_MRK"loadHostDataToHomer");
@@ -170,16 +181,6 @@ namespace HBOCC
/**
* @brief Execute procedures and steps necessary
* to load OCC data in specified processor
- *
- * @param[in] i_target Target proc to load
- * @param[in] i_homerVirtAddrBase Virtual
- * address of current
- * proc's HOMER
- * @param[in] i_homerPhysAddrBase Physical
- * address of current
- * proc's HOMER
- *
- * @return errlHndl_t Error log image load failed
*/
errlHndl_t loadOCC(TARGETING::Target* i_target,
uint64_t i_homerPhysAddr,
@@ -299,12 +300,6 @@ namespace HBOCC
* @brief Start OCC for specified DCM pair of processors.
* If 2nd input is NULL, OCC will be setup on just
* one target.
- *
- * @param[in] i_target0: target of first processor in DCM pair
- * @param[in] i_target1: target of second processor in DCM pair
- * @param[out] o_failedTarget failed target in case of an error
- *
- * @return errlHndl_t Error log of startOCC failed
*/
errlHndl_t startOCC (Target* i_target0,
Target* i_target1,
@@ -423,11 +418,6 @@ namespace HBOCC
* @brief Stop OCC for specified DCM pair of processors.
* If 2nd input is NULL, OCC will be setup on just
* one target.
- *
- * @param[in] i_target0: target of first processor in DCM pair
- * @param[in] i_target1: target of second processor in DCM pair
- *
- * @return errlHndl_t Error log of stopOCC failed
*/
errlHndl_t stopOCC(TARGETING::Target * i_target0,
TARGETING::Target * i_target1)
diff --git a/src/usr/hwpf/hwp/occ/runtime/rt_occ.C b/src/usr/hwpf/hwp/occ/runtime/rt_occ.C
index 29509a1b9..87d30b71b 100644
--- a/src/usr/hwpf/hwp/occ/runtime/rt_occ.C
+++ b/src/usr/hwpf/hwp/occ/runtime/rt_occ.C
@@ -179,7 +179,7 @@ namespace RT_OCC
void* occHostVirt = reinterpret_cast <void *> (i_homer_addr_va +
HOMER_OFFSET_TO_OCC_HOST_DATA);
- err = HBOCC::loadHostDataToHomer(occHostVirt);
+ err = HBOCC::loadHostDataToHomer(proc_target,occHostVirt);
if( err != NULL )
{
TRACFCOMP( g_fapiImpTd, ERR_MRK"loading Host Data Area failed!" );
OpenPOWER on IntegriCloud