soc/intel/apollolake: Remove PEIM GFX from normal mode and S3 resume

Do not pass VBT table to fsp in normal mode and S3 resume so that
PEIM GFX will not get initialized.

Change-Id: Iab7be3cceb0f80ae0273940b36fdd9c41bdb121e
Signed-off-by: Abhay Kumar <abhay.kumar@intel.com>
Reviewed-on: https://review.coreboot.org/14575
Tested-by: build bot (Jenkins)
Reviewed-by: Martin Roth <martinroth@google.com>
This commit is contained in:
Abhay Kumar 2016-07-14 18:43:54 -07:00 committed by Martin Roth
parent 3707fc2d96
commit ec2947fb07
3 changed files with 26 additions and 2 deletions

View file

@ -194,8 +194,7 @@ static void soc_init(void *data)
struct global_nvs_t *gnvs;
/* Save VBT info and mapping */
if (locate_vbt(&vbt_rdev) != CB_ERR)
vbt = rdev_mmap_full(&vbt_rdev);
vbt = vbt_get(&vbt_rdev);
/* Snapshot the current GPIO IRQ polarities. FSP is setting a
* default policy that doesn't honor boards' requirements. */

View file

@ -15,6 +15,8 @@
#include <cbfs.h>
#include <console/console.h>
#include <arch/acpi.h>
#include <bootmode.h>
#include "vbt.h"
@ -40,3 +42,21 @@ enum cb_err locate_vbt(struct region_device *rdev)
return CB_SUCCESS;
}
void *vbt_get(struct region_device *rdev)
{
void *vbt_data;
/* Normal mode and S3 resume path PEIM GFX init is not needed.
* Passing NULL as VBT will not make PEIM GFX to execute. */
if (acpi_is_wakeup_s3())
return NULL;
if (!display_init_required())
return NULL;
if (locate_vbt(rdev) != CB_ERR) {
vbt_data = rdev_mmap_full(rdev);
return vbt_data;
} else {
return NULL;
}
}

View file

@ -21,4 +21,9 @@
/* locate .vbt file */
enum cb_err locate_vbt(struct region_device *rdev);
/*
* Returns VBT pointer and mapping after checking prerequisites for Pre OS
* Graphics initialization
*/
void *vbt_get(struct region_device *rdev);
#endif