From: Nathan Binkert Date: Mon, 1 Mar 2010 03:28:09 +0000 (-0800) Subject: uart: use integer versions of time instead of messing around with floats X-Git-Tag: stable_2012_02_02~1486 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ebdd004eb28b684fd8f41f71954127ecb347704c;p=gem5.git uart: use integer versions of time instead of messing around with floats --- diff --git a/src/dev/uart8250.cc b/src/dev/uart8250.cc index e3eacaaa2..f131ab69f 100644 --- a/src/dev/uart8250.cc +++ b/src/dev/uart8250.cc @@ -90,7 +90,7 @@ Uart8250::IntrEvent::process() void Uart8250::IntrEvent::scheduleIntr() { - static const Tick interval = (Tick)((Clock::Float::s / 2e9) * 450); + static const Tick interval = 225 * Clock::Int::ns; DPRINTF(Uart, "Scheduling IER interrupt for %#x, at cycle %lld\n", intrBit, curTick + interval); if (!scheduled()) @@ -217,8 +217,7 @@ Uart8250::write(PacketPtr pkt) if (UART_IER_THRI & IER) { DPRINTF(Uart, "IER: IER_THRI set, scheduling TX intrrupt\n"); - if (curTick - lastTxInt > - (Tick)((Clock::Float::s / 2e9) * 450)) { + if (curTick - lastTxInt > 225 * Clock::Int::ns) { DPRINTF(Uart, "-- Interrupting Immediately... %d,%d\n", curTick, lastTxInt); txIntrEvent.process();