From 8a020d40d3e7c9ecd3a41cfa5ab720080f5a9bbf Mon Sep 17 00:00:00 2001 From: Gabe Black Date: Wed, 28 Nov 2007 14:39:19 -0800 Subject: Make ports that aren't connected to anything fail more gracefully. --HG-- extra : convert_revision : 3803b28fb2fdfd729f01f1a44df2ae02ef83a2fc --- src/mem/port.cc | 58 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) (limited to 'src/mem/port.cc') diff --git a/src/mem/port.cc b/src/mem/port.cc index ba4f23668..2e56d2486 100644 --- a/src/mem/port.cc +++ b/src/mem/port.cc @@ -39,6 +39,64 @@ #include "mem/mem_object.hh" #include "mem/port.hh" +class defaultPeerPortClass: public Port +{ + protected: + void blowUp() + { + fatal("Unconnected port!"); + } + + public: + defaultPeerPortClass() : Port("default_port") + {} + + bool recvTiming(PacketPtr) + { + blowUp(); + return false; + } + + Tick recvAtomic(PacketPtr) + { + blowUp(); + return 0; + } + + void recvFunctional(PacketPtr) + { + blowUp(); + } + + void recvStatusChange(Status) + { + blowUp(); + } + + int deviceBlockSize() + { + blowUp(); + return 0; + } + + void getDeviceAddressRanges(AddrRangeList &, bool &) + { + blowUp(); + } + + bool isDefaultPort() { return true; } + +} defaultPeerPort; + +Port::Port() : peer(&defaultPeerPort), owner(NULL) +{ +} + +Port::Port(const std::string &_name, MemObject *_owner) : + portName(_name), peer(&defaultPeerPort), owner(_owner) +{ +} + void Port::setPeer(Port *port) { -- cgit v1.2.3