diff options
author | Iru Cai <mytbk920423@gmail.com> | 2020-02-11 16:43:31 +0800 |
---|---|---|
committer | Iru Cai <mytbk920423@gmail.com> | 2020-02-11 16:43:31 +0800 |
commit | 1595558f39f6724b3f5bd630c68bcb35fe8bf012 (patch) | |
tree | b8f2921c0443e71c6977918a24719632c5be62c0 /src/learning_gem5/part2/simple_object.cc | |
parent | 98b2d7acc57b664996de528e6d32ae8abaee2b99 (diff) | |
download | gem5-1595558f39f6724b3f5bd630c68bcb35fe8bf012.tar.xz |
learning-gem5: memory access example for simple object
Change-Id: I63a68239ac73b2bce3dea5692deac29a3467d27b
Diffstat (limited to 'src/learning_gem5/part2/simple_object.cc')
-rw-r--r-- | src/learning_gem5/part2/simple_object.cc | 53 |
1 files changed, 52 insertions, 1 deletions
diff --git a/src/learning_gem5/part2/simple_object.cc b/src/learning_gem5/part2/simple_object.cc index f340f1327..76dadf9c8 100644 --- a/src/learning_gem5/part2/simple_object.cc +++ b/src/learning_gem5/part2/simple_object.cc @@ -32,12 +32,63 @@ #include <iostream> +#include "mem/packet.hh" +#include "mem/request.hh" +#include "sim/system.hh" + SimpleObject::SimpleObject(SimpleObjectParams *params) : - SimObject(params) + SimObject(params), + masterId(params->system->getMasterId(this)), + memPort(params->name + ".mem_side", this), + isread(params->isread), + event([this] { processEvent(); }, name() + ".event") { std::cout << "Hello World! From a SimObject!" << std::endl; } +void SimpleObject::processEvent() +{ + readAtomic(); +} + +void SimpleObject::readAtomic() +{ + uint32_t val = 0; + + RequestPtr req = std::make_shared<Request>(0x200000, 4, 0, masterId); + PacketPtr pkt = Packet::createRead(req); + + pkt->dataStatic(&val); + // pkt->setData((const uint8_t *)&x); + + Tick t = memPort.sendAtomic(pkt); + std::cout << "sendAtomic read " << t << " ticks." << std::endl; + std::cout << "read value 0x" << std::hex << val << std::endl; +} + +void SimpleObject::writeAtomic() +{ + RequestPtr req = std::make_shared<Request>(0x200000, 4, 0, masterId); + PacketPtr pkt = Packet::createWrite(req); + + uint32_t x = 0xdeadbeef; + pkt->dataStatic(&x); + // pkt->setData((const uint8_t *)&x); + + Tick t = memPort.sendAtomic(pkt); + std::cout << "sendAtomic write " << t << " ticks." << std::endl; +} + +void SimpleObject::startup() +{ + if (!isread) { + writeAtomic(); + } else { + schedule(event, 40000); + } + +} + SimpleObject* SimpleObjectParams::create() { |