ruby: modify the directed tester to read/write streams

The directed tester supports only generating only read or only write accesses. The
patch modifies the tester to support streams that have both read and write accesses.
This commit is contained in:
Nilay Vaish 2012-12-11 10:05:55 -06:00
parent 9b72a0f627
commit c120273708
4 changed files with 21 additions and 13 deletions

View file

@ -52,16 +52,17 @@ parser.add_option("-l", "--requests", metavar="N", default=100,
help="Stop after N requests") help="Stop after N requests")
parser.add_option("-f", "--wakeup_freq", metavar="N", default=10, parser.add_option("-f", "--wakeup_freq", metavar="N", default=10,
help="Wakeup every N cycles") help="Wakeup every N cycles")
parser.add_option("--test-type", type="string", default="SeriesGetx", parser.add_option("--test-type", type="choice", default="SeriesGetx",
help="SeriesGetx|SeriesGets|Invalidate") choices = ["SeriesGetx", "SeriesGets", "SeriesGetMixed",
"Invalidate"],
help = "Type of test")
parser.add_option("--percent-writes", type="int", default=100,
help="percentage of accesses that should be writes")
# #
# Add the ruby specific and protocol specific options # Add the ruby specific and protocol specific options
# #
Ruby.define_options(parser) Ruby.define_options(parser)
execfile(os.path.join(config_root, "common", "Options.py"))
(options, args) = parser.parse_args() (options, args) = parser.parse_args()
if args: if args:
@ -73,10 +74,13 @@ if args:
# #
if options.test_type == "SeriesGetx": if options.test_type == "SeriesGetx":
generator = SeriesRequestGenerator(num_cpus = options.num_cpus, generator = SeriesRequestGenerator(num_cpus = options.num_cpus,
issue_writes = True) percent_writes = 100)
elif options.test_type == "SeriesGets": elif options.test_type == "SeriesGets":
generator = SeriesRequestGenerator(num_cpus = options.num_cpus, generator = SeriesRequestGenerator(num_cpus = options.num_cpus,
issue_writes = False) percent_writes = 0)
elif options.test_type == "SeriesGetMixed":
generator = SeriesRequestGenerator(num_cpus = options.num_cpus,
percent_writes = options.percent_writes)
elif options.test_type == "Invalidate": elif options.test_type == "Invalidate":
generator = InvalidateGenerator(num_cpus = options.num_cpus) generator = InvalidateGenerator(num_cpus = options.num_cpus)
else: else:

View file

@ -42,7 +42,9 @@ class SeriesRequestGenerator(DirectedGenerator):
type = 'SeriesRequestGenerator' type = 'SeriesRequestGenerator'
cxx_header = "cpu/testers/directedtest/SeriesRequestGenerator.hh" cxx_header = "cpu/testers/directedtest/SeriesRequestGenerator.hh"
addr_increment_size = Param.Int(64, "address increment size") addr_increment_size = Param.Int(64, "address increment size")
issue_writes = Param.Bool(True, "issue writes if true, otherwise reads") num_series = Param.UInt32(1,
"number of different address streams to generate")
percent_writes = Param.Percent(50, "percent of access that are writes")
class InvalidateGenerator(DirectedGenerator): class InvalidateGenerator(DirectedGenerator):
type = 'InvalidateGenerator' type = 'InvalidateGenerator'

View file

@ -33,13 +33,13 @@
#include "debug/DirectedTest.hh" #include "debug/DirectedTest.hh"
SeriesRequestGenerator::SeriesRequestGenerator(const Params *p) SeriesRequestGenerator::SeriesRequestGenerator(const Params *p)
: DirectedGenerator(p) : DirectedGenerator(p),
m_addr_increment_size(p->addr_increment_size),
m_percent_writes(p->percent_writes)
{ {
m_status = SeriesRequestGeneratorStatus_Thinking; m_status = SeriesRequestGeneratorStatus_Thinking;
m_active_node = 0; m_active_node = 0;
m_address = 0x0; m_address = 0x0;
m_addr_increment_size = p->addr_increment_size;
m_issue_writes = p->issue_writes;
} }
SeriesRequestGenerator::~SeriesRequestGenerator() SeriesRequestGenerator::~SeriesRequestGenerator()
@ -60,11 +60,13 @@ SeriesRequestGenerator::initiate()
Request *req = new Request(m_address, 1, flags, masterId); Request *req = new Request(m_address, 1, flags, masterId);
Packet::Command cmd; Packet::Command cmd;
if (m_issue_writes) { bool do_write = ((random() % 100) < m_percent_writes);
if (do_write) {
cmd = MemCmd::WriteReq; cmd = MemCmd::WriteReq;
} else { } else {
cmd = MemCmd::ReadReq; cmd = MemCmd::ReadReq;
} }
PacketPtr pkt = new Packet(req, cmd); PacketPtr pkt = new Packet(req, cmd);
uint8_t* dummyData = new uint8_t; uint8_t* dummyData = new uint8_t;
*dummyData = 0; *dummyData = 0;

View file

@ -56,7 +56,7 @@ class SeriesRequestGenerator : public DirectedGenerator
Addr m_address; Addr m_address;
uint32_t m_active_node; uint32_t m_active_node;
uint32_t m_addr_increment_size; uint32_t m_addr_increment_size;
bool m_issue_writes; uint32_t m_percent_writes;
}; };
#endif //__CPU_DIRECTEDTEST_SERIESREQUESTGENERATOR_HH__ #endif //__CPU_DIRECTEDTEST_SERIESREQUESTGENERATOR_HH__