fix SMC detection when trace cache is not compiled in
This commit is contained in:
parent
45f0c72385
commit
906805bb68
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: icache.cc,v 1.39 2011-01-12 19:53:47 sshwarts Exp $
|
// $Id: icache.cc,v 1.40 2011-01-15 17:08:07 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (c) 2007-2011 Stanislav Shwartsman
|
// Copyright (c) 2007-2011 Stanislav Shwartsman
|
||||||
@ -37,7 +37,6 @@ void flushICaches(void)
|
|||||||
{
|
{
|
||||||
for (unsigned i=0; i<BX_SMP_PROCESSORS; i++) {
|
for (unsigned i=0; i<BX_SMP_PROCESSORS; i++) {
|
||||||
BX_CPU(i)->iCache.flushICacheEntries();
|
BX_CPU(i)->iCache.flushICacheEntries();
|
||||||
BX_CPU(i)->invalidate_prefetch_q();
|
|
||||||
#if BX_SUPPORT_TRACE_CACHE
|
#if BX_SUPPORT_TRACE_CACHE
|
||||||
BX_CPU(i)->async_event |= BX_ASYNC_EVENT_STOP_TRACE;
|
BX_CPU(i)->async_event |= BX_ASYNC_EVENT_STOP_TRACE;
|
||||||
#endif
|
#endif
|
||||||
@ -46,16 +45,18 @@ void flushICaches(void)
|
|||||||
pageWriteStampTable.resetWriteStamps();
|
pageWriteStampTable.resetWriteStamps();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if BX_SUPPORT_TRACE_CACHE
|
|
||||||
|
|
||||||
void handleSMC(bx_phy_address pAddr)
|
void handleSMC(bx_phy_address pAddr)
|
||||||
{
|
{
|
||||||
for (unsigned i=0; i<BX_SMP_PROCESSORS; i++) {
|
for (unsigned i=0; i<BX_SMP_PROCESSORS; i++) {
|
||||||
|
#if BX_SUPPORT_TRACE_CACHE
|
||||||
BX_CPU(i)->async_event |= BX_ASYNC_EVENT_STOP_TRACE;
|
BX_CPU(i)->async_event |= BX_ASYNC_EVENT_STOP_TRACE;
|
||||||
|
#endif
|
||||||
BX_CPU(i)->iCache.handleSMC(pAddr);
|
BX_CPU(i)->iCache.handleSMC(pAddr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if BX_SUPPORT_TRACE_CACHE
|
||||||
|
|
||||||
void BX_CPU_C::serveICacheMiss(bxICacheEntry_c *entry, Bit32u eipBiased, bx_phy_address pAddr)
|
void BX_CPU_C::serveICacheMiss(bxICacheEntry_c *entry, Bit32u eipBiased, bx_phy_address pAddr)
|
||||||
{
|
{
|
||||||
BX_CPU_THIS_PTR iCache.alloc_trace(entry);
|
BX_CPU_THIS_PTR iCache.alloc_trace(entry);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: icache.h,v 1.58 2011-01-12 19:53:47 sshwarts Exp $
|
// $Id: icache.h,v 1.59 2011-01-15 17:08:07 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (c) 2007-2011 Stanislav Shwartsman
|
// Copyright (c) 2007-2011 Stanislav Shwartsman
|
||||||
@ -24,9 +24,7 @@
|
|||||||
#ifndef BX_ICACHE_H
|
#ifndef BX_ICACHE_H
|
||||||
#define BX_ICACHE_H
|
#define BX_ICACHE_H
|
||||||
|
|
||||||
#if BX_SUPPORT_TRACE_CACHE
|
|
||||||
extern void handleSMC(bx_phy_address pAddr);
|
extern void handleSMC(bx_phy_address pAddr);
|
||||||
#endif
|
|
||||||
|
|
||||||
class bxPageWriteStampTable
|
class bxPageWriteStampTable
|
||||||
{
|
{
|
||||||
@ -69,9 +67,7 @@ public:
|
|||||||
Bit32u index = hash(pAddr);
|
Bit32u index = hash(pAddr);
|
||||||
|
|
||||||
if (fineGranularityMapping[index]) {
|
if (fineGranularityMapping[index]) {
|
||||||
#if BX_SUPPORT_TRACE_CACHE
|
|
||||||
handleSMC(pAddr); // one of the CPUs might be running trace from this page
|
handleSMC(pAddr); // one of the CPUs might be running trace from this page
|
||||||
#endif
|
|
||||||
fineGranularityMapping[index] = 0;
|
fineGranularityMapping[index] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -86,9 +82,7 @@ public:
|
|||||||
mask |= 1 << (PAGE_OFFSET((Bit32u) pAddr + len - 1) >> 7);
|
mask |= 1 << (PAGE_OFFSET((Bit32u) pAddr + len - 1) >> 7);
|
||||||
|
|
||||||
if (fineGranularityMapping[index] & mask) {
|
if (fineGranularityMapping[index] & mask) {
|
||||||
#if BX_SUPPORT_TRACE_CACHE
|
|
||||||
handleSMC(pAddr); // one of the CPUs might be running trace from this page
|
handleSMC(pAddr); // one of the CPUs might be running trace from this page
|
||||||
#endif
|
|
||||||
fineGranularityMapping[index] = 0;
|
fineGranularityMapping[index] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -177,9 +171,9 @@ public:
|
|||||||
|
|
||||||
nextPageSplitIndex = (nextPageSplitIndex+1) & (BX_ICACHE_PAGE_SPLIT_ENTRIES-1);
|
nextPageSplitIndex = (nextPageSplitIndex+1) & (BX_ICACHE_PAGE_SPLIT_ENTRIES-1);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
BX_CPP_INLINE void handleSMC(bx_phy_address pAddr);
|
BX_CPP_INLINE void handleSMC(bx_phy_address pAddr);
|
||||||
#endif
|
|
||||||
|
|
||||||
BX_CPP_INLINE void purgeICacheEntries(void);
|
BX_CPP_INLINE void purgeICacheEntries(void);
|
||||||
BX_CPP_INLINE void flushICacheEntries(void);
|
BX_CPP_INLINE void flushICacheEntries(void);
|
||||||
@ -208,18 +202,19 @@ BX_CPP_INLINE void bxICache_c::flushICacheEntries(void)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#if BX_SUPPORT_TRACE_CACHE
|
|
||||||
BX_CPP_INLINE void bxICache_c::handleSMC(bx_phy_address pAddr)
|
BX_CPP_INLINE void bxICache_c::handleSMC(bx_phy_address pAddr)
|
||||||
{
|
{
|
||||||
// TODO: invalidate only entries in same page as pAddr
|
// TODO: invalidate only entries in same page as pAddr
|
||||||
|
|
||||||
pAddr = LPFOf(pAddr);
|
pAddr = LPFOf(pAddr);
|
||||||
|
|
||||||
|
#if BX_SUPPORT_TRACE_CACHE
|
||||||
for (unsigned i=0;i<BX_ICACHE_PAGE_SPLIT_ENTRIES;i++) {
|
for (unsigned i=0;i<BX_ICACHE_PAGE_SPLIT_ENTRIES;i++) {
|
||||||
if (pAddr == pageSplitIndex[i].ppf) {
|
if (pAddr == pageSplitIndex[i].ppf) {
|
||||||
pageSplitIndex[i].ppf = BX_ICACHE_INVALID_PHY_ADDRESS;
|
pageSplitIndex[i].ppf = BX_ICACHE_INVALID_PHY_ADDRESS;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
bxICacheEntry_c *e = get_entry(pAddr, 0);
|
bxICacheEntry_c *e = get_entry(pAddr, 0);
|
||||||
|
|
||||||
@ -227,7 +222,6 @@ BX_CPP_INLINE void bxICache_c::handleSMC(bx_phy_address pAddr)
|
|||||||
if (pAddr == LPFOf(e->pAddr)) e->pAddr = BX_ICACHE_INVALID_PHY_ADDRESS;
|
if (pAddr == LPFOf(e->pAddr)) e->pAddr = BX_ICACHE_INVALID_PHY_ADDRESS;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
extern void flushICaches(void);
|
extern void flushICaches(void);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user