| /* SPDX-License-Identifier: GPL-2.0-only */ |
| |
| #include <device/azalia.h> |
| #include <AGESA.h> |
| #include <northbridge/amd/agesa/BiosCallOuts.h> |
| #include <northbridge/amd/agesa/state_machine.h> |
| #include <FchPlatform.h> |
| |
| const BIOS_CALLOUT_STRUCT BiosCallouts[] = |
| { |
| {AGESA_DO_RESET, agesa_Reset }, |
| {AGESA_READ_SPD, agesa_ReadSpd }, |
| {AGESA_READ_SPD_RECOVERY, agesa_NoopUnsupported }, |
| {AGESA_RUNFUNC_ONAP, agesa_RunFuncOnAp }, |
| {AGESA_GET_IDS_INIT_DATA, agesa_EmptyIdsInitData }, |
| {AGESA_HOOKBEFORE_DQS_TRAINING, agesa_NoopSuccess }, |
| {AGESA_HOOKBEFORE_EXIT_SELF_REF, agesa_NoopSuccess }, |
| {AGESA_GNB_GFX_GET_VBIOS_IMAGE, agesa_GfxGetVbiosImage } |
| }; |
| const int BiosCalloutsLen = ARRAY_SIZE(BiosCallouts); |
| |
| /** |
| * CODEC Initialization Table for Azalia HD Audio using Realtek ALC662 chip |
| */ |
| static const CODEC_ENTRY Alc662_VerbTbl[] = |
| { |
| { 0x14, /*01014010*/ /* Port D - green headphone jack */ |
| (AZALIA_PINCFG_PORT_JACK << 30) |
| | ((AZALIA_PINCFG_LOCATION_EXTERNAL | AZALIA_PINCFG_LOCATION_REAR) << 24) |
| | (AZALIA_PINCFG_DEVICE_LINEOUT << 20) |
| | (AZALIA_PINCFG_CONN_MINI_HEADPHONE_JACK << 16) |
| | (AZALIA_PINCFG_COLOR_GREEN << 12) |
| | (1 << 4) |
| | (0 << 0) |
| }, |
| { 0x15, /*0x90170120*/ /* Port A - white speaker header */ |
| (AZALIA_PINCFG_PORT_FIXED << 30) |
| | (AZALIA_PINCFG_LOCATION_INTERNAL << 24) |
| | (AZALIA_PINCFG_DEVICE_SPEAKER << 20) |
| | (AZALIA_PINCFG_CONN_OTHER_ANALOG << 16) |
| | (AZALIA_PINCFG_COLOR_WHITE << 12) |
| | (AZALIA_PINCFG_MISC_IGNORE_PRESENCE << 8) |
| | (2 << 4) |
| | (0 << 0) |
| }, |
| { 0x16, 0x411111F0 }, /* Port G - not connected */ |
| { 0x18, /*0x01A19040*/ /* Port B - pink headphone jack */ |
| (AZALIA_PINCFG_PORT_JACK << 30) |
| | ((AZALIA_PINCFG_LOCATION_EXTERNAL | AZALIA_PINCFG_LOCATION_REAR) << 24) |
| | (AZALIA_PINCFG_DEVICE_MICROPHONE << 20) |
| | (AZALIA_PINCFG_CONN_MINI_HEADPHONE_JACK << 16) |
| | (AZALIA_PINCFG_COLOR_PINK << 12) |
| | (4 << 4) |
| | (0 << 0) |
| }, |
| { 0x19, /*0x02A19050*/ /* Port F - front panel header mic */ |
| (AZALIA_PINCFG_PORT_NC << 30) |
| | ((AZALIA_PINCFG_LOCATION_EXTERNAL | AZALIA_PINCFG_LOCATION_FRONT) << 24) |
| | (AZALIA_PINCFG_DEVICE_MICROPHONE << 20) |
| | (AZALIA_PINCFG_CONN_MINI_HEADPHONE_JACK << 16) |
| | (AZALIA_PINCFG_COLOR_PINK << 12) |
| | (5 << 4) |
| | (0 << 0) |
| }, |
| { 0x1A, /*0x0181304F*/ /* Port C - NL blue headphone jack */ |
| (AZALIA_PINCFG_PORT_NC << 30) |
| | ((AZALIA_PINCFG_LOCATION_EXTERNAL | AZALIA_PINCFG_LOCATION_REAR) << 24) |
| | (AZALIA_PINCFG_DEVICE_LINEIN << 20) |
| | (AZALIA_PINCFG_CONN_MINI_HEADPHONE_JACK << 16) |
| | (AZALIA_PINCFG_COLOR_BLUE << 12) |
| | (4 << 4) |
| | (0xF << 0) |
| }, |
| { 0x1B, /*0x02214030*/ /* Port E - front panel line-out */ |
| (AZALIA_PINCFG_PORT_NC << 30) |
| | ((AZALIA_PINCFG_LOCATION_EXTERNAL | AZALIA_PINCFG_LOCATION_FRONT) << 24) |
| | (AZALIA_PINCFG_DEVICE_HP_OUT << 20) |
| | (AZALIA_PINCFG_CONN_MINI_HEADPHONE_JACK << 16) |
| | (AZALIA_PINCFG_COLOR_GREEN << 12) |
| | (3 << 4) |
| | (0 << 0) |
| }, |
| { 0x1C, 0x411111F0 }, /* CD-in - Not Connected */ |
| { 0x1D, 0x411111F0 }, /* PC Beep - Not Connected */ |
| { 0x1E, 0x411111F0 }, /* S/PDIF - Not connected */ |
| { 0xFF, 0xFFFFFFFF }, |
| }; |
| |
| static const CODEC_TBL_LIST CodecTableList[] = |
| { |
| {0x10ec0662, (CODEC_ENTRY*)Alc662_VerbTbl}, |
| {(UINT32)0x0FFFFFFFF, (CODEC_ENTRY*)0x0FFFFFFFFUL} |
| }; |
| |
| void board_FCH_InitReset(struct sysinfo *cb_NA, FCH_RESET_DATA_BLOCK *FchParams_reset) |
| { |
| } |
| |
| void board_FCH_InitEnv(struct sysinfo *cb_NA, FCH_DATA_BLOCK *FchParams_env) |
| { |
| /* Azalia Controller OEM Codec Table Pointer */ |
| FchParams_env->Azalia.AzaliaOemCodecTablePtr = (CODEC_TBL_LIST*)CodecTableList; |
| } |