mirror of
https://github.com/corda/corda.git
synced 2025-01-19 11:16:54 +00:00
update CLoader::is_relocation_page to check the array index is out of range. Signed-off-by Yu Yuan yuan.yu@intel.com
This commit is contained in:
parent
30b4f9ea09
commit
dc3125fe2e
@ -433,15 +433,15 @@ bool CLoader::is_enclave_buffer(uint64_t offset, uint64_t size)
|
||||
// is_relocation_page returns true if the specified RVA is a writable relocation page based on the bitmap.
|
||||
bool CLoader::is_relocation_page(const uint64_t rva, vector<uint8_t> *bitmap)
|
||||
{
|
||||
if(bitmap && bitmap->size())
|
||||
uint64_t page_frame = rva >> SE_PAGE_SHIFT;
|
||||
//NOTE:
|
||||
// Current enclave size is not beyond 128G, so the type-casting from (uint64>>15) to (size_t) is OK.
|
||||
// In the future, if the max enclave size is extended to beyond (1<<49), this type-casting will not work.
|
||||
// It only impacts the enclave signing process. (32bit signing tool to sign 64 bit enclaves)
|
||||
size_t index = (size_t)(page_frame / 8);
|
||||
if(bitmap && (index < bitmap->size()))
|
||||
{
|
||||
uint64_t page_frame = rva >> SE_PAGE_SHIFT;
|
||||
|
||||
//NOTE:
|
||||
// Current enclave size is not beyond 64G, so the type-casting from (uint64>>15) to (size_t) is OK.
|
||||
// In the future, if the max enclave size is extended to beyond (1<<49), this type-casting will not work.
|
||||
// It only impacts the enclave signing process. (32bit signing tool to sign 64 bit enclaves)
|
||||
return ((*bitmap)[(size_t)(page_frame / 8)] & (1 << (page_frame % 8)));
|
||||
return ((*bitmap)[index] & (1 << (page_frame % 8)));
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user