Go to the documentation of this file.
   40 #include "debug/Uart.hh" 
   58        DPRINTF(
Uart, 
"UART InterEvent, not interrupting\n");
 
   79     DPRINTF(
Uart, 
"Scheduling IER interrupt for %s, at cycle %lld\n",
 
   81     if (!
event->scheduled())
 
   89     : 
Uart(
p, 
p.pio_size), registers(this, 
name() + 
".registers"),
 
   92       rxIntrEvent([
this]{ processIntrEvent(
RX_INT); }, 
"RX")
 
   97     RegisterBankLE(new_name, 0), rbrThr(rbr, thr), rbrThrDll(rbrThr, dll),
 
   98     ierDlh(ier, dlh), iirFcr(iir, fcr)
 
  105     lcr.writer([
this](
auto &
reg, 
const auto &value) {
 
  119             if (device->dataAvailable())
 
  167         iir.id = (uint8_t)InterruptIds::Rx;
 
  169         iir.id = (uint8_t)InterruptIds::Tx;
 
  184         DPRINTF(
Uart, 
"IER: IER_THRI set, scheduling TX intrrupt\n");
 
  186             DPRINTF(
Uart, 
"-- Interrupting Immediately... %d,%d\n",
 
  195         DPRINTF(
Uart, 
"IER: IER_THRI cleared, descheduling TX intrrupt\n");
 
  204         DPRINTF(
Uart, 
"IER: IER_RDI set, scheduling RX intrrupt\n");
 
  207         DPRINTF(
Uart, 
"IER: IER_RDI cleared, descheduling RX intrrupt\n");
 
  234     DPRINTF(
Uart, 
"Write register %#x value %#x\n", daddr,
 
  
Tick curTick()
The universal simulation clock.
void writeIer(Register< Ier > ®, const Ier &ier)
const uint8_t UART_MCR_LOOP
Tick when() const
Get the time that the event is scheduled.
Addr pioAddr
Address that the device listens to.
void scheduleIntr(Event *event)
RWSwitchedRegister iirFcr
#define UNSERIALIZE_SCALAR(scalar)
AddrRange RangeSize(Addr start, Addr size)
void writeThr(Register8 ®, const uint8_t &data)
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
Registers(Uart8250 *uart, const std::string &new_name)
virtual void write(Addr addr, const void *buf, Addr bytes)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Uart8250(const Params &p)
void schedule(Event &event, Tick when)
AddrRangeList getAddrRanges() const override
Determine the address ranges that this device responds to.
void makeAtomicResponse()
virtual bool dataAvailable() const =0
Check if there is pending data from the serial device.
void addRegisters(std::initializer_list< std::reference_wrapper< RegisterBase >> regs)
virtual void writeData(uint8_t c)=0
Transmit a character from the host interface to the device.
T getRaw() const
Get the data in the packet without byte swapping.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
Tick pioDelay
Delay that the device experinces on an access.
Iir readIir(Register< Iir > ®)
void reschedule(Event &event, Tick when, bool always=false)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
#define SERIALIZE_SCALAR(scalar)
void deschedule(Event &event)
void dataAvailable() override
Inform the uart that there is data available.
virtual void read(Addr addr, void *buf, Addr bytes)
constexpr This & readonly()
void paramOut(CheckpointOut &cp, const std::string &name, ExtMachInst const &machInst)
void serialize(CheckpointOut &cp) const override
Serialize an object.
constexpr This & reader(const ReadFunc &new_reader)
void paramIn(CheckpointIn &cp, const std::string &name, ExtMachInst &machInst)
void processIntrEvent(int intrBit)
EventFunctionWrapper rxIntrEvent
Addr pioSize
Size that the device's address range.
std::ostream CheckpointOut
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
EventFunctionWrapper txIntrEvent
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
virtual uint8_t readData()=0
Read a character from the device.
uint8_t readRbr(Register8 ®)
constexpr This & writer(const WriteFunc &new_writer)
bool scheduled() const
Determine if the current event is scheduled.
T * getPtr()
get a pointer to the data ptr.
Generated on Wed May 4 2022 12:13:58 for gem5 by  doxygen 1.8.17