From: Steve Reinhardt Date: Mon, 24 Mar 2008 05:08:02 +0000 (-0400) Subject: Delete the Request for a no-response Packet X-Git-Tag: copyright_update~12 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=623dd7ed3a66e71e241dc8365c079cb5b42fa918;p=gem5.git Delete the Request for a no-response Packet when the Packet is deleted, since the requester can't possibly do it. --HG-- extra : convert_revision : 8571b144ecb3c70efc06d09faa8b3161fb58352d --- diff --git a/src/mem/packet.hh b/src/mem/packet.hh index 7aad9de98..a278a3945 100644 --- a/src/mem/packet.hh +++ b/src/mem/packet.hh @@ -455,7 +455,15 @@ class Packet : public FastAlloc, public Printable /** Destructor. */ ~Packet() - { if (staticData || dynamicData) deleteData(); } + { + // If this is a request packet for which there's no response, + // delete the request object here, since the requester will + // never get the chance. + if (req && isRequest() && !needsResponse()) + delete req; + if (staticData || dynamicData) + deleteData(); + } /** Reinitialize packet address and size from the associated * Request object, and reset other fields that may have been diff --git a/src/mem/tport.cc b/src/mem/tport.cc index 9fa27046b..ad5e95909 100644 --- a/src/mem/tport.cc +++ b/src/mem/tport.cc @@ -83,7 +83,6 @@ SimpleTimingPort::recvTiming(PacketPtr pkt) assert(pkt->isResponse()); schedSendTiming(pkt, curTick + latency); } else { - delete pkt->req; delete pkt; }