From fead3ef10057760c977503b3b564048cbfc76ce5 Mon Sep 17 00:00:00 2001 From: George Punter Date: Tue, 25 Oct 2016 09:33:49 +0100 Subject: Fixed subtle bug and changed comment about max RAM size --- src/shared/mips_mem_ram.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/shared/mips_mem_ram.cpp b/src/shared/mips_mem_ram.cpp index 3d4d6d2..81ae63f 100644 --- a/src/shared/mips_mem_ram.cpp +++ b/src/shared/mips_mem_ram.cpp @@ -19,7 +19,7 @@ extern "C" mips_mem_h mips_mem_create_ram( uint32_t cbMem //!< Total number of bytes of ram ){ if(cbMem>0x20000000){ - return 0; // No more than 256MB of RAM + return 0; // No more than 512MB of RAM } uint8_t *data=(uint8_t*)malloc(cbMem); @@ -57,7 +57,7 @@ static mips_error mips_mem_read_write( if(0 != (address % length) ){ return mips_ExceptionInvalidAlignment; } - if((address+length) > mem->length){ // A subtle bug here, maybe? + if((address+length) > mem->length || address > (UINT32_MAX - length)){ // A subtle bug here, maybe? return mips_ExceptionInvalidAddress; } -- cgit