blob: cbf0313267f666e014a778a5c685da2a35fab0e5 [file] [log] [blame]
Angel Pons4b429832020-04-02 23:48:50 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Kyösti Mälkki28c4d2f2016-11-25 11:21:02 +02002
Kyösti Mälkki2446c1e2020-07-09 07:13:37 +03003#include <amdblocks/biosram.h>
4
Elyes HAOUAS19f5ba82018-10-14 14:52:06 +02005#include <Porting.h>
6#include <AGESA.h>
Kyösti Mälkki28c4d2f2016-11-25 11:21:02 +02007#include <northbridge/amd/agesa/state_machine.h>
8#include <northbridge/amd/agesa/agesa_helper.h>
9
10void platform_BeforeInitReset(struct sysinfo *cb, AMD_RESET_PARAMS *Reset)
11{
12}
13
14void platform_BeforeInitEarly(struct sysinfo *cb, AMD_EARLY_PARAMS *Early)
15{
16}
17
18void platform_BeforeInitPost(struct sysinfo *cb, AMD_POST_PARAMS *Post)
19{
Kyösti Mälkki2b9f5b52017-03-26 11:56:43 +030020 AGESA_STATUS status;
21
Mike Banone7f176c2020-01-19 21:42:09 +030022 Post->MemConfig.BottomIo = (UINT16)(MIN(0xE0000000,
23 MAX(0x28000000, CONFIG_BOTTOMIO_POSITION)) >> 24) & 0xF8;
24
Julius Wernercd49cce2019-03-05 16:53:33 -080025 if (CONFIG(ENABLE_MRC_CACHE)) {
Kyösti Mälkki2b9f5b52017-03-26 11:56:43 +030026 status = OemInitResume(&Post->MemConfig.MemContext);
Elyes HAOUAS0f8b8d92019-01-03 10:23:28 +010027 if (status == AGESA_SUCCESS)
Kyösti Mälkki2b9f5b52017-03-26 11:56:43 +030028 Post->MemConfig.MemRestoreCtl = 1;
29 }
Kyösti Mälkki28c4d2f2016-11-25 11:21:02 +020030}
31
32void platform_AfterInitPost(struct sysinfo *cb, AMD_POST_PARAMS *Post)
33{
34 backup_top_of_low_cacheable(Post->MemConfig.Sub4GCacheTop);
35}
36
37void platform_BeforeInitResume(struct sysinfo *cb, AMD_RESUME_PARAMS *Resume)
38{
39 OemInitResume(&Resume->S3DataBlock);
40}
41
42void platform_AfterInitResume(struct sysinfo *cb, AMD_RESUME_PARAMS *Resume)
43{
44}
45
46void platform_BeforeInitEnv(struct sysinfo *cb, AMD_ENV_PARAMS *Env)
47{
48 EmptyHeap();
49}
50
51void platform_AfterInitEnv(struct sysinfo *cb, AMD_ENV_PARAMS *Env)
52{
53}
54
55void platform_BeforeS3LateRestore(struct sysinfo *cb, AMD_S3LATE_PARAMS *S3Late)
56{
57 OemS3LateRestore(&S3Late->S3DataBlock);
58}
59
60void platform_AfterS3LateRestore(struct sysinfo *cb, AMD_S3LATE_PARAMS *S3Late)
61{
62 amd_initcpuio();
Kyösti Mälkki28c4d2f2016-11-25 11:21:02 +020063}
64
65void platform_BeforeInitMid(struct sysinfo *cb, AMD_MID_PARAMS *Mid)
66{
67 amd_initcpuio();
68}
69
Michał Żygowski506b9c12019-12-20 16:57:13 +010070void platform_BeforeInitLate(struct sysinfo *cb, AMD_LATE_PARAMS *Late)
71{
72}
73
Kyösti Mälkki28c4d2f2016-11-25 11:21:02 +020074void platform_AfterInitLate(struct sysinfo *cb, AMD_LATE_PARAMS *Late)
75{
Kyösti Mälkki28c4d2f2016-11-25 11:21:02 +020076}
77
78void platform_AfterS3Save(struct sysinfo *cb, AMD_S3SAVE_PARAMS *S3Save)
79{
80 OemS3Save(&S3Save->S3DataBlock);
81}