summaryrefslogtreecommitdiffstats
path: root/hwp/perv/p9_sbe_setup_evid.C
blob: b07499b8a80573c1b2c5dd90888f2998852d6bee (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
///
/// @file  p9_sbe_setup_evid.C
/// @brief Setup External Voltage IDs and Boot Frequency
///
// *HW Owner    : Greg Still <stillgs@us.ibm.com>
// *FW Owner    : Sangeetha T S <sangeet2@in.ibm.com>
// *Team        : PM
// *Consumed by : SBE
// *Level       : 1
///
/// @verbatim
/// Procedure Summary:
///   - Use Attributes to send VDD, VCS via the AVS bus to VRMs
///   - Use Attributes to adjust the VDN and send via I2C to VRM
///   - Read core frequency ATTR and write to the Quad PPM
/// @endverbatim

//-----------------------------------------------------------------------------
// Includes
//-----------------------------------------------------------------------------
#include <fapi2.H>
#include "p9_sbe_setup_evid.H"

//-----------------------------------------------------------------------------
// Procedure
//-----------------------------------------------------------------------------

fapi2::ReturnCode
p9_sbe_setup_evid(const fapi2::Target<fapi2::TARGET_TYPE_PROC_CHIP>& i_target)
{

    //fapi2::ReturnCode l_rc = fapi2::FAPI2_RC_SUCCESS;

    // Substep indicators

    // commented out in Level 1 to not have "unused variable" warnings
    // until the SBE substep management "macro" or "call" is defined.

    // const uint32_t STEP_SBE_EVID_START              = 0x1;
    // const uint32_t STEP_SBE_EVID_CONFIG             = 0x2;
    // const uint32_t STEP_SBE_EVID_WRITE_VDN          = 0x3;
    // const uint32_t STEP_SBE_EVID_POLL_VDN_STATUS    = 0x4;
    // const uint32_t STEP_SBE_EVID_WRITE_VDD          = 0x5;
    // const uint32_t STEP_SBE_EVID_POLL_VDD_STATUS    = 0x6;
    // const uint32_t STEP_SBE_EVID_WRITE_VCS          = 0x7;
    // const uint32_t STEP_SBE_EVID_POLL_VCS_STATUS    = 0x8;
    // const uint32_t STEP_SBE_EVID_TIMEOUT            = 0x9;
    // const uint32_t STEP_SBE_EVID_BOOT_FREQ          = 0xA;
    // const uint32_t STEP_SBE_EVID_COMPLETE           = 0xB;

// The inclusion of the following will cause a "label 'fapi_try_exit' defined but not used"
// compile error in Cronus.  This will be uncommented when FAPI_TRY functions are added
// during the real procedure development.  However, this is NOT needed for Level 1.
//fapi_try_exit:
    return fapi2::current_err;

} // Procedure

OpenPOWER on IntegriCloud