This patch fixes an assert condition that is not true at all
times. There are valid situations that arise in dual-core
dual-workload runs where the assert condition is false. The function
call following the assert however needs to be called only when the
condition is true (a block cannot be invalidated in the tags structure
if has not been allocated in the structure, and the tempBlock is never
allocated). Hence the 'assert' has been replaced with an 'if'.
pkt->assertMemInhibit();
}
// on ReadExReq we give up our copy unconditionally
- assert(blk != tempBlock);
- tags->invalidate(blk);
+ if (blk != tempBlock)
+ tags->invalidate(blk);
blk->invalidate();
} else if (blk->isWritable() && !pending_downgrade
&& !pkt->sharedAsserted() && !pkt->req->isInstFetch()) {
// Do this last in case it deallocates block data or something
// like that
if (invalidate) {
- assert(blk != tempBlock);
- tags->invalidate(blk);
+ if (blk != tempBlock)
+ tags->invalidate(blk);
blk->invalidate();
}