From 77481e36c633f2f0e6567fcd5e5a2269eb87efec Mon Sep 17 00:00:00 2001 From: crgeddes Date: Mon, 17 Jul 2017 11:27:06 -0500 Subject: Add pm_check_quiesce function to list of sbe_check_quiesce function In addition to powman suspend we need to make sure that special wakeups are in a safe state when we do an MPIPL. We are adding in that cleanup to sbe_check_quiesce. In this commit I also added in some other pm cleanup that will be done later by p9_powman_suspend. Change-Id: I8a24bec460c5a8185365ff8e749f92f938555de7 Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/43213 Tested-by: Jenkins Server Tested-by: PPE CI Reviewed-by: Brian T. Vanderpool Reviewed-by: Michael S. Floyd Reviewed-by: Sachin Gupta Reviewed-by: Jennifer A. Stofer Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/43218 Tested-by: FSP CI Jenkins --- .../p9/procedures/hwp/nest/p9_sbe_check_quiesce.C | 59 ++++++++++++++++++++++ .../p9/procedures/hwp/nest/p9_sbe_check_quiesce.H | 6 +++ 2 files changed, 65 insertions(+) (limited to 'src/import') diff --git a/src/import/chips/p9/procedures/hwp/nest/p9_sbe_check_quiesce.C b/src/import/chips/p9/procedures/hwp/nest/p9_sbe_check_quiesce.C index 4fee69a9..504f1645 100644 --- a/src/import/chips/p9/procedures/hwp/nest/p9_sbe_check_quiesce.C +++ b/src/import/chips/p9/procedures/hwp/nest/p9_sbe_check_quiesce.C @@ -53,6 +53,7 @@ #include #include #include +#include #ifndef DD2 #include @@ -94,6 +95,10 @@ extern "C" { FAPI_TRY(p9_psihb_check_quiesce(i_target), "Error from p9_psihb_check_quiesce"); FAPI_TRY(p9_intp_check_quiesce(i_target), "Error from p9_intp_check_quiesce"); + //We also need to clean up any active special wakeups, and redirect + //special wakeups to the SGPE + FAPI_TRY(p9_pm_check_quiesce(i_target), " Error from p9_pm_check_quiesce"); + fapi_try_exit: fapi2::ReturnCode saveError = fapi2::current_err; fapi2::buffer l_data(0); @@ -952,5 +957,59 @@ extern "C" { return fapi2::current_err; } + fapi2::ReturnCode p9_pm_check_quiesce(const fapi2::Target& i_target) + { + // Bit-13 used to set WAKEUP_NOTIFY_SELECT bit on the Core Power Management Mode Reg + static const uint64_t CPPM_WKUP_NOTIFY_SELECT = 0x0004000000000000; + // Bit 0 in each SPWKUP_PMM register controls if SPWKUP is asserted from the source + static const uint64_t CLEAR_SPWKUP = 0x0000000000000000; + // Special wakeup sources + static const uint64_t SPWKUP_SRC_REGS[4] = {C_PPM_SPWKUP_OTR, C_PPM_SPWKUP_FSP, C_PPM_SPWKUP_HYP, C_PPM_SPWKUP_OCC}; + + //TODO: RTC 166888 Remove unneeded consts when p9_pm_suspend gets pulled into MPIPL flow + // Bits 1:3 are XCR control of the PPE_XIXCR, we want to HALT which = 0x010 + static const uint64_t PPE_XIXCR_XCR_HALT = 0x6000000000000000; + // Bit 0 in each C_CPPMR register controls the DISABLE_WRITE functionality + static const uint64_t CLEAR_DISABLE_WRITE = 0x8000000000000000; + //XIXCR scom regs that control the OCC's GPEs + static const uint64_t GPE_XIXCR_REGS[4] = {P9N2_PU_GPE0_GPENXIXCR_SCOM, P9N2_PU_GPE1_GPENXIXCR_SCOM, P9N2_PU_GPE2_GPENXIXCR_SCOM, P9N2_PU_GPE3_GPENXIXCR_SCOM}; + + FAPI_IMP("p9_pm_check_quiesce: Entering..."); + + //Loop over cores and set the WKUP_NOTIFY_SELECT bit and clear out + //SPWK request from all srcs + for(auto& l_childCore : + i_target.getChildren()) + { + //This scom sets WKUP_NOTIFY_SELECT + FAPI_TRY(fapi2::putScom(l_childCore, PERV_EC00_CPPM_CPMMR_OR, CPPM_WKUP_NOTIFY_SELECT )); + + + //This loop clears spwkup asserts from all the possilble srcs + for(uint8_t i = 0; i < 4; i++) + { + FAPI_TRY(fapi2::putScom(l_childCore, SPWKUP_SRC_REGS[i] , CLEAR_SPWKUP)); + } + + //TODO: RTC 166888 Remove clearing WRITE_DISABLE once p9_powman_suspend is added to MPIPL flow + //This scom clears the WRITE_DISABLE bit, this step enables SBE writes + FAPI_TRY(fapi2::putScom(l_childCore, C_CPPM_CPMMR_CLEAR, CLEAR_DISABLE_WRITE )); + + } + + //TODO: RTC 166888 Remove GPE halts once p9_powman_suspend is added to MPIPL flow + //Need to halt the GPEs so wakeups are handled correctly later on + //Loop over the differnt GPE XIXCR scom regs and send the halt command + // to each by writing 0x6 to bits 1:3 of the XIXCR register + for(uint8_t i = 0; i < 4; i++) + { + FAPI_TRY(fapi2::putScom(i_target, GPE_XIXCR_REGS[i], PPE_XIXCR_XCR_HALT)); + } + + fapi_try_exit: + FAPI_IMP("p9_pm_check_quiece: Exiting..."); + return fapi2::current_err; + } + } // extern "C" diff --git a/src/import/chips/p9/procedures/hwp/nest/p9_sbe_check_quiesce.H b/src/import/chips/p9/procedures/hwp/nest/p9_sbe_check_quiesce.H index 5dda788b..dd57f9ff 100644 --- a/src/import/chips/p9/procedures/hwp/nest/p9_sbe_check_quiesce.H +++ b/src/import/chips/p9/procedures/hwp/nest/p9_sbe_check_quiesce.H @@ -126,6 +126,12 @@ extern "C" { fapi2::ReturnCode p9_intp_check_quiesce( const fapi2::Target& i_target); + /// @brief Helper function to ensure SP_WAKEUPS are quiesced + /// @param[in] i_target => P9 chip target + /// @return FAPI_RC_SUCCESS if the check_quiesce completes successfully + fapi2::ReturnCode p9_pm_check_quiesce( + const fapi2::Target& i_target); + fapi2::ReturnCode p9_int_scrub_caches(const fapi2::Target& i_target); } //extern "C" -- cgit v1.2.1