From 0b01870bf406d5e6dc9f079318b48abae8d1c12b Mon Sep 17 00:00:00 2001 From: Dave Brolley Date: Mon, 3 Nov 2003 18:29:57 +0000 Subject: 2003-11-03 Dave Brolley * cache.c (address_interference): Check for higher priority requests in the same pipeline. --- sim/frv/cache.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) (limited to 'sim/frv/cache.c') diff --git a/sim/frv/cache.c b/sim/frv/cache.c index bfefa87..7b2635b 100644 --- a/sim/frv/cache.c +++ b/sim/frv/cache.c @@ -1109,14 +1109,23 @@ address_interference (FRV_CACHE *cache, SI address, FRV_CACHE_REQUEST *req, return 1; } /* If this is not a WAR request, then yield to any WAR requests in - either pipeline. */ + either pipeline or to a higher priority request in the same pipeline. + */ if (req->kind != req_WAR) { for (j = FIRST_STAGE; j < FRV_CACHE_STAGES; ++j) { other_req = cache->pipeline[i].stages[j].request; - if (other_req != NULL && other_req->kind == req_WAR) - return 1; + if (other_req != NULL) + { + if (other_req->kind == req_WAR) + return 1; + if (i == pipe + && (address == (other_req->address & line_mask) + || address == all_address) + && priority > other_req->priority) + return 1; + } } } } -- cgit v1.1