fix SMC detection when trace cache is not compiled in

This commit is contained in:
Stanislav Shwartsman 2011-01-15 17:08:07 +00:00
parent 45f0c72385
commit 906805bb68
2 changed files with 9 additions and 14 deletions

View File

@ -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);

View File

@ -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);