diff options
| author | Yue Du <daviddu@us.ibm.com> | 2017-01-10 16:05:25 -0600 |
|---|---|---|
| committer | hostboot <hostboot@us.ibm.com> | 2018-08-22 17:54:20 -0500 |
| commit | c47b00594dd0ed5403684628112696d900136246 (patch) | |
| tree | c79640bd6d56411b5170ff13a3a19bbefa44e1b0 /import | |
| parent | ee432a5c78b9789a9788d51a3f2977fb347d1449 (diff) | |
| download | talos-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.c | 30 |
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]"); |

