diff options
author | Steve Reinhardt <stever@eecs.umich.edu> | 2005-10-03 09:13:56 -0400 |
---|---|---|
committer | Steve Reinhardt <stever@eecs.umich.edu> | 2005-10-03 09:13:56 -0400 |
commit | e90332ff7ada8b466bfba276957ad2ffaa82b58a (patch) | |
tree | 93a8e7f1541fefb47cab3efed4878bf687e63c3b | |
parent | 93e60de65647f3324e59b291c35ef2cf3a0fb9a0 (diff) | |
download | gem5-e90332ff7ada8b466bfba276957ad2ffaa82b58a.tar.xz |
Minor cleanup of memtest.
cpu/memtest/memtest.cc:
Call random() consistently (not sometimes rand() and sometimes random()).
Don't bother to call random() for copy-only parameters unless we're
actually doing a copy.
--HG--
extra : convert_revision : 50ef72594ad53ba531584b3c9dde61ac036a4e38
-rw-r--r-- | cpu/memtest/memtest.cc | 29 |
1 files changed, 15 insertions, 14 deletions
diff --git a/cpu/memtest/memtest.cc b/cpu/memtest/memtest.cc index f3e1df3ed..27f790fac 100644 --- a/cpu/memtest/memtest.cc +++ b/cpu/memtest/memtest.cc @@ -236,23 +236,20 @@ MemTest::tick() } //make new request - unsigned cmd = rand() % 100; - unsigned offset1 = random() % size; - unsigned offset2 = random() % size; + unsigned cmd = random() % 100; + unsigned offset = random() % size; unsigned base = random() % 2; uint64_t data = random(); unsigned access_size = random() % 4; - unsigned cacheable = rand() % 100; - unsigned source_align = rand() % 100; - unsigned dest_align = rand() % 100; + unsigned cacheable = random() % 100; //If we aren't doing copies, use id as offset, and do a false sharing //mem tester if (percentCopies == 0) { //We can eliminate the lower bits of the offset, and then use the id //to offset within the blks - offset1 &= ~63; //Not the low order bits - offset1 += id; + offset &= ~63; //Not the low order bits + offset += id; access_size = 0; } @@ -260,12 +257,12 @@ MemTest::tick() if (cacheable < percentUncacheable) { req->flags |= UNCACHEABLE; - req->paddr = uncacheAddr + offset1; + req->paddr = uncacheAddr + offset; } else { - req->paddr = ((base) ? baseAddr1 : baseAddr2) + offset1; + req->paddr = ((base) ? baseAddr1 : baseAddr2) + offset; } - bool probe = (rand() % 2 == 1) && !req->isUncacheable(); - probe = false; + // bool probe = (random() % 2 == 1) && !req->isUncacheable(); + bool probe = false; req->size = 1 << access_size; req->data = new uint8_t[req->size]; @@ -288,7 +285,7 @@ MemTest::tick() if (blockAddr(req->paddr) == traceBlockAddr) { cerr << name() << ": initiating read " - << ((probe)?"probe of ":"access of ") + << ((probe) ? "probe of " : "access of ") << dec << req->size << " bytes from addr 0x" << hex << req->paddr << " (0x" << hex << blockAddr(req->paddr) << ")" @@ -334,7 +331,11 @@ MemTest::tick() } } else { // copy - Addr source = ((base) ? baseAddr1 : baseAddr2) + offset1; + unsigned source_align = random() % 100; + unsigned dest_align = random() % 100; + unsigned offset2 = random() % size; + + Addr source = ((base) ? baseAddr1 : baseAddr2) + offset; Addr dest = ((base) ? baseAddr2 : baseAddr1) + offset2; if (outstandingAddrs.find(source) != outstandingAddrs.end()) return; else outstandingAddrs.insert(source); |