uart: use integer versions of time instead of messing around with floats
This commit is contained in:
@@ -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();
|
||||
|
||||
Reference in New Issue
Block a user