mirror of https://github.com/PCSX2/pcsx2.git
Merge pull request #89 from lioncash/array-bounds
Fix a possibility for out of bound accesses in logging within Cache.cpp
This commit is contained in:
commit
5907bbea6e
|
@ -179,25 +179,24 @@ void writeCache128(u32 mem, const mem128_t* value){
|
||||||
}
|
}
|
||||||
|
|
||||||
u8 readCache8(u32 mem) {
|
u8 readCache8(u32 mem) {
|
||||||
int i, number;
|
int number;
|
||||||
|
|
||||||
i = getFreeCache(mem,0,&number);
|
int i = getFreeCache(mem,0,&number);
|
||||||
CACHE_LOG("readCache %8.8x from %d, way %d QW %x u8 part %x Really Reading %x", mem, i,number, (mem >> 4) & 0x3, (mem&0xf)>>2, (u32)pCache[i].data[number][(mem >> 4) & 0x3].b8._u8[(mem&0xf)]);
|
|
||||||
if(i == -1)
|
if(i == -1)
|
||||||
{
|
{
|
||||||
u32 vmv=vtlbdata.vmap[mem>>VTLB_PAGE_BITS];
|
u32 vmv=vtlbdata.vmap[mem>>VTLB_PAGE_BITS];
|
||||||
s32 ppf=mem+vmv;
|
s32 ppf=mem+vmv;
|
||||||
return *(u8*)ppf;
|
return *(u8*)ppf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CACHE_LOG("readCache %8.8x from %d, way %d QW %x u8 part %x Really Reading %x", mem, i, number, (mem >> 4) & 0x3, (mem & 0xf) >> 2, (u32)pCache[i].data[number][(mem >> 4) & 0x3].b8._u8[(mem & 0xf)]);
|
||||||
return pCache[i].data[number][(mem >> 4) & 0x3].b8._u8[(mem&0xf)];
|
return pCache[i].data[number][(mem >> 4) & 0x3].b8._u8[(mem&0xf)];
|
||||||
}
|
}
|
||||||
|
|
||||||
u16 readCache16(u32 mem) {
|
u16 readCache16(u32 mem) {
|
||||||
int i, number;
|
int number;
|
||||||
|
|
||||||
i = getFreeCache(mem,0,&number);
|
|
||||||
CACHE_LOG("readCache %8.8x from %d, way %d QW %x u16 part %x Really Reading %x", mem, i,number, (mem >> 4) & 0x3, (mem&0xf)>>2, (u32)pCache[i].data[number][(mem >> 4) & 0x3].b8._u16[(mem&0xf)>>1]);
|
|
||||||
|
|
||||||
|
int i = getFreeCache(mem,0,&number);
|
||||||
if(i == -1)
|
if(i == -1)
|
||||||
{
|
{
|
||||||
u32 vmv=vtlbdata.vmap[mem>>VTLB_PAGE_BITS];
|
u32 vmv=vtlbdata.vmap[mem>>VTLB_PAGE_BITS];
|
||||||
|
@ -205,34 +204,37 @@ u16 readCache16(u32 mem) {
|
||||||
return *(u16*)ppf;
|
return *(u16*)ppf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CACHE_LOG("readCache %8.8x from %d, way %d QW %x u16 part %x Really Reading %x", mem, i, number, (mem >> 4) & 0x3, (mem & 0xf) >> 2, (u32)pCache[i].data[number][(mem >> 4) & 0x3].b8._u16[(mem & 0xf) >> 1]);
|
||||||
return pCache[i].data[number][(mem >> 4) & 0x3].b8._u16[(mem&0xf)>>1];
|
return pCache[i].data[number][(mem >> 4) & 0x3].b8._u16[(mem&0xf)>>1];
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 readCache32(u32 mem) {
|
u32 readCache32(u32 mem) {
|
||||||
int i, number;
|
int number;
|
||||||
|
|
||||||
i = getFreeCache(mem,0,&number);
|
int i = getFreeCache(mem,0,&number);
|
||||||
CACHE_LOG("readCache %8.8x from %d, way %d QW %x u32 part %x Really Reading %x", mem, i,number, (mem >> 4) & 0x3, (mem&0xf)>>2, (u32)pCache[i].data[number][(mem >> 4) & 0x3].b8._u32[(mem&0xf)>>2]);
|
|
||||||
if(i == -1)
|
if(i == -1)
|
||||||
{
|
{
|
||||||
u32 vmv=vtlbdata.vmap[mem>>VTLB_PAGE_BITS];
|
u32 vmv=vtlbdata.vmap[mem>>VTLB_PAGE_BITS];
|
||||||
s32 ppf=mem+vmv;
|
s32 ppf=mem+vmv;
|
||||||
return *(u32*)ppf;
|
return *(u32*)ppf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CACHE_LOG("readCache %8.8x from %d, way %d QW %x u32 part %x Really Reading %x", mem, i, number, (mem >> 4) & 0x3, (mem & 0xf) >> 2, (u32)pCache[i].data[number][(mem >> 4) & 0x3].b8._u32[(mem & 0xf) >> 2]);
|
||||||
return pCache[i].data[number][(mem >> 4) & 0x3].b8._u32[(mem&0xf)>>2];
|
return pCache[i].data[number][(mem >> 4) & 0x3].b8._u32[(mem&0xf)>>2];
|
||||||
}
|
}
|
||||||
|
|
||||||
u64 readCache64(u32 mem) {
|
u64 readCache64(u32 mem) {
|
||||||
int i, number;
|
int number;
|
||||||
|
|
||||||
i = getFreeCache(mem,0,&number);
|
int i = getFreeCache(mem,0,&number);
|
||||||
CACHE_LOG("readCache %8.8x from %d, way %d QW %x u64 part %x Really Reading %x_%x", mem, i,number, (mem >> 4) & 0x3, (mem&0xf)>>2, pCache[i].data[number][(mem >> 4) & 0x3].b8._u64[(mem&0xf)>>3]);
|
|
||||||
if(i == -1)
|
if(i == -1)
|
||||||
{
|
{
|
||||||
u32 vmv=vtlbdata.vmap[mem>>VTLB_PAGE_BITS];
|
u32 vmv=vtlbdata.vmap[mem>>VTLB_PAGE_BITS];
|
||||||
s32 ppf=mem+vmv;
|
s32 ppf=mem+vmv;
|
||||||
return *(u64*)ppf;
|
return *(u64*)ppf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CACHE_LOG("readCache %8.8x from %d, way %d QW %x u64 part %x Really Reading %x_%x", mem, i, number, (mem >> 4) & 0x3, (mem & 0xf) >> 2, pCache[i].data[number][(mem >> 4) & 0x3].b8._u64[(mem & 0xf) >> 3]);
|
||||||
return pCache[i].data[number][(mem >> 4) & 0x3].b8._u64[(mem&0xf)>>3];
|
return pCache[i].data[number][(mem >> 4) & 0x3].b8._u64[(mem&0xf)>>3];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue