ACPI: Add framework for GNVS initialisation
Provide common initialisation point for setting up GNVS structure before first SMI is triggered. Change-Id: Iccad533c3824d70f6cbae52cc8dd79f142ece944 Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/42423 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
cf06124cc6
commit
e37459ed64
4 changed files with 108 additions and 0 deletions
|
@ -8,6 +8,8 @@ ramstage-y += acpigen_dsm.c
|
|||
ramstage-y += acpigen_ps2_keybd.c
|
||||
ramstage-y += acpigen_usb.c
|
||||
ramstage-y += device.c
|
||||
ramstage-$(CONFIG_CHROMEOS) += chromeos-gnvs.c
|
||||
ramstage-y += gnvs.c
|
||||
ramstage-y += pld.c
|
||||
ramstage-y += sata.c
|
||||
ramstage-y += soundwire.c
|
||||
|
|
18
src/acpi/chromeos-gnvs.c
Normal file
18
src/acpi/chromeos-gnvs.c
Normal file
|
@ -0,0 +1,18 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#include <acpi/acpi_gnvs.h>
|
||||
#include <types.h>
|
||||
#include <ec/google/chromeec/ec.h>
|
||||
#include <vendorcode/google/chromeos/gnvs.h>
|
||||
|
||||
void gnvs_assign_chromeos(void)
|
||||
{
|
||||
chromeos_acpi_t *gnvs_chromeos = gnvs_chromeos_ptr();
|
||||
chromeos_init_chromeos_acpi(gnvs_chromeos);
|
||||
|
||||
/* EC can override to ECFW_RW. */
|
||||
gnvs_chromeos->vbt2 = ACTIVE_ECFW_RO;
|
||||
|
||||
if (CONFIG(EC_GOOGLE_CHROMEEC) && !google_ec_running_ro())
|
||||
gnvs_chromeos->vbt2 = ACTIVE_ECFW_RW;
|
||||
}
|
69
src/acpi/gnvs.c
Normal file
69
src/acpi/gnvs.c
Normal file
|
@ -0,0 +1,69 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#include <acpi/acpi_gnvs.h>
|
||||
#include <acpi/acpigen.h>
|
||||
#include <cbmem.h>
|
||||
#include <console/console.h>
|
||||
#include <string.h>
|
||||
#include <types.h>
|
||||
|
||||
static void *gnvs;
|
||||
|
||||
void *acpi_get_gnvs(void)
|
||||
{
|
||||
if (gnvs)
|
||||
return gnvs;
|
||||
|
||||
gnvs = cbmem_find(CBMEM_ID_ACPI_GNVS);
|
||||
if (gnvs)
|
||||
return gnvs;
|
||||
|
||||
printk(BIOS_ERR, "Unable to locate Global NVS\n");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static void gnvs_assign_cbmc(void)
|
||||
{
|
||||
uint32_t *gnvs_cbmc = gnvs_cbmc_ptr();
|
||||
if (gnvs_cbmc)
|
||||
*gnvs_cbmc = (uintptr_t)cbmem_find(CBMEM_ID_CONSOLE);
|
||||
}
|
||||
|
||||
void *gnvs_get_or_create(void)
|
||||
{
|
||||
size_t gnvs_size;
|
||||
|
||||
if (gnvs)
|
||||
return gnvs;
|
||||
|
||||
gnvs = cbmem_find(CBMEM_ID_ACPI_GNVS);
|
||||
if (gnvs)
|
||||
return gnvs;
|
||||
|
||||
gnvs_size = gnvs_size_of_array();
|
||||
|
||||
gnvs = cbmem_add(CBMEM_ID_ACPI_GNVS, gnvs_size);
|
||||
if (!gnvs)
|
||||
return gnvs;
|
||||
|
||||
memset(gnvs, 0, gnvs_size);
|
||||
|
||||
if (CONFIG(CONSOLE_CBMEM))
|
||||
gnvs_assign_cbmc();
|
||||
|
||||
if (CONFIG(CHROMEOS))
|
||||
gnvs_assign_chromeos();
|
||||
|
||||
return gnvs;
|
||||
}
|
||||
|
||||
void acpi_inject_nvsa(void)
|
||||
{
|
||||
uintptr_t gnvs_address = (uintptr_t)acpi_get_gnvs();
|
||||
if (!gnvs_address)
|
||||
return;
|
||||
|
||||
acpigen_write_scope("\\");
|
||||
acpigen_write_name_dword("NVSA", gnvs_address);
|
||||
acpigen_pop_len();
|
||||
}
|
19
src/include/acpi/acpi_gnvs.h
Normal file
19
src/include/acpi/acpi_gnvs.h
Normal file
|
@ -0,0 +1,19 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef __ACPI_GNVS_H__
|
||||
#define __ACPI_GNVS_H__
|
||||
|
||||
#include <types.h>
|
||||
|
||||
void *acpi_get_gnvs(void);
|
||||
void *gnvs_get_or_create(void);
|
||||
void acpi_inject_nvsa(void);
|
||||
|
||||
void gnvs_assign_chromeos(void);
|
||||
|
||||
/* Platform code must implement these. */
|
||||
size_t gnvs_size_of_array(void);
|
||||
uint32_t *gnvs_cbmc_ptr(void);
|
||||
void *gnvs_chromeos_ptr(void);
|
||||
|
||||
#endif
|
Loading…
Reference in a new issue