Siyuan Wang | 80cf7d5 | 2013-07-09 17:42:43 +0800 | [diff] [blame] | 1 | /* |
| 2 | * This file is part of the coreboot project. |
| 3 | * |
Kyösti Mälkki | f21c2ac | 2014-10-19 09:35:18 +0300 | [diff] [blame] | 4 | * Copyright (C) 2011 Advanced Micro Devices, Inc. |
Siyuan Wang | 80cf7d5 | 2013-07-09 17:42:43 +0800 | [diff] [blame] | 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify |
| 7 | * it under the terms of the GNU General Public License as published by |
| 8 | * the Free Software Foundation; version 2 of the License. |
| 9 | * |
| 10 | * This program is distributed in the hope that it will be useful, |
| 11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 13 | * GNU General Public License for more details. |
Siyuan Wang | 80cf7d5 | 2013-07-09 17:42:43 +0800 | [diff] [blame] | 14 | */ |
| 15 | |
Siyuan Wang | 80cf7d5 | 2013-07-09 17:42:43 +0800 | [diff] [blame] | 16 | #ifndef _AGESAWRAPPER_H_ |
| 17 | #define _AGESAWRAPPER_H_ |
| 18 | |
| 19 | #include <stdint.h> |
| 20 | #include "Porting.h" |
| 21 | #include "AGESA.h" |
| 22 | |
Siyuan Wang | 80cf7d5 | 2013-07-09 17:42:43 +0800 | [diff] [blame] | 23 | enum { |
| 24 | PICK_DMI, /* DMI Interface */ |
| 25 | PICK_PSTATE, /* Acpi Pstate SSDT Table */ |
| 26 | PICK_SRAT, /* SRAT Table */ |
| 27 | PICK_SLIT, /* SLIT Table */ |
| 28 | PICK_WHEA_MCE, /* WHEA MCE table */ |
| 29 | PICK_WHEA_CMC, /* WHEA CMV table */ |
| 30 | PICK_ALIB, /* SACPI SSDT table with ALIB implementation */ |
| 31 | PICK_IVRS, /* IOMMU ACPI IVRS(I/O Virtualization Reporting Structure) table */ |
| 32 | }; |
| 33 | |
Edward O'Callaghan | 06ff726 | 2014-07-05 15:24:50 +1000 | [diff] [blame] | 34 | AGESA_STATUS agesawrapper_amdinitreset(void); |
| 35 | AGESA_STATUS agesawrapper_amdinitearly(void); |
| 36 | AGESA_STATUS agesawrapper_amdinitenv(void); |
| 37 | AGESA_STATUS agesawrapper_amdinitlate(void); |
| 38 | AGESA_STATUS agesawrapper_amdinitpost(void); |
| 39 | AGESA_STATUS agesawrapper_amdinitmid(void); |
Kyösti Mälkki | f21c2ac | 2014-10-19 09:35:18 +0300 | [diff] [blame] | 40 | |
Kyösti Mälkki | 1aa35c6 | 2014-10-21 14:19:04 +0300 | [diff] [blame] | 41 | void agesawrapper_trace(AGESA_STATUS ret, AMD_CONFIG_PARAMS *StdHeader, const char *func); |
| 42 | #define AGESA_EVENTLOG(status, stdheader) \ |
| 43 | agesawrapper_trace(status, stdheader, __func__) |
Kyösti Mälkki | f21c2ac | 2014-10-19 09:35:18 +0300 | [diff] [blame] | 44 | |
Kyösti Mälkki | 48518f0 | 2014-11-25 14:20:57 +0200 | [diff] [blame] | 45 | void amd_initcpuio(void); |
| 46 | void amd_initmmio(void); |
Kyösti Mälkki | 4a08e15 | 2014-12-14 19:41:54 +0200 | [diff] [blame] | 47 | void amd_initenv(void); |
Kyösti Mälkki | 48518f0 | 2014-11-25 14:20:57 +0200 | [diff] [blame] | 48 | |
Edward O'Callaghan | 06ff726 | 2014-07-05 15:24:50 +1000 | [diff] [blame] | 49 | AGESA_STATUS agesawrapper_amdinitresume(void); |
Kyösti Mälkki | f21c2ac | 2014-10-19 09:35:18 +0300 | [diff] [blame] | 50 | AGESA_STATUS agesawrapper_amdS3Save(void); |
Edward O'Callaghan | 06ff726 | 2014-07-05 15:24:50 +1000 | [diff] [blame] | 51 | AGESA_STATUS agesawrapper_amds3laterestore(void); |
Kyösti Mälkki | f21c2ac | 2014-10-19 09:35:18 +0300 | [diff] [blame] | 52 | AGESA_STATUS agesawrapper_amdlaterunaptask (UINT32 Func, UINT32 Data, VOID *ConfigPtr); |
| 53 | void *agesawrapper_getlateinitptr (int pick); |
Siyuan Wang | 80cf7d5 | 2013-07-09 17:42:43 +0800 | [diff] [blame] | 54 | |
Edward O'Callaghan | 06ff726 | 2014-07-05 15:24:50 +1000 | [diff] [blame] | 55 | AGESA_STATUS agesawrapper_fchs3earlyrestore(void); |
| 56 | AGESA_STATUS agesawrapper_fchs3laterestore(void); |
Siyuan Wang | 80cf7d5 | 2013-07-09 17:42:43 +0800 | [diff] [blame] | 57 | |
Kyösti Mälkki | 6e74b2c | 2014-12-16 07:34:58 +0200 | [diff] [blame] | 58 | struct OEM_HOOK |
| 59 | { |
| 60 | /* romstage */ |
| 61 | AGESA_STATUS (*InitEarly)(AMD_EARLY_PARAMS *); |
| 62 | AGESA_STATUS (*InitPost)(AMD_POST_PARAMS *); |
Kyösti Mälkki | 296696d | 2014-12-16 09:29:56 +0200 | [diff] [blame] | 63 | |
| 64 | /* ramstage */ |
| 65 | AGESA_STATUS (*InitMid)(AMD_MID_PARAMS *); |
Kyösti Mälkki | 6e74b2c | 2014-12-16 07:34:58 +0200 | [diff] [blame] | 66 | }; |
| 67 | |
| 68 | extern const struct OEM_HOOK OemCustomize; |
| 69 | |
Kyösti Mälkki | 300cace | 2014-12-16 19:50:47 +0200 | [diff] [blame] | 70 | /* For suspend-to-ram support. */ |
| 71 | AGESA_STATUS OemInitResume(AMD_RESUME_PARAMS *ResumeParams); |
| 72 | AGESA_STATUS OemS3LateRestore(AMD_S3LATE_PARAMS *S3LateParams); |
Kyösti Mälkki | bb85f9e | 2015-10-31 18:06:52 +0200 | [diff] [blame] | 73 | AGESA_STATUS OemS3Save(AMD_S3SAVE_PARAMS *S3SaveParams); |
Kyösti Mälkki | 300cace | 2014-12-16 19:50:47 +0200 | [diff] [blame] | 74 | |
Edward O'Callaghan | cd30951 | 2014-06-12 14:29:27 +1000 | [diff] [blame] | 75 | #endif /* _AGESAWRAPPER_H_ */ |