diff options
author | spashabk-in <shakeebbk@in.ibm.com> | 2017-01-18 00:37:53 -0600 |
---|---|---|
committer | Sachin Gupta <sgupta2m@in.ibm.com> | 2017-02-07 09:07:54 -0500 |
commit | 8ba9b982a8f4357dcc4c6ff2204dee00a344c013 (patch) | |
tree | f860a61630d052012258eca090f13f1029a933f6 /src/sbefw | |
parent | 9454074a844f0fa70c19e4e5c4d0f3fd9085d646 (diff) | |
download | talos-sbe-8ba9b982a8f4357dcc4c6ff2204dee00a344c013.tar.gz talos-sbe-8ba9b982a8f4357dcc4c6ff2204dee00a344c013.zip |
Stopclock chip-op update
Change-Id: If382ef60fa3c4a7115fd417edf7c4f18999f226e
RTC:162349
Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/34164
Tested-by: Jenkins Server <pfd-jenkins+hostboot@us.ibm.com>
Tested-by: FSP CI Jenkins <fsp-CI-jenkins+hostboot@us.ibm.com>
Reviewed-by: AMIT J. TENDOLKAR <amit.tendolkar@in.ibm.com>
Reviewed-by: Sachin Gupta <sgupta2m@in.ibm.com>
Diffstat (limited to 'src/sbefw')
-rw-r--r-- | src/sbefw/sbeSpMsg.H | 23 | ||||
-rw-r--r-- | src/sbefw/sbe_sp_intf.H | 8 | ||||
-rw-r--r-- | src/sbefw/sbecmdiplcontrol.C | 2 | ||||
-rw-r--r-- | src/sbefw/sbecmdmpipl.C | 202 |
4 files changed, 162 insertions, 73 deletions
diff --git a/src/sbefw/sbeSpMsg.H b/src/sbefw/sbeSpMsg.H index b80592be..341a9122 100644 --- a/src/sbefw/sbeSpMsg.H +++ b/src/sbefw/sbeSpMsg.H @@ -551,29 +551,6 @@ typedef struct uint32_t targetType:16; uint32_t reserved:8; uint32_t chipletId:8; - - /** - * @brief Validate Target Type for MPIPL Stop Clocks ChipOp - * - * @return bool, true if validation is success, else false - */ - bool validateInputTargetType() - { - bool l_validatePassFlag = false; - switch(targetType) - { - case TARGET_CORE: - case TARGET_EQ: - l_validatePassFlag = true; - break; - - default: - SBE_ERROR(SBE_FUNC "Invalid TargetType[%d] ChipletId[%d] " - "by User",(uint32_t)targetType,(uint32_t)chipletId); - break; - } - return l_validatePassFlag; - } }sbeStopClocksReqMsgHdr_t; /** diff --git a/src/sbefw/sbe_sp_intf.H b/src/sbefw/sbe_sp_intf.H index a2d43994..fdc49770 100644 --- a/src/sbefw/sbe_sp_intf.H +++ b/src/sbefw/sbe_sp_intf.H @@ -330,6 +330,14 @@ enum sbeCoreChipletId }; /** + * @brief EX Chiplet Id Enum + */ +enum sbeExChipletId +{ + EX_ALL_CHIPLETS = 0xFF, +}; + +/** * @brief Thread Num Enum */ enum sbeThreadNum diff --git a/src/sbefw/sbecmdiplcontrol.C b/src/sbefw/sbecmdiplcontrol.C index 46243c3f..2a83b972 100644 --- a/src/sbefw/sbecmdiplcontrol.C +++ b/src/sbefw/sbecmdiplcontrol.C @@ -191,7 +191,7 @@ ReturnCode performTpmReset(); #ifdef SEEPROM_IMAGE // Using function pointer to force long call. p9_sbe_select_ex_FP_t p9_sbe_select_ex_hwp = &p9_sbe_select_ex; -p9_stopclocks_FP_t p9_stopclocks_hwp = &p9_stopclocks; +extern p9_stopclocks_FP_t p9_stopclocks_hwp; //p9_thread_control_FP_t threadCntlhwp = &p9_thread_control; extern p9_thread_control_FP_t threadCntlhwp; #endif diff --git a/src/sbefw/sbecmdmpipl.C b/src/sbefw/sbecmdmpipl.C index 7eaee224..b947603f 100644 --- a/src/sbefw/sbecmdmpipl.C +++ b/src/sbefw/sbecmdmpipl.C @@ -41,6 +41,7 @@ #include "p9_hcd_core_stopclocks.H" #include "p9_hcd_cache_stopclocks.H" +#include "p9_stopclocks.H" #include "fapi2.H" using namespace fapi2; @@ -49,6 +50,7 @@ using namespace fapi2; // Using function pointer to force long call. p9_hcd_cache_stopclocks_FP_t p9_hcd_cache_stopclocks_hwp = &p9_hcd_cache_stopclocks; p9_hcd_core_stopclocks_FP_t p9_hcd_core_stopclocks_hwp = &p9_hcd_core_stopclocks; +p9_stopclocks_FP_t p9_stopclocks_hwp = &p9_stopclocks; #endif /////////////////////////////////////////////////////////////////////// @@ -178,6 +180,93 @@ uint32_t sbeContinueMpipl(uint8_t *i_pArg) // @return RC from the underlying FIFO utility // RTC-161679 : Stop Clocks Chip-op to handle Proc Chip Target /////////////////////////////////////////////////////////////////////// +#define SBE_IS_EX0(chipletId) \ + (((chipletId - EX_TARGET_OFFSET) & 0x0002) >> 1) +/* @brief Bitmapped enumeration to identify the stop clock HWP call + */ +enum stopClockHWPType +{ + SC_NONE = 0x00, + SC_PROC = 0x01, // Call p9_stopclocks + SC_CACHE = 0x02, // Call p9_hcd_cache_stopclocks + SC_CORE = 0x04, // Call p9_hcd_core_stopclocks +}; +/* @brief Deduce the type of stop clock procedure to call based on + * target and chiplet id combination + * + * @param[in] i_targetType SBE chip-op target type + * @param[in] i_chipletId Chiplet id + * + * @return Bitmapped stopClockHWPType enum values + * */ +static inline uint32_t getStopClockHWPType(uint32_t i_targetType, + uint32_t i_chipletId) +{ + uint32_t l_rc = SC_NONE; + TargetType l_fapiTarget = sbeGetFapiTargetType( + i_targetType, + i_chipletId); + if((l_fapiTarget == TARGET_TYPE_PROC_CHIP) || + (l_fapiTarget == TARGET_TYPE_PERV) || + ((i_targetType == TARGET_CORE) && (i_chipletId == SMT4_ALL_CORES))|| + ((i_targetType == TARGET_EQ) && (i_chipletId == EQ_ALL_CHIPLETS)) || + ((i_targetType == TARGET_EX) && (i_chipletId == EX_ALL_CHIPLETS))) + { + l_rc |= SC_PROC; + } + if((l_fapiTarget == TARGET_TYPE_CORE) || + (l_fapiTarget == TARGET_TYPE_EX)) + { + l_rc |= SC_CORE; + } + if((l_fapiTarget == TARGET_TYPE_EQ) || + (l_fapiTarget == TARGET_TYPE_EX)) + { + l_rc |= SC_CACHE; + } + return l_rc; +} +/* @brief Prepare Stop clock flags base on Target Type + * + * @param[in] i_targetType SBE chip-op target Type + * + * @return p9_stopclocks_flags + */ +static inline p9_stopclocks_flags getStopClocksFlags( + uint32_t i_targetType) +{ + p9_stopclocks_flags l_flags; + + if(i_targetType != TARGET_PROC_CHIP) + { + // Clear default flags - only in case the target is not PROC_CHIP + // Otherwise, for a PROC_CHIP target, we want to keep default flags + l_flags.clearAll(); + } + if(i_targetType == TARGET_PERV) + { + // Keep only tp as true + l_flags.stop_tp_clks = true; + } + else if(i_targetType == TARGET_CORE) + { + // Keep only core flag as true + l_flags.stop_core_clks = true; + } + else if(i_targetType == TARGET_EQ) + { + // Keep only cache flag as true + l_flags.stop_cache_clks = true; + } + else if(i_targetType == TARGET_EX) + { + // Keep only cache and core as true + l_flags.stop_cache_clks = true; + l_flags.stop_core_clks = true; + } + + return l_flags; +} uint32_t sbeStopClocks(uint8_t *i_pArg) { #define SBE_FUNC " sbeStopClocks" @@ -202,71 +291,86 @@ uint32_t sbeStopClocks(uint8_t *i_pArg) (uint16_t)l_reqMsg.targetType, (uint8_t)l_reqMsg.chipletId); - if(false == l_reqMsg.validateInputTargetType()) + fapi2::plat_target_handle_t l_tgtHndl; + // Keep these default values in sync with p9_stopclocks.H + p9hcd::P9_HCD_CLK_CTRL_CONSTANTS l_clk_regions + = p9hcd::CLK_REGION_ALL_BUT_PLL_REFR; + p9hcd::P9_HCD_EX_CTRL_CONSTANTS l_ex_select = p9hcd::BOTH_EX; + + // Get the type of stopclocks procedure to call + // based on target and chiplet id + uint32_t l_hwpType = getStopClockHWPType(l_reqMsg.targetType, + l_reqMsg.chipletId); + if(l_hwpType == SC_NONE) { + // Error in target and chiplet id combination + SBE_ERROR(SBE_FUNC "Invalid TargetType[0x%04X] ChipletId[0x%02X]", + (uint32_t)l_reqMsg.targetType, + (uint32_t)l_reqMsg.chipletId); l_respHdr.setStatus( SBE_PRI_INVALID_DATA, SBE_SEC_INVALID_TARGET_TYPE_PASSED ); break; } - - uint64_t l_clk_regions = p9hcd::CLK_REGION_ALL_BUT_PLL_REFR; - uint8_t l_ex_select = p9hcd::BOTH_EX; - - if( (l_reqMsg.chipletId == SMT4_ALL_CORES) || - (l_reqMsg.chipletId == EQ_ALL_CHIPLETS) ) + // All Core/All Cache/All Ex & Perv & Proc are handled here + if(l_hwpType & SC_PROC) { - Target<TARGET_TYPE_PROC_CHIP > l_procTgt = plat_getChipTarget(); - if(l_reqMsg.targetType == TARGET_CORE) + SBE_DEBUG(SBE_FUNC " Calling p9_stopclocks"); + p9_stopclocks_flags l_flags = getStopClocksFlags( + l_reqMsg.targetType); + if(l_reqMsg.targetType == TARGET_EX) { - for (auto l_coreTgt : l_procTgt.getChildren<fapi2::TARGET_TYPE_CORE>()) - { - SBE_DEBUG(SBE_FUNC " Calling p9_hcd_core_stopclocks"); - SBE_EXEC_HWP(l_fapiRc, p9_hcd_core_stopclocks_hwp, l_coreTgt) - if(l_fapiRc != FAPI2_RC_SUCCESS) - { - // break from internal for loop - break; - } - } + l_clk_regions = static_cast<p9hcd::P9_HCD_CLK_CTRL_CONSTANTS> + (p9hcd::CLK_REGION_EX0_REFR | + p9hcd::CLK_REGION_EX1_REFR); } - else // Cache + SBE_EXEC_HWP(l_fapiRc, p9_stopclocks_hwp, + plat_getChipTarget(), + l_flags, + l_clk_regions, + l_ex_select); + } + // Specific CORE/EX + if(l_hwpType & SC_CORE) + { + SBE_DEBUG(SBE_FUNC " Calling p9_hcd_core_stopclocks"); + sbeGetFapiTargetHandle(l_reqMsg.targetType, + l_reqMsg.chipletId, + l_tgtHndl); + if(l_reqMsg.targetType == TARGET_EX) { - for (auto l_eqTgt : l_procTgt.getChildren<fapi2::TARGET_TYPE_EQ>()) + Target<TARGET_TYPE_EX> l_exTgt(l_tgtHndl); + for(auto &l_childCore : + l_exTgt.getChildren<TARGET_TYPE_CORE>()) { - SBE_DEBUG(SBE_FUNC " Calling p9_hcd_cache_stopclocks"); - SBE_EXEC_HWP(l_fapiRc, p9_hcd_cache_stopclocks_hwp, - l_eqTgt, - (p9hcd::P9_HCD_CLK_CTRL_CONSTANTS)l_clk_regions, - (p9hcd::P9_HCD_EX_CTRL_CONSTANTS)l_ex_select) - if(l_fapiRc != FAPI2_RC_SUCCESS) - { - // break from internal for loop - break; - } + SBE_EXEC_HWP(l_fapiRc, + p9_hcd_core_stopclocks_hwp, + l_childCore); } } - } - else // for a single Core/Cache chiplet - { - // Construct the Target - fapi2::plat_target_handle_t l_tgtHndl; - // No Need to check the return here, it's already validated - sbeGetFapiTargetHandle( l_reqMsg.targetType, - l_reqMsg.chipletId, - l_tgtHndl ); - - if(l_reqMsg.targetType == TARGET_CORE) + else { - SBE_DEBUG(SBE_FUNC " Calling p9_hcd_core_stopclocks"); - l_fapiRc = p9_hcd_core_stopclocks(l_tgtHndl); + SBE_EXEC_HWP(l_fapiRc, p9_hcd_core_stopclocks_hwp, l_tgtHndl); } - else //Cache + } + // Specific EQ/EX + if(l_hwpType & SC_CACHE) + { + SBE_DEBUG(SBE_FUNC " Calling p9_hcd_cache_stopclocks"); + if(l_reqMsg.targetType == TARGET_EX) { - SBE_DEBUG(SBE_FUNC " Calling p9_hcd_cache_stopclocks"); - l_fapiRc = p9_hcd_cache_stopclocks(l_tgtHndl, - (p9hcd::P9_HCD_CLK_CTRL_CONSTANTS)l_clk_regions, - (p9hcd::P9_HCD_EX_CTRL_CONSTANTS)l_ex_select); + // Modify l_clk_regions based on chiplet Id + l_clk_regions = SBE_IS_EX0(l_reqMsg.chipletId) ? + p9hcd::CLK_REGION_EX0_REFR : p9hcd::CLK_REGION_EX1_REFR; + // Modify l_ex_select based on chiplet ID + l_ex_select = SBE_IS_EX0(l_reqMsg.chipletId) ? + p9hcd::EVEN_EX : p9hcd::ODD_EX; + Target<TARGET_TYPE_EX> l_ex_target(l_tgtHndl); + l_tgtHndl = l_ex_target.getParent<TARGET_TYPE_EQ>(); } + SBE_EXEC_HWP(l_fapiRc, p9_hcd_cache_stopclocks_hwp, + l_tgtHndl, + (p9hcd::P9_HCD_CLK_CTRL_CONSTANTS)l_clk_regions, + (p9hcd::P9_HCD_EX_CTRL_CONSTANTS)l_ex_select); } if( l_fapiRc != FAPI2_RC_SUCCESS ) |