diff options
-rw-r--r-- | src/dev/dma_device.hh | 19 | ||||
-rw-r--r-- | src/dev/uart8250.cc | 46 | ||||
-rw-r--r-- | src/dev/uart8250.hh | 19 |
3 files changed, 24 insertions, 60 deletions
diff --git a/src/dev/dma_device.hh b/src/dev/dma_device.hh index f354d3859..0dc79df42 100644 --- a/src/dev/dma_device.hh +++ b/src/dev/dma_device.hh @@ -240,22 +240,6 @@ class DmaCallback : public Drainable } } - /** - * Event invoked by DmaDevice on completion of each chunk. - */ - class DmaChunkEvent : public Event - { - private: - DmaCallback *callback; - - public: - DmaChunkEvent(DmaCallback *cb) - : Event(Default_Pri, AutoDelete), callback(cb) - { } - - void process() { callback->chunkComplete(); } - }; - public: /** @@ -265,7 +249,8 @@ class DmaCallback : public Drainable Event *getChunkEvent() { ++count; - return new DmaChunkEvent(this); + return new EventFunctionWrapper([this]{ chunkComplete(); }, name(), + true); } }; diff --git a/src/dev/uart8250.cc b/src/dev/uart8250.cc index 3c97604fd..482135c7b 100644 --- a/src/dev/uart8250.cc +++ b/src/dev/uart8250.cc @@ -49,27 +49,14 @@ using namespace std; using namespace TheISA; -Uart8250::IntrEvent::IntrEvent(Uart8250 *u, int bit) - : uart(u) -{ - DPRINTF(Uart, "UART Interrupt Event Initilizing\n"); - intrBit = bit; -} - -const char * -Uart8250::IntrEvent::description() const -{ - return "uart interrupt delay"; -} - void -Uart8250::IntrEvent::process() +Uart8250::processIntrEvent(int intrBit) { - if (intrBit & uart->IER) { + if (intrBit & IER) { DPRINTF(Uart, "UART InterEvent, interrupting\n"); - uart->platform->postConsoleInt(); - uart->status |= intrBit; - uart->lastTxInt = curTick(); + platform->postConsoleInt(); + status |= intrBit; + lastTxInt = curTick(); } else DPRINTF(Uart, "UART InterEvent, not interrupting\n"); @@ -89,21 +76,22 @@ Uart8250::IntrEvent::process() * character to send to alleviate this problem. --Ali */ void -Uart8250::IntrEvent::scheduleIntr() +Uart8250::scheduleIntr(Event *event) { static const Tick interval = 225 * SimClock::Int::ns; - DPRINTF(Uart, "Scheduling IER interrupt for %#x, at cycle %lld\n", intrBit, - curTick() + interval); - if (!scheduled()) - uart->schedule(this, curTick() + interval); + DPRINTF(Uart, "Scheduling IER interrupt for %s, at cycle %lld\n", + event->name(), curTick() + interval); + if (!event->scheduled()) + schedule(event, curTick() + interval); else - uart->reschedule(this, curTick() + interval); + reschedule(event, curTick() + interval); } Uart8250::Uart8250(const Params *p) : Uart(p, 8), IER(0), DLAB(0), LCR(0), MCR(0), lastTxInt(0), - txIntrEvent(this, TX_INT), rxIntrEvent(this, RX_INT) + txIntrEvent([this]{ processIntrEvent(TX_INT); }, "TX"), + rxIntrEvent([this]{ processIntrEvent(RX_INT); }, "RX") { } @@ -131,7 +119,7 @@ Uart8250::read(PacketPtr pkt) platform->clearConsoleInt(); if (term->dataAvailable() && (IER & UART_IER_RDI)) - rxIntrEvent.scheduleIntr(); + scheduleIntr(&rxIntrEvent); } else { // dll divisor latch ; } @@ -206,7 +194,7 @@ Uart8250::write(PacketPtr pkt) platform->clearConsoleInt(); status &= ~TX_INT; if (UART_IER_THRI & IER) - txIntrEvent.scheduleIntr(); + scheduleIntr(&txIntrEvent); } else { // dll divisor latch ; } @@ -224,7 +212,7 @@ Uart8250::write(PacketPtr pkt) } else { DPRINTF(Uart, "-- Delaying interrupt... %d,%d\n", curTick(), lastTxInt); - txIntrEvent.scheduleIntr(); + scheduleIntr(&txIntrEvent); } } else @@ -239,7 +227,7 @@ Uart8250::write(PacketPtr pkt) if ((UART_IER_RDI & IER) && term->dataAvailable()) { DPRINTF(Uart, "IER: IER_RDI set, scheduling RX intrrupt\n"); - rxIntrEvent.scheduleIntr(); + scheduleIntr(&rxIntrEvent); } else { DPRINTF(Uart, "IER: IER_RDI cleared, descheduling RX intrrupt\n"); if (rxIntrEvent.scheduled()) diff --git a/src/dev/uart8250.hh b/src/dev/uart8250.hh index ccccac1e9..b7fefc534 100644 --- a/src/dev/uart8250.hh +++ b/src/dev/uart8250.hh @@ -73,20 +73,11 @@ class Uart8250 : public Uart uint8_t IER, DLAB, LCR, MCR; Tick lastTxInt; - class IntrEvent : public Event - { - protected: - Uart8250 *uart; - int intrBit; - public: - IntrEvent(Uart8250 *u, int bit); - virtual void process(); - virtual const char *description() const; - void scheduleIntr(); - }; - - IntrEvent txIntrEvent; - IntrEvent rxIntrEvent; + void processIntrEvent(int intrBit); + void scheduleIntr(Event *event); + + EventFunctionWrapper txIntrEvent; + EventFunctionWrapper rxIntrEvent; public: typedef Uart8250Params Params; |