summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDoug Gilbert <dgilbert@us.ibm.com>2014-06-23 19:35:02 -0500
committerA. Patrick Williams III <iawillia@us.ibm.com>2014-06-24 13:53:12 -0500
commit82343f7897f79abc0e9780b7b1a3388728d6562d (patch)
tree5b388d08b13dbaa58fdc7cf82c328bbde52f9d19 /src
parentaaadc0e5955551542ddc5fc84cc54dd32f8d9788 (diff)
downloadblackbird-hostboot-82343f7897f79abc0e9780b7b1a3388728d6562d.tar.gz
blackbird-hostboot-82343f7897f79abc0e9780b7b1a3388728d6562d.zip
Set payload base address correctly on slave nodes
Change-Id: I6cc9f135a5f79b524db673f0f4563466b1d52202 CQ: SW266592 Reviewed-on: http://gfw160.aus.stglabs.ibm.com:8080/gerrit/11764 Tested-by: Jenkins Server Reviewed-by: Daniel M. Crowell <dcrowell@us.ibm.com> Reviewed-by: A. Patrick Williams III <iawillia@us.ibm.com>
Diffstat (limited to 'src')
-rw-r--r--src/include/usr/runtime/runtime.H6
-rw-r--r--src/usr/mbox/ipcSp.C3
-rw-r--r--src/usr/runtime/populate_attributes.C9
3 files changed, 18 insertions, 0 deletions
diff --git a/src/include/usr/runtime/runtime.H b/src/include/usr/runtime/runtime.H
index 237c8bc02..433f82169 100644
--- a/src/include/usr/runtime/runtime.H
+++ b/src/include/usr/runtime/runtime.H
@@ -129,6 +129,12 @@ errlHndl_t writeActualCount( RUNTIME::SectionId i_id );
void add_host_data_ffdc( SectionId i_section,
errlHndl_t& io_errlog );
+/*
+ * @brief Set the PAYLOAD_BASE attribute
+ * @param[in] i_payloadAddress in MEGABYTES
+ */
+void setPayloadBaseAddress(uint64_t i_payloadAddress);
+
}
#endif
diff --git a/src/usr/mbox/ipcSp.C b/src/usr/mbox/ipcSp.C
index 920e82e77..26fad96a8 100644
--- a/src/usr/mbox/ipcSp.C
+++ b/src/usr/mbox/ipcSp.C
@@ -109,6 +109,9 @@ void IpcSp::msgHandler()
}
if(!err)
{
+ RUNTIME::setPayloadBaseAddress
+ (reinterpret_cast<uint64_t>(msg->extra_data));
+
err = RUNTIME::populate_node_attributes( msg->data[0] );
}
diff --git a/src/usr/runtime/populate_attributes.C b/src/usr/runtime/populate_attributes.C
index b1aa2c635..e6e9ff03b 100644
--- a/src/usr/runtime/populate_attributes.C
+++ b/src/usr/runtime/populate_attributes.C
@@ -760,6 +760,7 @@ errlHndl_t populate_attributes( void )
uint64_t this_node = INTR::PIR_t(task_getcpuid()).nodeId;
task_affinity_unpin();
+ uint64_t payloadBase = sys->getAttr<TARGETING::ATTR_PAYLOAD_BASE>();
//loop though all possible drawers whether they exist or not
// An invalid or non-existant logical node number in that drawer
@@ -785,6 +786,7 @@ errlHndl_t populate_attributes( void )
msg->type = IPC::IPC_POPULATE_ATTRIBUTES;
msg->data[0] = drawer; // offset in attribute table
msg->data[1] = this_node; // node to send a msg back to
+ msg->extra_data = reinterpret_cast<uint64_t*>(payloadBase);
errhdl = MBOX::send(MBOX::HB_IPC_MSGQ, msg, node);
if (errhdl)
{
@@ -817,4 +819,11 @@ errlHndl_t populate_attributes( void )
return errhdl;
}
+void setPayloadBaseAddress(uint64_t i_payloadAddress)
+{
+ TARGETING::Target * sys = NULL;
+ TARGETING::targetService().getTopLevelTarget( sys );
+ sys->setAttr<TARGETING::ATTR_PAYLOAD_BASE>(i_payloadAddress);
+}
+
} //namespace RUNTIME
OpenPOWER on IntegriCloud