diff options
| author | Patrick Williams <iawillia@us.ibm.com> | 2013-03-26 11:23:47 -0500 |
|---|---|---|
| committer | A. Patrick Williams III <iawillia@us.ibm.com> | 2013-06-14 09:09:09 -0500 |
| commit | e89e72d2f8a2efe86acad95ed0769aa7a8fe64ae (patch) | |
| tree | 5541b72a698f58757ab2fe36b1a264fff6bcb3a2 /src/usr/secureboot/base/settings.C | |
| parent | 92255af10842c672550a586d342c67ac1c7e11ca (diff) | |
| download | talos-hostboot-e89e72d2f8a2efe86acad95ed0769aa7a8fe64ae.tar.gz talos-hostboot-e89e72d2f8a2efe86acad95ed0769aa7a8fe64ae.zip | |
Secureboot memory layout support.
* Start kernel in 1/4 cache mode per Secureboot.
* Copy Secureboot header for base image for later use.
* Blind-purge bottom half of cache.
* Add bottom of cache into memory maps for 1/2 cache mode.
RTC: 64762
Change-Id: I1b45f30a2d45c9709d4fd486cfe0ca2ce86b051c
Reviewed-on: http://gfw160.austin.ibm.com:8080/gerrit/3773
Reviewed-by: Michael Baiocchi <baiocchi@us.ibm.com>
Tested-by: Jenkins Server
Reviewed-by: ADAM R. MUHLE <armuhle@us.ibm.com>
Reviewed-by: Daniel M. Crowell <dcrowell@us.ibm.com>
Reviewed-by: A. Patrick Williams III <iawillia@us.ibm.com>
Diffstat (limited to 'src/usr/secureboot/base/settings.C')
| -rw-r--r-- | src/usr/secureboot/base/settings.C | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/src/usr/secureboot/base/settings.C b/src/usr/secureboot/base/settings.C new file mode 100644 index 000000000..dfacf46e7 --- /dev/null +++ b/src/usr/secureboot/base/settings.C @@ -0,0 +1,52 @@ +/* IBM_PROLOG_BEGIN_TAG */ +/* This is an automatically generated prolog. */ +/* */ +/* $Source: src/usr/secureboot/base/settings.C $ */ +/* */ +/* IBM CONFIDENTIAL */ +/* */ +/* COPYRIGHT International Business Machines Corp. 2013 */ +/* */ +/* p1 */ +/* */ +/* Object Code Only (OCO) source materials */ +/* Licensed Internal Code Source Materials */ +/* IBM HostBoot Licensed Internal Code */ +/* */ +/* The source code for this program is not published or otherwise */ +/* divested of its trade secrets, irrespective of what has been */ +/* deposited with the U.S. Copyright Office. */ +/* */ +/* Origin: 30 */ +/* */ +/* IBM_PROLOG_END_TAG */ +#include <errl/errlentry.H> +#include <devicefw/userif.H> + +#include "settings.H" + +namespace SECUREBOOT +{ + const uint64_t Settings::SECURITY_SWITCH_REGISTER = 0x00010005; + const uint64_t + Settings::SECURITY_SWITCH_TRUSTED_BOOT = 0x4000000000000000ull; + + void Settings::_init() + { + errlHndl_t l_errl = NULL; + size_t size = sizeof(iv_regValue); + + // Read / cache security switch setting from processor. + l_errl = deviceRead(TARGETING::MASTER_PROCESSOR_CHIP_TARGET_SENTINEL, + &iv_regValue, size, + DEVICE_SCOM_ADDRESS(SECURITY_SWITCH_REGISTER)); + + // If this errors, we're in bad shape and shouldn't trust anything. + assert(NULL == l_errl); + } + + bool Settings::getEnabled() + { + return 0 != (iv_regValue & SECURITY_SWITCH_TRUSTED_BOOT); + } +} |

