summaryrefslogtreecommitdiffstats
path: root/import
diff options
context:
space:
mode:
authorYue Du <daviddu@us.ibm.com>2017-01-10 16:05:25 -0600
committerhostboot <hostboot@us.ibm.com>2018-08-22 17:54:20 -0500
commitc47b00594dd0ed5403684628112696d900136246 (patch)
treec79640bd6d56411b5170ff13a3a19bbefa44e1b0 /import
parentee432a5c78b9789a9788d51a3f2977fb347d1449 (diff)
downloadtalos-hcode-c47b00594dd0ed5403684628112696d900136246.tar.gz
talos-hcode-c47b00594dd0ed5403684628112696d900136246.zip
STOP: Stop cme trace array and halt CME before stop cache clocks
Change-Id: Ic7b1db1de327c65e30929a5c357121a0faa1433c Original-Change-Id: I52b0e46799d8333f87b2954d5df66034c7002268 Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/34675 Tested-by: Jenkins Server <pfd-jenkins+hostboot@us.ibm.com> Reviewed-by: ASHISH A. MORE <ashish.more@in.ibm.com> Reviewed-by: AMIT KUMAR <akumar3@us.ibm.com> Reviewed-by: Gregory S. Still <stillgs@us.ibm.com>
Diffstat (limited to 'import')
-rw-r--r--import/chips/p9/procedures/ppe_closed/sgpe/stop_gpe/p9_sgpe_stop_entry.c30
1 files changed, 27 insertions, 3 deletions
diff --git a/import/chips/p9/procedures/ppe_closed/sgpe/stop_gpe/p9_sgpe_stop_entry.c b/import/chips/p9/procedures/ppe_closed/sgpe/stop_gpe/p9_sgpe_stop_entry.c
index 8d3f9288..1b39f055 100644
--- a/import/chips/p9/procedures/ppe_closed/sgpe/stop_gpe/p9_sgpe_stop_entry.c
+++ b/import/chips/p9/procedures/ppe_closed/sgpe/stop_gpe/p9_sgpe_stop_entry.c
@@ -25,6 +25,7 @@
#include "p9_sgpe_stop.h"
#include "p9_sgpe_stop_enter_marks.h"
+#include "p9_hcode_image_defines.H"
extern SgpeStopRecord G_sgpe_stop_record;
@@ -576,7 +577,13 @@ p9_sgpe_stop_entry()
GPE_PUTSCOM(GPE_SCOM_ADDR_EX(EX_PM_PURGE_REG, qloop, 1), BIT64(0));
}
- // todo: stop debug trace, attribute may be needed
+ // disable cme trace array
+ sgpeHeader_t* pSgpeImgHdr = (sgpeHeader_t*)(SGPE_IMAGE_SRAM_BASE + SGPE_HEADER_IMAGE_OFFSET);
+
+ if (pSgpeImgHdr->g_sgpe_reserve_flags & BIT32(4))
+ {
+ GPE_PUTSCOM(GPE_SCOM_ADDR_QUAD(DEBUG_TRACE_CONTROL, qloop), BIT64(1));
+ }
PK_TRACE("Poll for L3 purge done via EX_PM_PURGE_REG[0]");
@@ -717,7 +724,6 @@ p9_sgpe_stop_entry()
while(!(scom_data & BIT64(31)));
PK_TRACE("Drop powerbus purge via QCCR[30]");
- // todo may need to move this to wakeup
GPE_PUTSCOM(GPE_SCOM_ADDR_QUAD(EQ_QPPM_QCCR_WCLEAR, qloop), BIT64(30));
PK_TRACE_INF("SE11.B: PowerBus Purged");
@@ -733,7 +739,25 @@ p9_sgpe_stop_entry()
MARK_TAG(SE_QUIESCE_QUAD, (32 >> qloop))
//======================================
- /// @todo halt cme here
+ PK_TRACE("Halting CMEs");
+ GPE_PUTSCOM(GPE_SCOM_ADDR_CME(CME_SCOM_XIXCR, qloop, 0), BIT64(3));
+ GPE_PUTSCOM(GPE_SCOM_ADDR_CME(CME_SCOM_XIXCR, qloop, 1), BIT64(3));
+
+ do
+ {
+ GPE_GETSCOM(GPE_SCOM_ADDR_CME(CME_SCOM_XIRAMDBG, qloop, 0), scom_data);
+ }
+ while(!(scom_data & BIT64(0)));
+
+ PK_TRACE("CME0 Halted");
+
+ do
+ {
+ GPE_GETSCOM(GPE_SCOM_ADDR_CME(CME_SCOM_XIRAMDBG, qloop, 1), scom_data);
+ }
+ while(!(scom_data & BIT64(0)));
+
+ PK_TRACE("CME1 Halted");
PK_TRACE("Assert refresh quiesce prior to L3 (refresh domain) stop clk via EX_DRAM_REF_REG[7]");
OpenPOWER on IntegriCloud