coreboot-kgpe-d16/src/soc/intel/braswell
Chiranjeevi Rapolu fd016a44bb intel/braswell: allow dirty cache line evictions for SMRAM to stick
The BUNIT controls the policy for read/write access to physical
memory. For the SMRAM range the policy was not allowing dirty
evictions to the SMRAM when the core causing the eviction was not
in SMM mode. This could happen when the SMM handler dirtied a line
and then RSM'd back into non-SMM mode. The cache line was dirtied
while in SMM mode, but when that particular cache line was evicted
it would be silently dropped. Fix this by allowing the BUNIT to honor
writes to the SMRAM range while the evicting core is not in SMM mode.
The core SMRR msr provides the mechanism for disallowing general access
to the SMRAM region while it is not in SMM mode.

BUG=chrome-os-partner:43091
BRANCH=None
TEST=Run suspend_stress_test and ensure there is no hang SMI handler
on suspend-path.
Signed-off-by: Chiranjeevi Rapolu <chiranjeevi.rapolu@intel.com>

Change-Id: Ie794aa3afd54b5e21d0d59a2a7388d507f233537
Signed-off-by: Patrick Georgi <patrick@georgi-clan.de>
Original-Commit-Id: 9c481ab339b4e5ab063e2c32b1f0a48b521142b2
Original-Change-Id: I3e7d41c794c6168eb2ad4eb047675bdb1728f72f
Original-Reviewed-on: https://chromium-review.googlesource.com/292890
Original-Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Original-Commit-Queue: Hannah Williams <hannah.williams@intel.com>
Original-Tested-by: Hannah Williams <hannah.williams@intel.com>
Reviewed-on: http://review.coreboot.org/11412
Tested-by: build bot (Jenkins)
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
2015-08-29 07:10:52 +00:00
..
acpi intel/braswell: Adding conditional statements to turn on/off DPTF WIFI and WWAN 2015-08-29 07:10:19 +00:00
bootblock Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
include/soc intel/braswell: allow dirty cache line evictions for SMRAM to stick 2015-08-29 07:10:52 +00:00
microcode Braswell: Use CBFS image type name 2015-07-14 20:28:13 +02:00
romstage Braswell: Update to end of June. 2015-07-06 18:45:23 +02:00
acpi.c Braswell: Update to end of June. 2015-07-06 18:45:23 +02:00
chip.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
chip.h intel/braswell: fix build 2015-07-29 19:26:34 +02:00
cpu.c intel/braswell: allow dirty cache line evictions for SMRAM to stick 2015-08-29 07:10:52 +00:00
elog.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
emmc.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
gfx.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
gpio.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
gpio_support.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
hda.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
iosf.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
Kconfig intel/braswell: remove CBFS_SIZE option in SoC directory 2015-08-29 07:09:38 +00:00
lpc_init.c Braswell: Update to end of June. 2015-07-06 18:45:23 +02:00
lpe.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
lpss.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
Makefile.inc soc/*/Makefile.inc: Do not add soc/common as a subdir 2015-08-28 20:40:37 +00:00
memmap.c intel/common: fix stage_cache_external_region() 2015-08-14 15:19:31 +02:00
northcluster.c intel fsp: remove CHIPSET_RESERVED_MEM_BYTES 2015-07-21 20:09:31 +02:00
pcie.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
placeholders.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
pmutil.c Braswell: Update to end of June. 2015-07-06 18:45:23 +02:00
ramstage.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
sata.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
scc.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
sd.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
smihandler.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
smm.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
southcluster.c Braswell: Update the ACPI tables 2015-07-06 18:44:38 +02:00
spi.c Braswell: Update to end of June. 2015-07-06 18:45:23 +02:00
spi_loading.c Braswell: Add Braswell SOC support 2015-06-25 21:50:48 +02:00
tsc_freq.c Braswell: Update to end of June. 2015-07-06 18:45:23 +02:00