diff options
author | Jian J Wang <jian.j.wang@intel.com> | 2017-12-05 15:57:38 +0800 |
---|---|---|
committer | Star Zeng <star.zeng@intel.com> | 2017-12-08 14:38:44 +0800 |
commit | 7619eed8aa260c9527d72ccd525ce70060b64f1f (patch) | |
tree | acf708e4852686ac1de7657d4a9f3ee835b88f56 /IntelFrameworkModulePkg/Csm | |
parent | 2b55daaef0f3f53059c5c858ca6fd53b03eb5d4c (diff) | |
download | edk2-7619eed8aa260c9527d72ccd525ce70060b64f1f.zip edk2-7619eed8aa260c9527d72ccd525ce70060b64f1f.tar.gz edk2-7619eed8aa260c9527d72ccd525ce70060b64f1f.tar.bz2 |
IntelFrameworkPkg/LegacyBios.h: Add a macro to guarantee page 0 access
Due to the introduction of NULL pointer detection feature, page 0 will be
disabled if the feature is enabled, which will cause legacy code failed to
update legacy data in page 0. This macro is introduced to make sure the
page 0 is enabled before those code and restore the original status of it
afterwards.
Another reason to introduce this macro is to eliminate the dependency on
the PcdNullPointerDetectionPropertyMask. Because this is a new PCD, it
could cause some backward compatibility issue for some old packages.
This macro will simply check if the page 0 is disabled or not. If it's
disabled, it will enable it before code updating page 0 and disable it
afterwards. Otherwise, this macro will do nothing to page 0.
The usage of the macro will be look like (similar to DEBUG_CODE macro):
ACCESS_PAGE0_CODE(
<code accessing page 0>
);
Cc: Liming Gao <liming.gao@intel.com>
Cc: Michael D Kinney <michael.d.kinney@intel.com>
Cc: Ruiyu Ni <ruiyu.ni@intel.com>
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Jian J Wang <jian.j.wang@intel.com>
Reviewed-by: Ruiyu Ni <ruiyu.ni@intel.com>
Diffstat (limited to 'IntelFrameworkModulePkg/Csm')
0 files changed, 0 insertions, 0 deletions