summaryrefslogtreecommitdiff
path: root/src/dev/ns_gige.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/dev/ns_gige.cc')
-rw-r--r--src/dev/ns_gige.cc38
1 files changed, 17 insertions, 21 deletions
diff --git a/src/dev/ns_gige.cc b/src/dev/ns_gige.cc
index 90eb14acd..9269f7935 100644
--- a/src/dev/ns_gige.cc
+++ b/src/dev/ns_gige.cc
@@ -1138,18 +1138,16 @@ NSGigE::rxKick()
uint32_t &extsts = is64bit ? rxDesc64.extsts : rxDesc32.extsts;
next:
- if (clock) {
- if (rxKickTick > curTick()) {
- DPRINTF(EthernetSM, "receive kick exiting, can't run till %d\n",
- rxKickTick);
+ if (rxKickTick > curTick()) {
+ DPRINTF(EthernetSM, "receive kick exiting, can't run till %d\n",
+ rxKickTick);
- goto exit;
- }
-
- // Go to the next state machine clock tick.
- rxKickTick = curTick() + clockPeriod();
+ goto exit;
}
+ // Go to the next state machine clock tick.
+ rxKickTick = clockEdge(Cycles(1));
+
switch(rxDmaState) {
case dmaReadWaiting:
if (doRxDmaRead())
@@ -1457,7 +1455,7 @@ NSGigE::rxKick()
DPRINTF(EthernetSM, "rx state machine exited rxState=%s\n",
NsRxStateStrings[rxState]);
- if (clock && !rxKickEvent.scheduled())
+ if (!rxKickEvent.scheduled())
schedule(rxKickEvent, rxKickTick);
}
@@ -1586,17 +1584,15 @@ NSGigE::txKick()
uint32_t &extsts = is64bit ? txDesc64.extsts : txDesc32.extsts;
next:
- if (clock) {
- if (txKickTick > curTick()) {
- DPRINTF(EthernetSM, "transmit kick exiting, can't run till %d\n",
- txKickTick);
- goto exit;
- }
-
- // Go to the next state machine clock tick.
- txKickTick = curTick() + clockPeriod();
+ if (txKickTick > curTick()) {
+ DPRINTF(EthernetSM, "transmit kick exiting, can't run till %d\n",
+ txKickTick);
+ goto exit;
}
+ // Go to the next state machine clock tick.
+ txKickTick = clockEdge(Cycles(1));
+
switch(txDmaState) {
case dmaReadWaiting:
if (doTxDmaRead())
@@ -1900,7 +1896,7 @@ NSGigE::txKick()
DPRINTF(EthernetSM, "tx state machine exited txState=%s\n",
NsTxStateStrings[txState]);
- if (clock && !txKickEvent.scheduled())
+ if (!txKickEvent.scheduled())
schedule(txKickEvent, txKickTick);
}
@@ -2015,7 +2011,7 @@ NSGigE::transferDone()
DPRINTF(Ethernet, "transfer complete: data in txFifo...schedule xmit\n");
- reschedule(txEvent, curTick() + clockPeriod(), true);
+ reschedule(txEvent, clockEdge(Cycles(1)), true);
}
bool