/* SPDX-License-Identifier: GPL-2.0-only */ /* This file is part of the coreboot project. */ #include #include #include #include #include #include #include #include #include #include #include #include #include void platform_BeforeInitReset(struct sysinfo *cb, AMD_RESET_PARAMS *Reset) { if (!boot_cpu()) return; sb_Poweron_Init(); /* Reboots with outb(3,0x92), outb(4,0xcf9) or triple-fault all * would fail later in AmdInitPost(), when DRAM is already configured * and C6DramLock bit has been set. * * As a workaround, do a hard reset to clear C6DramLock bit. */ #ifdef __SIMPLE_DEVICE__ pci_devfn_t dev = PCI_DEV(0, 0x18, 2); #else struct device *dev = pcidev_on_root(0x18, 2); #endif u32 mct_cfg_lo = pci_read_config32(dev, 0x118); if (mct_cfg_lo & (1<<19)) { printk(BIOS_CRIT, "C6DramLock is set, resetting\n"); system_reset(); } } void platform_BeforeInitEarly(struct sysinfo *cb, AMD_EARLY_PARAMS *Early) { } void platform_BeforeInitPost(struct sysinfo *cb, AMD_POST_PARAMS *Post) { Post->MemConfig.BottomIo = (UINT16)(MIN(0xE0000000, MAX(0x28000000, CONFIG_BOTTOMIO_POSITION)) >> 24) & 0xF8; } void platform_AfterInitPost(struct sysinfo *cb, AMD_POST_PARAMS *Post) { backup_top_of_low_cacheable(Post->MemConfig.Sub4GCacheTop); } void platform_BeforeInitResume(struct sysinfo *cb, AMD_RESUME_PARAMS *Resume) { OemInitResume(&Resume->S3DataBlock); } void platform_AfterInitResume(struct sysinfo *cb, AMD_RESUME_PARAMS *Resume) { } void platform_BeforeInitEnv(struct sysinfo *cb, AMD_ENV_PARAMS *Env) { EmptyHeap(); } void platform_AfterInitEnv(struct sysinfo *cb, AMD_ENV_PARAMS *Env) { amd_initenv(); } void platform_BeforeS3LateRestore(struct sysinfo *cb, AMD_S3LATE_PARAMS *S3Late) { OemS3LateRestore(&S3Late->S3DataBlock); } void platform_AfterS3LateRestore(struct sysinfo *cb, AMD_S3LATE_PARAMS *S3Late) { } void platform_BeforeInitMid(struct sysinfo *cb, AMD_MID_PARAMS *Mid) { sb_After_Pci_Init(); sb_Mid_Post_Init(); amd_initcpuio(); } void platform_BeforeInitLate(struct sysinfo *cb, AMD_LATE_PARAMS *Late) { } void platform_AfterInitLate(struct sysinfo *cb, AMD_LATE_PARAMS *Late) { sb_Late_Post(); } void platform_AfterS3Save(struct sysinfo *cb, AMD_S3SAVE_PARAMS *S3Save) { OemS3Save(&S3Save->S3DataBlock); }