AGESA fam14: Add amd_initenv()
Not part of wrapper to AGESA, but workaround for enable_resources(). Also remove remains of comments in non-fam14 wrappers. Change-Id: I2526821ca283feb6a506b602b86f817f8b03b341 Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: http://review.coreboot.org/7816 Reviewed-by: Paul Menzel <paulepanter@users.sourceforge.net> Tested-by: build bot (Jenkins) Reviewed-by: Edward O'Callaghan <eocallaghan@alterapraxis.com>
This commit is contained in:
parent
48518f0d60
commit
4a08e15086
|
@ -97,3 +97,83 @@ void amd_initmmio(void)
|
|||
PciData = (AMD_APU_SSID << 0x10) | AMD_APU_SVID;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciData, &StdHeader);
|
||||
}
|
||||
|
||||
void amd_initenv(void)
|
||||
{
|
||||
AMD_INTERFACE_PARAMS AmdParamStruct;
|
||||
PCI_ADDR PciAddress;
|
||||
UINT32 PciValue;
|
||||
|
||||
/* Initialize Subordinate Bus Number and Secondary Bus Number
|
||||
* In platform BIOS this address is allocated by PCI enumeration code
|
||||
Modify D1F0x18
|
||||
*/
|
||||
PciAddress.Address.Bus = 0;
|
||||
PciAddress.Address.Device = 1;
|
||||
PciAddress.Address.Function = 0;
|
||||
PciAddress.Address.Register = 0x18;
|
||||
/* Write to D1F0x18 */
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x00010100;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize GMM Base Address for Legacy Bridge Mode
|
||||
* Modify B1D5F0x18
|
||||
*/
|
||||
PciAddress.Address.Bus = 1;
|
||||
PciAddress.Address.Device = 5;
|
||||
PciAddress.Address.Function = 0;
|
||||
PciAddress.Address.Register = 0x18;
|
||||
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x96000000;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize FB Base Address for Legacy Bridge Mode
|
||||
* Modify B1D5F0x10
|
||||
*/
|
||||
PciAddress.Address.Register = 0x10;
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x80000000;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize GMM Base Address for Pcie Mode
|
||||
* Modify B0D1F0x18
|
||||
*/
|
||||
PciAddress.Address.Bus = 0;
|
||||
PciAddress.Address.Device = 1;
|
||||
PciAddress.Address.Function = 0;
|
||||
PciAddress.Address.Register = 0x18;
|
||||
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x96000000;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize FB Base Address for Pcie Mode
|
||||
* Modify B0D1F0x10
|
||||
*/
|
||||
PciAddress.Address.Register = 0x10;
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x80000000;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize MMIO Base and Limit Address
|
||||
* Modify B0D1F0x20
|
||||
*/
|
||||
PciAddress.Address.Bus = 0;
|
||||
PciAddress.Address.Device = 1;
|
||||
PciAddress.Address.Function = 0;
|
||||
PciAddress.Address.Register = 0x20;
|
||||
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x96009600;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize MMIO Prefetchable Memory Limit and Base
|
||||
* Modify B0D1F0x24
|
||||
*/
|
||||
PciAddress.Address.Register = 0x24;
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x8FF18001;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
}
|
||||
|
|
|
@ -86,6 +86,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x41);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
post_code(0x50);
|
||||
copy_and_run();
|
||||
|
|
|
@ -93,6 +93,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x42);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
} else { /* S3 detect */
|
||||
printk(BIOS_INFO, "S3 detected\n");
|
||||
|
|
|
@ -86,6 +86,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x41);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
post_code(0x50);
|
||||
copy_and_run();
|
||||
|
|
|
@ -80,6 +80,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x41);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
post_code(0x50);
|
||||
copy_and_run();
|
||||
|
|
|
@ -86,6 +86,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x41);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
post_code(0x50);
|
||||
copy_and_run();
|
||||
|
|
|
@ -101,6 +101,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x42);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
} else { /* S3 detect */
|
||||
printk(BIOS_INFO, "S3 detected\n");
|
||||
|
|
|
@ -109,6 +109,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x42);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
} else { /* S3 detect */
|
||||
printk(BIOS_INFO, "S3 detected\n");
|
||||
|
|
|
@ -96,6 +96,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x42);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
} else { /* S3 detect */
|
||||
printk(BIOS_INFO, "S3 detected\n");
|
||||
|
|
|
@ -97,6 +97,7 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
|||
|
||||
post_code(0x42);
|
||||
agesawrapper_amdinitenv();
|
||||
amd_initenv();
|
||||
|
||||
} else { /* S3 detect */
|
||||
printk(BIOS_INFO, "S3 detected\n");
|
||||
|
|
|
@ -48,6 +48,7 @@ void agesawrapper_trace(AGESA_STATUS ret, AMD_CONFIG_PARAMS *StdHeader, const ch
|
|||
|
||||
void amd_initcpuio(void);
|
||||
void amd_initmmio(void);
|
||||
void amd_initenv(void);
|
||||
|
||||
AGESA_STATUS agesawrapper_amdinitresume(void);
|
||||
AGESA_STATUS agesawrapper_amdS3Save(void);
|
||||
|
|
|
@ -125,8 +125,6 @@ AGESA_STATUS agesawrapper_amdinitenv(VOID)
|
|||
{
|
||||
AGESA_STATUS status;
|
||||
AMD_INTERFACE_PARAMS AmdParamStruct;
|
||||
PCI_ADDR PciAddress;
|
||||
UINT32 PciValue;
|
||||
|
||||
memset(&AmdParamStruct, 0, sizeof(AMD_INTERFACE_PARAMS));
|
||||
|
||||
|
@ -141,80 +139,7 @@ AGESA_STATUS agesawrapper_amdinitenv(VOID)
|
|||
status = AmdInitEnv((AMD_ENV_PARAMS *) AmdParamStruct.NewStructPtr);
|
||||
AGESA_EVENTLOG(status, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize Subordinate Bus Number and Secondary Bus Number
|
||||
* In platform BIOS this address is allocated by PCI enumeration code
|
||||
Modify D1F0x18
|
||||
*/
|
||||
PciAddress.Address.Bus = 0;
|
||||
PciAddress.Address.Device = 1;
|
||||
PciAddress.Address.Function = 0;
|
||||
PciAddress.Address.Register = 0x18;
|
||||
/* Write to D1F0x18 */
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x00010100;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize GMM Base Address for Legacy Bridge Mode
|
||||
* Modify B1D5F0x18
|
||||
*/
|
||||
PciAddress.Address.Bus = 1;
|
||||
PciAddress.Address.Device = 5;
|
||||
PciAddress.Address.Function = 0;
|
||||
PciAddress.Address.Register = 0x18;
|
||||
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x96000000;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize FB Base Address for Legacy Bridge Mode
|
||||
* Modify B1D5F0x10
|
||||
*/
|
||||
PciAddress.Address.Register = 0x10;
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x80000000;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize GMM Base Address for Pcie Mode
|
||||
* Modify B0D1F0x18
|
||||
*/
|
||||
PciAddress.Address.Bus = 0;
|
||||
PciAddress.Address.Device = 1;
|
||||
PciAddress.Address.Function = 0;
|
||||
PciAddress.Address.Register = 0x18;
|
||||
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x96000000;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize FB Base Address for Pcie Mode
|
||||
* Modify B0D1F0x10
|
||||
*/
|
||||
PciAddress.Address.Register = 0x10;
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x80000000;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize MMIO Base and Limit Address
|
||||
* Modify B0D1F0x20
|
||||
*/
|
||||
PciAddress.Address.Bus = 0;
|
||||
PciAddress.Address.Device = 1;
|
||||
PciAddress.Address.Function = 0;
|
||||
PciAddress.Address.Register = 0x20;
|
||||
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x96009600;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
|
||||
/* Initialize MMIO Prefetchable Memory Limit and Base
|
||||
* Modify B0D1F0x24
|
||||
*/
|
||||
PciAddress.Address.Register = 0x24;
|
||||
LibAmdPciRead(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
PciValue |= 0x8FF18001;
|
||||
LibAmdPciWrite(AccessWidth32, PciAddress, &PciValue, &AmdParamStruct.StdHeader);
|
||||
AmdReleaseStruct(&AmdParamStruct);
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
|
|
|
@ -150,10 +150,6 @@ AGESA_STATUS agesawrapper_amdinitenv(void)
|
|||
|
||||
status = AmdInitEnv(EnvParam);
|
||||
AGESA_EVENTLOG(status, &EnvParam->StdHeader);
|
||||
/* Initialize Subordinate Bus Number and Secondary Bus Number
|
||||
* In platform BIOS this address is allocated by PCI enumeration code
|
||||
Modify D1F0x18
|
||||
*/
|
||||
|
||||
return status;
|
||||
}
|
||||
|
|
|
@ -150,10 +150,6 @@ AGESA_STATUS agesawrapper_amdinitenv(void)
|
|||
|
||||
status = AmdInitEnv(EnvParam);
|
||||
AGESA_EVENTLOG(status, &EnvParam->StdHeader);
|
||||
/* Initialize Subordinate Bus Number and Secondary Bus Number
|
||||
* In platform BIOS this address is allocated by PCI enumeration code
|
||||
Modify D1F0x18
|
||||
*/
|
||||
|
||||
return status;
|
||||
}
|
||||
|
|
|
@ -150,10 +150,6 @@ AGESA_STATUS agesawrapper_amdinitenv(void)
|
|||
|
||||
status = AmdInitEnv(EnvParam);
|
||||
AGESA_EVENTLOG(status, &EnvParam->StdHeader);
|
||||
/* Initialize Subordinate Bus Number and Secondary Bus Number
|
||||
* In platform BIOS this address is allocated by PCI enumeration code
|
||||
Modify D1F0x18
|
||||
*/
|
||||
|
||||
return status;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue