blob: 9d77332e2000faff413d25c0e1c38ce0410205e4 [file] [log] [blame]
/* $NoKeywords:$ */
/**
* @file
*
* Family 15h 'early sample' support
*
* This file defines the required structures for family 15h pre-production processors.
*
* @xrefitem bom "File Content Label" "Release Content"
* @e project: AGESA
* @e sub-project: Core
* @e \$Revision: 53356 $ @e \$Date: 2011-05-18 14:14:18 -0600 (Wed, 18 May 2011) $
*/
/*****************************************************************************
*
* Copyright (C) 2012 Advanced Micro Devices, Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of Advanced Micro Devices, Inc. nor the names of
* its contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL ADVANCED MICRO DEVICES, INC. BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*
***************************************************************************/
#ifndef _OPTION_FAMILY_15H_EARLY_SAMPLE_H_
#define _OPTION_FAMILY_15H_EARLY_SAMPLE_H_
/*---------------------------------------------------------------------------------------
* M I X E D (Definitions And Macros / Typedefs, Structures, Enums)
*---------------------------------------------------------------------------------------
*/
/*---------------------------------------------------------------------------------------
* D E F I N I T I O N S A N D M A C R O S
*---------------------------------------------------------------------------------------
*/
/*---------------------------------------------------------------------------------------
* T Y P E D E F S, S T R U C T U R E S, E N U M S
*---------------------------------------------------------------------------------------
*/
/*
* Install family 15h model 0x00 - 0x0F Early Sample support
*/
/**
* Early sample hook point during HTC initialization
*
* @param[in,out] HtcRegister Value of F3x64 to be written.
* @param[in] StdHeader Handle of Header for calling lib functions and services.
*
*/
typedef VOID F_F15_OR_ES_HTC_INIT_HOOK (
IN OUT UINT32 *HtcRegister,
IN AMD_CONFIG_PARAMS *StdHeader
);
/// Reference to a Method.
typedef F_F15_OR_ES_HTC_INIT_HOOK *PF_F15_OR_ES_HTC_INIT_HOOK;
/// Hook points in the core functionality necessary for
/// providing support for pre-production CPUs.
typedef struct {
PF_F15_OR_ES_HTC_INIT_HOOK F15OrHtcInitHook; ///< Allows for override of a certain processor register value during HTC init
} F15_OR_ES_CORE_SUPPORT;
/**
* Returns whether or not the processor should enable the CPB feature.
*
* @param[in,out] IsEnabled Whether or not to enable CPB
* @param[in] StdHeader Handle of Header for calling lib functions and services.
*
*/
typedef VOID F_F15_OR_ES_IS_CPB_SUPPORTED (
IN OUT BOOLEAN *IsEnabled,
IN AMD_CONFIG_PARAMS *StdHeader
);
/// Reference to a Method.
typedef F_F15_OR_ES_IS_CPB_SUPPORTED *PF_F15_OR_ES_IS_CPB_SUPPORTED;
/// Hook points in the CPB feature necessary for
/// providing support for pre-production CPUs.
typedef struct {
PF_F15_OR_ES_IS_CPB_SUPPORTED F15OrIsCpbSupportedHook; ///< CPB enablement override
} F15_OR_ES_CPB_SUPPORT;
/**
* Returns whether or not the processor should enable the C6 feature.
*
* @param[in,out] IsEnabled Whether or not to enable C6
* @param[in] StdHeader Handle of Header for calling lib functions and services.
*
*/
typedef VOID F_F15_OR_ES_IS_C6_SUPPORTED (
IN OUT BOOLEAN *IsEnabled,
IN AMD_CONFIG_PARAMS *StdHeader
);
/// Reference to a Method.
typedef F_F15_OR_ES_IS_C6_SUPPORTED *PF_F15_OR_ES_IS_C6_SUPPORTED;
/// Hook points in the C6 feature necessary for
/// providing support for pre-production CPUs.
typedef struct {
PF_F15_OR_ES_IS_C6_SUPPORTED F15OrIsC6SupportedHook; ///< C6 enablement override
} F15_OR_ES_C6_SUPPORT;
/**
* Workaround to avoid patch loading from causing NB cycles
*
* @param[in,out] StdHeader - Config handle for library and services.
* @param[in,out] SavedMsrValue - Saved a MSR value
*
*/
typedef VOID F_F15_OR_ES_AVOID_NB_CYCLES_START (
IN OUT AMD_CONFIG_PARAMS *StdHeader,
IN UINT64 *SavedMsrValue
);
/// Reference to a Method.
typedef F_F15_OR_ES_AVOID_NB_CYCLES_START *PF_F15_OR_ES_AVOID_NB_CYCLES_START;
/**
* Workaround to avoid patch loading from causing NB cycles
*
* @param[in,out] StdHeader - Config handle for library and services.
* @param[in] SavedMsrValue - Saved a MSR value
*
*
*/
typedef VOID F_F15_OR_ES_AVOID_NB_CYCLES_END (
IN OUT AMD_CONFIG_PARAMS *StdHeader,
IN UINT64 *SavedMsrValue
);
/// Reference to a Method.
typedef F_F15_OR_ES_AVOID_NB_CYCLES_END *PF_F15_OR_ES_AVOID_NB_CYCLES_END;
/**
* Workaround for Ax processors after patch is loaded.
*
* @param[in] StdHeader - Config handle for library and services.
* @param[in] IsPatchLoaded - Is patch loaded
*
*
*/
typedef VOID F_F15_OR_ES_AFTER_PATCH_LOADED (
IN OUT AMD_CONFIG_PARAMS *StdHeader,
IN BOOLEAN IsPatchLoaded
);
/// Reference to a Method.
typedef F_F15_OR_ES_AFTER_PATCH_LOADED *PF_F15_OR_ES_AFTER_PATCH_LOADED;
/**
* Update the CPU microcode.
*
* @param[in] StdHeader - Config handle for library and services.
*
* @retval TRUE - Patch Loaded Successfully.
* @retval FALSE - Patch Did Not Get Loaded.
*
*/
typedef BOOLEAN F_F15_OR_ES_LOAD_MCU_PATCH (
IN OUT AMD_CONFIG_PARAMS *StdHeader
);
/// Reference to a Method.
typedef F_F15_OR_ES_LOAD_MCU_PATCH *PF_F15_OR_ES_LOAD_MCU_PATCH;
/// Hook points in the Microcode Update feature necessary for
/// providing support for pre-production CPUs.
typedef struct {
PF_F15_OR_ES_AVOID_NB_CYCLES_START F15OrESAvoidNbCyclesStart; ///< Workaround to avoid patch loading from causing NB cycles
PF_F15_OR_ES_AVOID_NB_CYCLES_END F15OrESAvoidNbCyclesEnd; ///< Workaround to avoid patch loading from causing NB cycles
PF_F15_OR_ES_LOAD_MCU_PATCH F15OrUpdateMcuPatchHook; ///< Processor MCU Update override
PF_F15_OR_ES_AFTER_PATCH_LOADED F15OrESAfterPatchLoaded; ///< Workaround for Ax processors after patch is loaded
} F15_OR_ES_MCU_PATCH;
typedef BOOLEAN F_F15_TN_ES_LOAD_MCU_PATCH (
IN OUT AMD_CONFIG_PARAMS *StdHeader
);
/// Reference to a Method.
typedef F_F15_TN_ES_LOAD_MCU_PATCH *PF_F15_TN_ES_LOAD_MCU_PATCH;
/// Hook points in the Microcode Update feature necessary for
/// providing support for pre-production CPUs.
typedef struct {
PF_F15_TN_ES_LOAD_MCU_PATCH F15TnUpdateMcuPatchHook; ///< Processor MCU Update override
} F15_TN_ES_MCU_PATCH;
/*---------------------------------------------------------------------------------------
* F U N C T I O N P R O T O T Y P E
*---------------------------------------------------------------------------------------
*/
#endif // _OPTION_FAMILY_15H_EARLY_SAMPLE_H_