summaryrefslogtreecommitdiff
path: root/mem/port.hh
diff options
context:
space:
mode:
authorAli Saidi <saidi@eecs.umich.edu>2006-01-31 14:20:39 -0500
committerAli Saidi <saidi@eecs.umich.edu>2006-01-31 14:20:39 -0500
commit4875b3346709d72e0be99fb6ccede65550b91f94 (patch)
treebd71ec62c7a5a74e40ca226a2ac5b4f26c71f81d /mem/port.hh
parenta1033448ead67ea2819d67609c0390aefc865b0f (diff)
downloadgem5-4875b3346709d72e0be99fb6ccede65550b91f94.tar.xz
changed sendresult -> bool,tick,void as appropriate
first crack at io devices code made CpuRequest that derives from Request dev/io_device.cc: dev/io_device.hh: first crack at the classes for Pio and Dma devices dev/platform.hh: We are going to a system pointer to get info about the memory system mem/bus.hh: changed sendresult -> bool,tick,void as appropriate mem/port.hh: changed sendresult -> bool,tick,void as appropriate; removed the sendTiming(pkt,t) call since it is not really implementable in a generic fashion mem/request.hh: pulled items from Request into CpuRequest --HG-- extra : convert_revision : 6213cf2b66417fa023b80884d9e623e78f5aa891
Diffstat (limited to 'mem/port.hh')
-rw-r--r--mem/port.hh32
1 files changed, 6 insertions, 26 deletions
diff --git a/mem/port.hh b/mem/port.hh
index 03f4abac0..81150b2a3 100644
--- a/mem/port.hh
+++ b/mem/port.hh
@@ -87,25 +87,13 @@ class Port
protected:
/** Called to recive a timing call from the peer port. */
- virtual SendResult recvTiming(Packet &pkt) = 0;
-
- /** Virtual function that can be used to handle scheduling an event
- to send the recvTiming at a given time. This is for direct
- connection without a interconnect. The bus will override
- this in it's port class because the bus does the timing.
- This is used to insert timing when an interconnect doesn't
- have it's own event queue.
- */
- virtual SendResult recvTiming(Packet &pkt, Tick t)
- {
- // schedule event to call recvTiming(pkt) @ tick t
- }
+ virtual bool recvTiming(Packet &pkt) = 0;
/** Called to recive a atomic call from the peer port. */
- virtual SendResult recvAtomic(Packet &pkt) = 0;
+ virtual Tick recvAtomic(Packet &pkt) = 0;
/** Called to recive a functional call from the peer port. */
- virtual SendResult recvFunctional(Packet &pkt) = 0;
+ virtual void recvFunctional(Packet &pkt) = 0;
/** Called to recieve a status change from the peer port. */
virtual void recvStatusChange(Status status) = 0;
@@ -146,21 +134,13 @@ class Port
case a cache has a higher priority request come in while waiting for
the bus to arbitrate.
*/
- SendResult sendTiming(Packet &pkt) { return peer->recvTiming(pkt); }
-
- /** This function is identical to the sendTiming function, accept it
- provides a time when the recvTiming should be called. The
- peer->recvTimimng will schedule the event, if it's device handles the
- timing (bus) it will be overloaded by the bus type port to handle it
- properly.
- */
- SendResult sendTiming(Packet &pkt, Tick t) { return peer->recvTiming(pkt, t); }
+ bool sendTiming(Packet &pkt) { return peer->recvTiming(pkt); }
/** Function called by the associated device to send an atomic access,
an access in which the data is moved and the state is updated in one
cycle, without interleaving with other memory accesses.
*/
- SendResult sendAtomic(Packet &pkt)
+ Tick sendAtomic(Packet &pkt)
{ return peer->recvAtomic(pkt); }
/** Function called by the associated device to send a functional access,
@@ -168,7 +148,7 @@ class Port
memory system, without affecting the current state of any block
or moving the block.
*/
- SendResult sendFunctional(Packet &pkt)
+ void sendFunctional(Packet &pkt)
{ return peer->recvFunctional(pkt); }
/** Called by the associated device to send a status change to the device