diff options
author | Joe McGill <jmcgill@us.ibm.com> | 2016-10-25 08:09:06 -0500 |
---|---|---|
committer | William G. Hoffa <wghoffa@us.ibm.com> | 2017-01-16 21:59:00 -0500 |
commit | dddff1630540b922205aaad4bde664ca80620ee6 (patch) | |
tree | 5cdd7b875cd79f472573d2fe36c6b3d41f5d12ef /src/import/chips/p9/procedures/hwp/nest/p9_chiplet_scominit.C | |
parent | 6543e228612e9651a8af6e41f03c331ebdba9a85 (diff) | |
download | talos-hostboot-dddff1630540b922205aaad4bde664ca80620ee6.tar.gz talos-hostboot-dddff1630540b922205aaad4bde664ca80620ee6.zip |
p9_chiplet_scominit -- set FBC IOE/IOO DL TL FIR programming, mask HCA FIRs
Change-Id: I499c367e38132c76e40ace223505dbcfb31d1286
Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/34270
Tested-by: Jenkins Server <pfd-jenkins+hostboot@us.ibm.com>
Tested-by: Hostboot CI <hostboot-ci+hostboot@us.ibm.com>
Reviewed-by: Zane C. Shelley <zshelle@us.ibm.com>
Reviewed-by: Kevin F. Reick <reick@us.ibm.com>
Reviewed-by: Thi N. Tran <thi@us.ibm.com>
Reviewed-by: Joseph J. McGill <jmcgill@us.ibm.com>
Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/34335
Tested-by: FSP CI Jenkins <fsp-CI-jenkins+hostboot@us.ibm.com>
Tested-by: Jenkins OP Build CI <op-jenkins+hostboot@us.ibm.com>
Reviewed-by: William G. Hoffa <wghoffa@us.ibm.com>
Diffstat (limited to 'src/import/chips/p9/procedures/hwp/nest/p9_chiplet_scominit.C')
-rw-r--r-- | src/import/chips/p9/procedures/hwp/nest/p9_chiplet_scominit.C | 92 |
1 files changed, 90 insertions, 2 deletions
diff --git a/src/import/chips/p9/procedures/hwp/nest/p9_chiplet_scominit.C b/src/import/chips/p9/procedures/hwp/nest/p9_chiplet_scominit.C index b316823c3..6fbe41256 100644 --- a/src/import/chips/p9/procedures/hwp/nest/p9_chiplet_scominit.C +++ b/src/import/chips/p9/procedures/hwp/nest/p9_chiplet_scominit.C @@ -5,7 +5,7 @@ /* */ /* OpenPOWER HostBoot Project */ /* */ -/* Contributors Listed Below - COPYRIGHT 2015,2016 */ +/* Contributors Listed Below - COPYRIGHT 2015,2017 */ /* [+] International Business Machines Corp. */ /* */ /* */ @@ -51,6 +51,40 @@ #include <p9_int_scom.H> #include <p9_vas_scom.H> +#include <p9_xbus_scom_addresses.H> +#include <p9_xbus_scom_addresses_fld.H> +#include <p9_obus_scom_addresses.H> +#include <p9_obus_scom_addresses_fld.H> +#include <p9_misc_scom_addresses.H> + +//------------------------------------------------------------------------------ +// Constant definitions +//------------------------------------------------------------------------------ +const uint64_t FBC_IOE_TL_FIR_ACTION0 = 0x0000000000000000ULL; +const uint64_t FBC_IOE_TL_FIR_ACTION1 = 0x004B000000000000ULL; +const uint64_t FBC_IOE_TL_FIR_MASK = 0xFF24F0303FFFFFFFULL; + +const uint64_t FBC_IOO_TL_FIR_ACTION0 = 0x0000000000000000ULL; +const uint64_t FBC_IOO_TL_FIR_ACTION1 = 0x0002400000000000ULL; +const uint64_t FBC_IOO_TL_FIR_MASK = 0xFF6DB0000FFFFFFFULL; + +const uint64_t FBC_IOE_DL_FIR_ACTION0 = 0x0000000000000000ULL; +const uint64_t FBC_IOE_DL_FIR_ACTION1 = 0x0303C00000001FFCULL; +const uint64_t FBC_IOE_DL_FIR_MASK = 0xFCFC3FFFFFFFE003ULL; + +const uint64_t FBC_IOO_DL_FIR_ACTION0 = 0x0000000000000000ULL; +const uint64_t FBC_IOO_DL_FIR_ACTION1 = 0x0303C0000300FFFCULL; +const uint64_t FBC_IOO_DL_FIR_MASK = 0xFCFC3FFFFCFF0003ULL; + +const uint64_t HCA_EH_FIR_ACTION0 = 0x0000000000000000ULL; +const uint64_t HCA_EH_FIR_ACTION1 = 0x0000000000000000ULL; +const uint64_t HCA_EH_FIR_MASK = 0xFFFFFFFFF0000000ULL; + +const uint64_t HCA_EN_FIR_ACTION0 = 0x0000000000000000ULL; +const uint64_t HCA_EN_FIR_ACTION1 = 0x0000000000000000ULL; +const uint64_t HCA_EN_FIR_MASK = 0xFFFFFF0000000000ULL; + + //------------------------------------------------------------------------------ // Function definitions //------------------------------------------------------------------------------ @@ -100,7 +134,7 @@ fapi2::ReturnCode p9_chiplet_scominit(const fapi2::Target<fapi2::TARGET_TYPE_PRO goto fapi_try_exit; } - // invoke IOE (XBUS FBC IO) SCOM initfiles + // setup IOE (XBUS FBC IO) TL SCOMs FAPI_DBG("Invoking p9.fbc.ioe_tl.scom.initfile on target %s...", l_procTargetStr); FAPI_EXEC_HWP(l_rc, p9_fbc_ioe_tl_scom, i_target, FAPI_SYSTEM); @@ -113,6 +147,17 @@ fapi2::ReturnCode p9_chiplet_scominit(const fapi2::Target<fapi2::TARGET_TYPE_PRO l_xbus_chiplets = i_target.getChildren<fapi2::TARGET_TYPE_XBUS>(); + if (l_xbus_chiplets.size()) + { + FAPI_TRY(fapi2::putScom(i_target, PU_PB_IOE_FIR_ACTION0_REG, FBC_IOE_TL_FIR_ACTION0), + "Error from putScom (PU_PB_IOE_FIR_ACTION0_REG)"); + FAPI_TRY(fapi2::putScom(i_target, PU_PB_IOE_FIR_ACTION1_REG, FBC_IOE_TL_FIR_ACTION1), + "Error from putScom (PU_PB_IOE_FIR_ACTION1_REG)"); + FAPI_TRY(fapi2::putScom(i_target, PU_PB_IOE_FIR_MASK_REG, FBC_IOE_TL_FIR_MASK), + "Error from putScom (PU_PB_IOE_FIR_MASK_REG)"); + } + + // setup IOE (XBUS FBC IO) DL SCOMs for (auto l_iter = l_xbus_chiplets.begin(); l_iter != l_xbus_chiplets.end(); l_iter++) @@ -127,6 +172,14 @@ fapi2::ReturnCode p9_chiplet_scominit(const fapi2::Target<fapi2::TARGET_TYPE_PRO fapi2::current_err = l_rc; goto fapi_try_exit; } + + // configure action registers & unmask + FAPI_TRY(fapi2::putScom(*l_iter, XBUS_LL0_IOEL_FIR_ACTION0_REG, FBC_IOE_DL_FIR_ACTION0), + "Error from putScom (XBUS_LL0_IOEL_FIR_ACTION0_REG)"); + FAPI_TRY(fapi2::putScom(*l_iter, XBUS_LL0_IOEL_FIR_ACTION1_REG, FBC_IOE_DL_FIR_ACTION1), + "Error from putScom (XBUS_LL0_IOEL_FIR_ACTION1_REG)"); + FAPI_TRY(fapi2::putScom(*l_iter, XBUS_LL0_LL0_LL0_IOEL_FIR_MASK_REG, FBC_IOE_DL_FIR_MASK), + "Error from putScom (XBUS_LL0_LL0_LL0_IOEL_FIR_MASK_REG)"); } // invoke IOO (OBUS FBC IO) SCOM initfiles @@ -142,6 +195,16 @@ fapi2::ReturnCode p9_chiplet_scominit(const fapi2::Target<fapi2::TARGET_TYPE_PRO l_obus_chiplets = i_target.getChildren<fapi2::TARGET_TYPE_OBUS>(); + if (l_obus_chiplets.size()) + { + FAPI_TRY(fapi2::putScom(i_target, PU_IOE_PB_IOO_FIR_ACTION0_REG, FBC_IOO_TL_FIR_ACTION0), + "Error from putScom (PU_IOE_PB_IOO_FIR_ACTION0_REG)"); + FAPI_TRY(fapi2::putScom(i_target, PU_IOE_PB_IOO_FIR_ACTION1_REG, FBC_IOO_TL_FIR_ACTION1), + "Error from putScom (PU_IOE_PB_IOO_FIR_ACTION1_REG)"); + FAPI_TRY(fapi2::putScom(i_target, PU_IOE_PB_IOO_FIR_MASK_REG, FBC_IOO_TL_FIR_MASK), + "Error from putScom (PU_IOE_PB_IOO_FIR_MASK_REG)"); + } + for (auto l_iter = l_obus_chiplets.begin(); l_iter != l_obus_chiplets.end(); l_iter++) @@ -162,6 +225,14 @@ fapi2::ReturnCode p9_chiplet_scominit(const fapi2::Target<fapi2::TARGET_TYPE_PRO fapi2::current_err = l_rc; goto fapi_try_exit; } + + // configure action registers & unmask + FAPI_TRY(fapi2::putScom(*l_iter, OBUS_LL0_PB_IOOL_FIR_ACTION0_REG, FBC_IOO_DL_FIR_ACTION0), + "Error from putScom (OBUS_LL0_PB_IOOL_FIR_ACTION0_REG)"); + FAPI_TRY(fapi2::putScom(*l_iter, OBUS_LL0_PB_IOOL_FIR_ACTION1_REG, FBC_IOO_DL_FIR_ACTION1), + "Error from putScom (OBUS_LL0_PB_IOOL_FIR_ACTION1_REG)"); + FAPI_TRY(fapi2::putScom(*l_iter, OBUS_LL0_LL0_LL0_PB_IOOL_FIR_MASK_REG, FBC_IOO_DL_FIR_MASK), + "Error from putScom (OBUS_LL0_LL0_LL0_PB_IOOL_FIR_MASK_REG)"); } FAPI_TRY(FAPI_ATTR_SET(fapi2::ATTR_PROC_FABRIC_OPTICS_CONFIG_MODE, i_target, l_fbc_optics_cfg_mode), @@ -218,6 +289,23 @@ fapi2::ReturnCode p9_chiplet_scominit(const fapi2::Target<fapi2::TARGET_TYPE_PRO goto fapi_try_exit; } + // HCA setup + { + FAPI_TRY(fapi2::putScom(i_target, PU_EHHCA_FIR_ACTION0_REG, HCA_EH_FIR_ACTION0), + "Error from putScom (PU_EHHCA_FIR_ACTION0_REG)"); + FAPI_TRY(fapi2::putScom(i_target, PU_EHHCA_FIR_ACTION1_REG, HCA_EH_FIR_ACTION1), + "Error from putScom (PU_EHHCA_FIR_ACTION0_REG)"); + FAPI_TRY(fapi2::putScom(i_target, PU_EHHCA_FIR_MASK_REG, HCA_EH_FIR_MASK), + "Error from putScom (PU_EHHCA_FIR_MASK_REG)"); + + FAPI_TRY(fapi2::putScom(i_target, PU_ENHCA_FIR_ACTION0_REG, HCA_EN_FIR_ACTION0), + "Error from putScom (PU_ENHCA_FIR_ACTION0_REG)"); + FAPI_TRY(fapi2::putScom(i_target, PU_ENHCA_FIR_ACTION1_REG, HCA_EN_FIR_ACTION1), + "Error from putScom (PU_ENHCA_FIR_ACTION0_REG)"); + FAPI_TRY(fapi2::putScom(i_target, PU_ENHCA_FIR_MASK_REG, HCA_EN_FIR_MASK), + "Error from putScom (PU_ENHCA_FIR_MASK_REG)"); + } + fapi_try_exit: FAPI_DBG("End"); return fapi2::current_err; |