| gem5
    v22.1.0.0
    | 
#include <hdlcd.hh>
 
  
| Classes | |
| class | DmaEngine | 
| struct | HDLcdStats | 
| class | PixelPump | 
| Public Member Functions | |
| HDLcd (const HDLcdParams &p) | |
| void | serialize (CheckpointOut &cp) const override | 
| Serialize an object.  More... | |
| void | unserialize (CheckpointIn &cp) override | 
| Unserialize an object.  More... | |
| void | drainResume () override | 
| Resume execution after a successful drain.  More... | |
| Tick | read (PacketPtr pkt) override | 
| Pure virtual function that the device must implement.  More... | |
| Tick | write (PacketPtr pkt) override | 
| Pure virtual function that the device must implement.  More... | |
| AddrRangeList | getAddrRanges () const override | 
| Every PIO device is obliged to provide an implementation that returns the address ranges the device responds to.  More... | |
| bool | pxlNext (Pixel &p) | 
| size_t | lineNext (std::vector< Pixel >::iterator pixel_it, size_t line_length) | 
| void | pxlVSyncBegin () | 
| void | pxlVSyncEnd () | 
| void | pxlUnderrun () | 
| void | pxlFrameDone () | 
|  Public Member Functions inherited from gem5::AmbaDmaDevice | |
| AmbaDmaDevice (const Params &p, Addr pio_size=0) | |
|  Public Member Functions inherited from gem5::DmaDevice | |
| DmaDevice (const Params &p) | |
| virtual | ~DmaDevice ()=default | 
| void | dmaWrite (Addr addr, int size, Event *event, uint8_t *data, uint32_t sid, uint32_t ssid, Tick delay=0) | 
| void | dmaWrite (Addr addr, int size, Event *event, uint8_t *data, Tick delay=0) | 
| void | dmaRead (Addr addr, int size, Event *event, uint8_t *data, uint32_t sid, uint32_t ssid, Tick delay=0) | 
| void | dmaRead (Addr addr, int size, Event *event, uint8_t *data, Tick delay=0) | 
| bool | dmaPending () const | 
| void | init () override | 
| init() is called after all C++ SimObjects have been created and all ports are connected.  More... | |
| unsigned int | cacheBlockSize () const | 
| Port & | getPort (const std::string &if_name, PortID idx=InvalidPortID) override | 
| Get a port with a given name and index.  More... | |
|  Public Member Functions inherited from gem5::PioDevice | |
| PioDevice (const Params &p) | |
| virtual | ~PioDevice () | 
| void | init () override | 
| init() is called after all C++ SimObjects have been created and all ports are connected.  More... | |
| Port & | getPort (const std::string &if_name, PortID idx=InvalidPortID) override | 
| Get a port with a given name and index.  More... | |
|  Public Member Functions inherited from gem5::ClockedObject | |
| ClockedObject (const ClockedObjectParams &p) | |
| void | serialize (CheckpointOut &cp) const override | 
| Serialize an object.  More... | |
| void | unserialize (CheckpointIn &cp) override | 
| Unserialize an object.  More... | |
|  Public Member Functions inherited from gem5::SimObject | |
| const Params & | params () const | 
| SimObject (const Params &p) | |
| virtual | ~SimObject () | 
| virtual void | loadState (CheckpointIn &cp) | 
| loadState() is called on each SimObject when restoring from a checkpoint.  More... | |
| virtual void | initState () | 
| initState() is called on each SimObject when not restoring from a checkpoint.  More... | |
| virtual void | regProbePoints () | 
| Register probe points for this object.  More... | |
| virtual void | regProbeListeners () | 
| Register probe listeners for this object.  More... | |
| ProbeManager * | getProbeManager () | 
| Get the probe manager for this object.  More... | |
| virtual void | startup () | 
| startup() is the final initialization call before simulation.  More... | |
| DrainState | drain () override | 
| Provide a default implementation of the drain interface for objects that don't need draining.  More... | |
| virtual void | memWriteback () | 
| Write back dirty buffers to memory using functional writes.  More... | |
| virtual void | memInvalidate () | 
| Invalidate the contents of memory buffers.  More... | |
| void | serialize (CheckpointOut &cp) const override | 
| Serialize an object.  More... | |
| void | unserialize (CheckpointIn &cp) override | 
| Unserialize an object.  More... | |
|  Public Member Functions inherited from gem5::EventManager | |
| EventQueue * | eventQueue () const | 
| void | schedule (Event &event, Tick when) | 
| void | deschedule (Event &event) | 
| void | reschedule (Event &event, Tick when, bool always=false) | 
| void | schedule (Event *event, Tick when) | 
| void | deschedule (Event *event) | 
| void | reschedule (Event *event, Tick when, bool always=false) | 
| void | wakeupEventQueue (Tick when=(Tick) -1) | 
| This function is not needed by the usual gem5 event loop but may be necessary in derived EventQueues which host gem5 on other schedulers.  More... | |
| void | setCurTick (Tick newVal) | 
| EventManager (EventManager &em) | |
| Event manger manages events in the event queue.  More... | |
| EventManager (EventManager *em) | |
| EventManager (EventQueue *eq) | |
|  Public Member Functions inherited from gem5::Serializable | |
| Serializable () | |
| virtual | ~Serializable () | 
| void | serializeSection (CheckpointOut &cp, const char *name) const | 
| Serialize an object into a new section.  More... | |
| void | serializeSection (CheckpointOut &cp, const std::string &name) const | 
| void | unserializeSection (CheckpointIn &cp, const char *name) | 
| Unserialize an a child object.  More... | |
| void | unserializeSection (CheckpointIn &cp, const std::string &name) | 
|  Public Member Functions inherited from gem5::Drainable | |
| DrainState | drainState () const | 
| Return the current drain state of an object.  More... | |
| virtual void | notifyFork () | 
| Notify a child process of a fork.  More... | |
|  Public Member Functions inherited from gem5::statistics::Group | |
| Group (Group *parent, const char *name=nullptr) | |
| Construct a new statistics group.  More... | |
| virtual | ~Group () | 
| virtual void | regStats () | 
| Callback to set stat parameters.  More... | |
| virtual void | resetStats () | 
| Callback to reset stats.  More... | |
| virtual void | preDumpStats () | 
| Callback before stats are dumped.  More... | |
| void | addStat (statistics::Info *info) | 
| Register a stat with this group.  More... | |
| const std::map< std::string, Group * > & | getStatGroups () const | 
| Get all child groups associated with this object.  More... | |
| const std::vector< Info * > & | getStats () const | 
| Get all stats associated with this object.  More... | |
| void | addStatGroup (const char *name, Group *block) | 
| Add a stat block as a child of this block.  More... | |
| const Info * | resolveStat (std::string name) const | 
| Resolve a stat by its name within this group.  More... | |
| void | mergeStatGroup (Group *block) | 
| Merge the contents (stats & children) of a block to this block.  More... | |
| Group ()=delete | |
| Group (const Group &)=delete | |
| Group & | operator= (const Group &)=delete | 
|  Public Member Functions inherited from gem5::Named | |
| Named (const std::string &name_) | |
| virtual | ~Named ()=default | 
| virtual std::string | name () const | 
|  Public Member Functions inherited from gem5::Clocked | |
| void | updateClockPeriod () | 
| Update the tick to the current tick.  More... | |
| Tick | clockEdge (Cycles cycles=Cycles(0)) const | 
| Determine the tick when a cycle begins, by default the current one, but the argument also enables the caller to determine a future cycle.  More... | |
| Cycles | curCycle () const | 
| Determine the current cycle, corresponding to a tick aligned to a clock edge.  More... | |
| Tick | nextCycle () const | 
| Based on the clock of the object, determine the start tick of the first cycle that is at least one cycle in the future.  More... | |
| uint64_t | frequency () const | 
| Tick | clockPeriod () const | 
| double | voltage () const | 
| Cycles | ticksToCycles (Tick t) const | 
| Tick | cyclesToTicks (Cycles c) const | 
| Protected Types | |
| enum | RegisterOffset { Version = 0x0000 , Int_RawStat = 0x0010 , Int_Clear = 0x0014 , Int_Mask = 0x0018 , Int_Status = 0x001C , Fb_Base = 0x0100 , Fb_Line_Length = 0x0104 , Fb_Line_Count = 0x0108 , Fb_Line_Pitch = 0x010C , Bus_Options = 0x0110 , V_Sync = 0x0200 , V_Back_Porch = 0x0204 , V_Data = 0x0208 , V_Front_Porch = 0x020C , H_Sync = 0x0210 , H_Back_Porch = 0x0214 , H_Data = 0x0218 , H_Front_Porch = 0x021C , Polarities = 0x0220 , Command = 0x0230 , Pixel_Format = 0x0240 , Red_Select = 0x0244 , Green_Select = 0x0248 , Blue_Select = 0x024C } | 
| ARM HDLcd register offsets.  More... | |
| Protected Member Functions | |
| uint32_t | readReg (Addr offset) | 
| void | writeReg (Addr offset, uint32_t value) | 
| PixelConverter | pixelConverter () const | 
| DisplayTimings | displayTimings () const | 
| void | createDmaEngine () | 
| void | cmdEnable () | 
| void | cmdDisable () | 
| bool | enabled () const | 
| void | setInterrupts (uint32_t ints, uint32_t mask) | 
| Assign new interrupt values and update interrupt signals.  More... | |
| void | intMask (uint32_t mask) | 
| Convenience function to update the interrupt mask.  More... | |
| void | intRaise (uint32_t ints) | 
| Convenience function to raise a new interrupt.  More... | |
| void | intClear (uint32_t ints) | 
| Convenience function to clear interrupts.  More... | |
| uint32_t | intStatus () const | 
| Masked interrupt status register.  More... | |
| void | virtRefresh () | 
| Handler for fast frame refresh in KVM-mode.  More... | |
|  Protected Member Functions inherited from gem5::Drainable | |
| Drainable () | |
| virtual | ~Drainable () | 
| void | signalDrainDone () const | 
| Signal that an object is drained.  More... | |
|  Protected Member Functions inherited from gem5::Clocked | |
| Clocked (ClockDomain &clk_domain) | |
| Create a clocked object and set the clock domain based on the parameters.  More... | |
| Clocked (Clocked &)=delete | |
| Clocked & | operator= (Clocked &)=delete | 
| virtual | ~Clocked () | 
| Virtual destructor due to inheritance.  More... | |
| void | resetClock () const | 
| Reset the object's clock using the current global tick value.  More... | |
| virtual void | clockPeriodUpdated () | 
| A hook subclasses can implement so they can do any extra work that's needed when the clock rate is changed.  More... | |
|  Protected Member Functions inherited from gem5::AmbaDevice | |
| bool | readId (PacketPtr pkt, uint64_t amba_id, Addr pio_addr) | 
| Protected Attributes | |
| VncInput * | vnc | 
| const bool | workaroundSwapRB | 
| const bool | workaroundDmaLineCount | 
| const AddrRangeList | addrRanges | 
| const bool | enableCapture | 
| const Addr | pixelBufferSize | 
| const Tick | virtRefreshRate | 
| std::vector< uint8_t > | lineBuffer | 
| Addr | bypassLineAddress = 0 | 
| EventFunctionWrapper | virtRefreshEvent | 
| std::unique_ptr< ImgWriter > | imgWriter | 
| Helper to write out bitmaps.  More... | |
| enums::ImageFormat | imgFormat | 
| Image Format.  More... | |
| OutputStream * | pic = nullptr | 
| Picture of what the current frame buffer looks like.  More... | |
| PixelConverter | conv = PixelConverter::rgba8888_le | 
| Cached pixel converter, set when the converter is enabled.  More... | |
| PixelPump | pixelPump | 
| std::unique_ptr< DmaEngine > | dmaEngine | 
| gem5::HDLcd::HDLcdStats | stats | 
| HDLCDRegisters | |
| HDLCD register contents. | |
| uint32_t | int_rawstat = 0 | 
| Interrupt raw status register.  More... | |
| uint32_t | int_mask = 0 | 
| Interrupt mask register.  More... | |
| uint32_t | fb_base = 0 | 
| Frame buffer base address register.  More... | |
| uint32_t | fb_line_length = 0 | 
| Frame buffer Line length register.  More... | |
| FbLineCountReg | fb_line_count = 0 | 
| int32_t | fb_line_pitch = 0 | 
| Frame buffer Line pitch register.  More... | |
| BusOptsReg | bus_options = BUS_OPTIONS_RESETV | 
| Bus options register.  More... | |
| TimingReg | v_sync = 0 | 
| Vertical sync width register.  More... | |
| TimingReg | v_back_porch = 0 | 
| Vertical back porch width register.  More... | |
| TimingReg | v_data = 0 | 
| Vertical data width register.  More... | |
| TimingReg | v_front_porch = 0 | 
| Vertical front porch width register.  More... | |
| TimingReg | h_sync = 0 | 
| Horizontal sync width register.  More... | |
| TimingReg | h_back_porch = 0 | 
| Horizontal back porch width reg.  More... | |
| TimingReg | h_data = 0 | 
| Horizontal data width register.  More... | |
| TimingReg | h_front_porch = 0 | 
| Horizontal front porch width reg.  More... | |
| PolaritiesReg | polarities = 0 | 
| Polarities register.  More... | |
| CommandReg | command = 0 | 
| Command register.  More... | |
| PixelFormatReg | pixel_format = 0 | 
| Pixel format register.  More... | |
| ColorSelectReg | red_select = 0 | 
| Red color select register.  More... | |
| ColorSelectReg | green_select = 0 | 
| Green color select register.  More... | |
| ColorSelectReg | blue_select = 0 | 
| Blue color select register.  More... | |
|  Protected Attributes inherited from gem5::AmbaDmaDevice | |
| uint64_t | ambaId | 
| Addr | pioAddr | 
| Addr | pioSize | 
| Tick | pioDelay | 
| ArmInterruptPin *const | interrupt | 
|  Protected Attributes inherited from gem5::DmaDevice | |
| DmaPort | dmaPort | 
|  Protected Attributes inherited from gem5::PioDevice | |
| System * | sys | 
| PioPort< PioDevice > | pioPort | 
| The pioPort that handles the requests for us and provides us requests that it sees.  More... | |
|  Protected Attributes inherited from gem5::SimObject | |
| const SimObjectParams & | _params | 
| Cached copy of the object parameters.  More... | |
|  Protected Attributes inherited from gem5::EventManager | |
| EventQueue * | eventq | 
| A pointer to this object's event queue.  More... | |
| Static Protected Attributes | |
| static constexpr size_t | BUS_OPTIONS_RESETV = 0x408 | 
| Reset value for Bus_Options register.  More... | |
| static constexpr size_t | VERSION_RESETV = 0x1CDC0000 | 
| Reset value for Version register.  More... | |
| static constexpr size_t | AXI_PORT_WIDTH = 8 | 
| AXI port width in bytes.  More... | |
| static constexpr size_t | MAX_BURST_LEN = 16 | 
| max number of beats delivered in one dma burst  More... | |
| static constexpr size_t | MAX_PIXEL_SIZE = 4 | 
| Maximum number of bytes per pixel.  More... | |
|  Static Protected Attributes inherited from gem5::AmbaDevice | |
| static const int | AMBA_PER_ID0 = 0xFE0 | 
| static const int | AMBA_PER_ID1 = 0xFE4 | 
| static const int | AMBA_PER_ID2 = 0xFE8 | 
| static const int | AMBA_PER_ID3 = 0xFEC | 
| static const int | AMBA_CEL_ID0 = 0xFF0 | 
| static const int | AMBA_CEL_ID1 = 0xFF4 | 
| static const int | AMBA_CEL_ID2 = 0xFF8 | 
| static const int | AMBA_CEL_ID3 = 0xFFC | 
| RegisterFieldLayouts | |
| version_minor | |
| Bitfield< 15, 8 > | version_major | 
| Bitfield< 31, 16 > | product_id | 
| fb_line_count | |
| Bitfield< 31, 12 > | reserved_31_12 | 
| burst_len | |
| Bitfield< 7, 5 > | reserved_7_5 | 
| Bitfield< 11, 8 > | max_outstanding | 
| val | |
| Bitfield< 1 > | hsync_polarity | 
| Bitfield< 2 > | dataen_polarity | 
| Bitfield< 3 > | data_polarity | 
| Bitfield< 4 > | pxlclk_polarity | 
| Bitfield< 31, 5 > | reserved_31_5 | 
| Bitfield< 31, 1 > | reserved_31_1 | 
| reserved_2_0 | |
| Bitfield< 4, 3 > | bytes_per_pixel | 
| Bitfield< 30, 5 > | reserved_30_5 | 
| Bitfield< 31 > | big_endian | 
| offset | |
| Bitfield< 11, 8 > | size | 
| Bitfield< 15, 12 > | reserved_15_12 | 
| Bitfield< 23, 16 > | default_color | 
| Bitfield< 31, 24 > | reserved_31_24 | 
| static constexpr uint32_t | INT_BUS_ERROR = (1UL << 1) | 
| static constexpr uint32_t | INT_VSYNC = (1UL << 2) | 
| static constexpr uint32_t | INT_UNDERRUN = (1UL << 3) | 
| BitUnion32 (VersionReg) Bitfield< 7 | |
| EndBitUnion (VersionReg) static const expr uint32_t INT_DMA_END | |
| BitUnion32 (FbLineCountReg) Bitfield< 11 | |
| EndBitUnion (FbLineCountReg) BitUnion32(BusOptsReg) Bitfield< 4 | |
| EndBitUnion (BusOptsReg) BitUnion32(TimingReg) Bitfield< 11 | |
| EndBitUnion (TimingReg) BitUnion32(PolaritiesReg) Bitfield< 0 > vsync_polarity | |
| EndBitUnion (PolaritiesReg) BitUnion32(CommandReg) Bitfield< 0 > enable | |
| EndBitUnion (CommandReg) BitUnion32(PixelFormatReg) Bitfield< 2 | |
| EndBitUnion (PixelFormatReg) BitUnion32(ColorSelectReg) Bitfield< 4 | |
| Additional Inherited Members | |
|  Public Types inherited from gem5::AmbaDmaDevice | |
| typedef AmbaDmaDeviceParams | Params | 
|  Public Types inherited from gem5::DmaDevice | |
| typedef DmaDeviceParams | Params | 
|  Public Types inherited from gem5::PioDevice | |
| using | Params = PioDeviceParams | 
|  Public Types inherited from gem5::ClockedObject | |
| using | Params = ClockedObjectParams | 
| Parameters of ClockedObject.  More... | |
|  Public Types inherited from gem5::SimObject | |
| typedef SimObjectParams | Params | 
|  Static Public Member Functions inherited from gem5::SimObject | |
| static void | serializeAll (const std::string &cpt_dir) | 
| Create a checkpoint by serializing all SimObjects in the system.  More... | |
| static SimObject * | find (const char *name) | 
| Find the SimObject with the given name and return a pointer to it.  More... | |
| static void | setSimObjectResolver (SimObjectResolver *resolver) | 
| There is a single object name resolver, and it is only set when simulation is restoring from checkpoints.  More... | |
| static SimObjectResolver * | getSimObjectResolver () | 
| There is a single object name resolver, and it is only set when simulation is restoring from checkpoints.  More... | |
|  Static Public Member Functions inherited from gem5::Serializable | |
| static const std::string & | currentSection () | 
| Gets the fully-qualified name of the active section.  More... | |
| static void | generateCheckpointOut (const std::string &cpt_dir, std::ofstream &outstream) | 
| Generate a checkpoint file so that the serialization can be routed to it.  More... | |
|  Public Attributes inherited from gem5::ClockedObject | |
| PowerState * | powerState | 
| 
 | protected | 
ARM HDLcd register offsets.
| gem5::HDLcd::HDLcd | ( | const HDLcdParams & | p | ) | 
Definition at line 60 of file hdlcd.cc.
References virtRefresh().
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
Definition at line 487 of file hdlcd.cc.
References gem5::System::bypassCaches(), gem5::EventManager::deschedule(), dmaEngine, pixelPump, gem5::Event::scheduled(), gem5::BasePixelPump::stop(), gem5::PioDevice::sys, and virtRefreshEvent.
Referenced by drainResume(), and writeReg().
| 
 | protected | 
Definition at line 471 of file hdlcd.cc.
References gem5::System::bypassCaches(), gem5::Clocked::clockEdge(), conv, createDmaEngine(), displayTimings(), pixelConverter(), pixelPump, gem5::EventManager::schedule(), gem5::BasePixelPump::start(), gem5::PioDevice::sys, gem5::BasePixelPump::updateTimings(), and virtRefreshEvent.
Referenced by drainResume(), and writeReg().
| 
 | protected | 
Definition at line 446 of file hdlcd.cc.
References AXI_PORT_WIDTH, bus_options, dmaEngine, fb_line_count, fb_line_length, fb_line_pitch, gem5::findMsbSet(), MAX_BURST_LEN, pixelBufferSize, warn, and workaroundDmaLineCount.
Referenced by cmdEnable(), and unserialize().
| 
 | protected | 
Definition at line 437 of file hdlcd.cc.
References h_back_porch, h_data, h_front_porch, h_sync, v_back_porch, v_data, v_front_porch, and v_sync.
Referenced by cmdEnable().
| 
 | overridevirtual | 
Resume execution after a successful drain.
Reimplemented from gem5::Drainable.
Definition at line 182 of file hdlcd.cc.
References gem5::BasePixelPump::active(), gem5::System::bypassCaches(), cmdDisable(), cmdEnable(), gem5::Drainable::drainResume(), enabled(), pixelPump, gem5::VncInput::setDirty(), gem5::PioDevice::sys, and vnc.
| 
 | inlineprotected | 
Definition at line 273 of file hdlcd.hh.
References command.
Referenced by drainResume(), serialize(), and unserialize().
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
| 
 | protected | 
| 
 | inlineoverridevirtual | 
Every PIO device is obliged to provide an implementation that returns the address ranges the device responds to.
Implements gem5::PioDevice.
Definition at line 108 of file hdlcd.hh.
References addrRanges.
| 
 | inlineprotected | 
Convenience function to clear interrupts.
| ints | Set of interrupts to clear | 
Definition at line 324 of file hdlcd.hh.
References int_mask, int_rawstat, and setInterrupts().
Referenced by writeReg().
| 
 | inlineprotected | 
Convenience function to update the interrupt mask.
| mask | New interrupt mask | 
Definition at line 303 of file hdlcd.hh.
References int_rawstat, gem5::mask(), and setInterrupts().
Referenced by writeReg().
| 
 | inlineprotected | 
Convenience function to raise a new interrupt.
| ints | Set of interrupts to raise | 
Definition at line 312 of file hdlcd.hh.
References int_mask, int_rawstat, and setInterrupts().
Referenced by pxlUnderrun(), pxlVSyncBegin(), and writeReg().
| 
 | inlineprotected | 
Masked interrupt status register.
Definition at line 330 of file hdlcd.hh.
References int_mask, and int_rawstat.
Referenced by readReg(), and setInterrupts().
| size_t gem5::HDLcd::lineNext | ( | std::vector< Pixel >::iterator | pixel_it, | 
| size_t | line_length | ||
| ) | 
Definition at line 512 of file hdlcd.cc.
References bypassLineAddress, conv, gem5::DmaDevice::dmaRead(), fb_line_pitch, gem5::ArmISA::i, gem5::PixelConverter::length, lineBuffer, and gem5::PixelConverter::toPixel().
Referenced by gem5::HDLcd::PixelPump::nextLine().
| 
 | protected | 
Definition at line 414 of file hdlcd.cc.
References blue_select, green_select, pixel_format, red_select, and workaroundSwapRB.
Referenced by cmdEnable(), and unserialize().
| void gem5::HDLcd::pxlFrameDone | ( | ) | 
Definition at line 558 of file hdlcd.cc.
References gem5::OutputDirectory::create(), gem5::csprintf(), dmaEngine, DPRINTF, gem5::HDLcd::PixelPump::dumpSettings(), enableCapture, imgWriter, gem5::Named::name(), pic, pixelPump, gem5::VncInput::setDirty(), gem5::simout, gem5::OutputStream::stream(), gem5::PioDevice::sys, vnc, and warn.
Referenced by gem5::HDLcd::PixelPump::onFrameDone().
| bool gem5::HDLcd::pxlNext | ( | Pixel & | p | ) | 
Definition at line 499 of file hdlcd.cc.
References conv, dmaEngine, gem5::PixelConverter::length, MAX_PIXEL_SIZE, gem5::VegaISA::p, and gem5::PixelConverter::toPixel().
Referenced by gem5::HDLcd::PixelPump::nextPixel().
| void gem5::HDLcd::pxlUnderrun | ( | ) | 
Definition at line 549 of file hdlcd.cc.
References dmaEngine, DPRINTF, INT_UNDERRUN, intRaise(), and gem5::statistics::Group::stats.
Referenced by gem5::HDLcd::PixelPump::onUnderrun().
| void gem5::HDLcd::pxlVSyncBegin | ( | ) | 
Definition at line 531 of file hdlcd.cc.
References DPRINTF, INT_VSYNC, and intRaise().
Referenced by gem5::HDLcd::PixelPump::onVSyncBegin().
| void gem5::HDLcd::pxlVSyncEnd | ( | ) | 
Definition at line 538 of file hdlcd.cc.
References gem5::System::bypassCaches(), bypassLineAddress, dmaEngine, DPRINTF, fb_base, and gem5::PioDevice::sys.
Referenced by gem5::HDLcd::PixelPump::onVSyncEnd().
Pure virtual function that the device must implement.
Called when a read command is recieved by the port.
| pkt | Packet describing this request | 
Implements gem5::PioDevice.
Definition at line 215 of file hdlcd.cc.
References data, DPRINTF, gem5::Packet::getAddr(), gem5::Packet::getSize(), gem5::Packet::makeAtomicResponse(), panic_if, gem5::AmbaDmaDevice::pioAddr, gem5::AmbaDmaDevice::pioDelay, gem5::AmbaDmaDevice::pioSize, readReg(), and gem5::Packet::setLE().
| 
 | protected | 
Definition at line 254 of file hdlcd.cc.
References Blue_Select, blue_select, Bus_Options, bus_options, Command, command, Fb_Base, fb_base, Fb_Line_Count, fb_line_count, Fb_Line_Length, fb_line_length, Fb_Line_Pitch, fb_line_pitch, Green_Select, green_select, H_Back_Porch, h_back_porch, H_Data, h_data, H_Front_Porch, h_front_porch, H_Sync, h_sync, Int_Clear, Int_Mask, int_mask, Int_RawStat, int_rawstat, Int_Status, intStatus(), offset, panic, Pixel_Format, pixel_format, Polarities, polarities, Red_Select, red_select, V_Back_Porch, v_back_porch, V_Data, v_data, V_Front_Porch, v_front_porch, V_Sync, v_sync, and Version.
Referenced by read().
| 
 | overridevirtual | 
Serialize an object.
Output an object's state into the current checkpoint section.
| cp | Checkpoint state | 
Implements gem5::Serializable.
Definition at line 94 of file hdlcd.cc.
References blue_select, bus_options, command, dmaEngine, DPRINTF, enabled(), fb_base, fb_line_count, fb_line_length, fb_line_pitch, green_select, h_back_porch, h_data, h_front_porch, h_sync, int_mask, int_rawstat, pixel_format, pixelPump, polarities, red_select, SERIALIZE_OBJ, SERIALIZE_SCALAR, v_back_porch, v_data, v_front_porch, and v_sync.
| 
 | protected | 
Assign new interrupt values and update interrupt signals.
A new interrupt is scheduled signalled if the set of unmasked interrupts goes empty to non-empty. Conversely, if the set of unmasked interrupts goes from non-empty to empty, the interrupt signal is cleared.
| ints | New raw interrupt status | 
| mask | New interrupt mask | 
Definition at line 588 of file hdlcd.cc.
References gem5::ArmInterruptPin::clear(), int_mask, int_rawstat, gem5::AmbaDmaDevice::interrupt, intStatus(), gem5::mask(), and gem5::ArmInterruptPin::raise().
Referenced by intClear(), intMask(), and intRaise().
| 
 | overridevirtual | 
Unserialize an object.
Read an object's state from the current checkpoint section.
| cp | Checkpoint state | 
Implements gem5::Serializable.
Definition at line 131 of file hdlcd.cc.
References blue_select, bus_options, command, conv, createDmaEngine(), gem5::Serializable::currentSection(), dmaEngine, DPRINTF, enabled(), fb_base, fb_line_count, fb_line_length, fb_line_pitch, green_select, h_back_porch, h_data, h_front_porch, h_sync, int_mask, int_rawstat, pixel_format, pixelConverter(), pixelPump, polarities, red_select, gem5::CheckpointIn::sectionExists(), gem5::BasePixelPump::unserialize(), UNSERIALIZE_SCALAR, v_back_porch, v_data, v_front_porch, and v_sync.
| 
 | protected | 
Handler for fast frame refresh in KVM-mode.
Definition at line 207 of file hdlcd.cc.
References gem5::curTick(), pixelPump, gem5::BasePixelPump::renderFrame(), gem5::EventManager::schedule(), virtRefreshEvent, and virtRefreshRate.
Referenced by HDLcd().
Pure virtual function that the device must implement.
Called when a write command is recieved by the port.
| pkt | Packet describing this request | 
Implements gem5::PioDevice.
Definition at line 235 of file hdlcd.cc.
References data, DPRINTF, gem5::Packet::getAddr(), gem5::Packet::getLE(), gem5::Packet::getSize(), gem5::Packet::makeAtomicResponse(), panic_if, gem5::AmbaDmaDevice::pioAddr, gem5::AmbaDmaDevice::pioDelay, gem5::AmbaDmaDevice::pioSize, and writeReg().
| 
 | protected | 
Definition at line 293 of file hdlcd.cc.
References Blue_Select, blue_select, burst_len, Bus_Options, bus_options, cmdDisable(), cmdEnable(), Command, command, DPRINTF, Fb_Base, fb_base, Fb_Line_Count, fb_line_count, Fb_Line_Length, fb_line_length, Fb_Line_Pitch, fb_line_pitch, Green_Select, green_select, H_Back_Porch, h_back_porch, H_Data, h_data, H_Front_Porch, h_front_porch, H_Sync, h_sync, Int_Clear, Int_Mask, Int_RawStat, Int_Status, intClear(), intMask(), intRaise(), max_outstanding, offset, panic, Pixel_Format, pixel_format, Polarities, polarities, Red_Select, red_select, V_Back_Porch, v_back_porch, V_Data, v_data, V_Front_Porch, v_front_porch, V_Sync, v_sync, and Version.
Referenced by write().
| 
 | protected | 
Definition at line 114 of file hdlcd.hh.
Referenced by getAddrRanges().
| 
 | staticconstexprprotected | 
| 
 | protected | 
Blue color select register.
Definition at line 257 of file hdlcd.hh.
Referenced by pixelConverter(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Definition at line 186 of file hdlcd.hh.
Referenced by writeReg().
| 
 | protected | 
Bus options register.
Definition at line 242 of file hdlcd.hh.
Referenced by createDmaEngine(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | staticconstexprprotected | 
| 
 | protected | 
Definition at line 366 of file hdlcd.hh.
Referenced by lineNext(), and pxlVSyncEnd().
| 
 | protected | 
Command register.
Definition at line 253 of file hdlcd.hh.
Referenced by enabled(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Cached pixel converter, set when the converter is enabled.
Definition at line 382 of file hdlcd.hh.
Referenced by cmdEnable(), lineNext(), pxlNext(), and unserialize().
| 
 | protected | 
Definition at line 414 of file hdlcd.hh.
Referenced by cmdDisable(), createDmaEngine(), pxlFrameDone(), pxlNext(), pxlUnderrun(), pxlVSyncEnd(), serialize(), and unserialize().
| 
 | protected | 
Definition at line 115 of file hdlcd.hh.
Referenced by pxlFrameDone().
| 
 | protected | 
Frame buffer base address register.
Definition at line 237 of file hdlcd.hh.
Referenced by pxlVSyncEnd(), readReg(), serialize(), gem5::HDLcd::DmaEngine::startFrame(), unserialize(), and writeReg().
| 
 | protected | 
Definition at line 181 of file hdlcd.hh.
Referenced by createDmaEngine(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Frame buffer Line length register.
Frame buffer Line count register
Definition at line 238 of file hdlcd.hh.
Referenced by createDmaEngine(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Frame buffer Line pitch register.
Definition at line 241 of file hdlcd.hh.
Referenced by createDmaEngine(), lineNext(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Green color select register.
Definition at line 256 of file hdlcd.hh.
Referenced by pixelConverter(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Horizontal back porch width reg.
Definition at line 249 of file hdlcd.hh.
Referenced by displayTimings(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Horizontal data width register.
Definition at line 250 of file hdlcd.hh.
Referenced by displayTimings(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Horizontal front porch width reg.
Definition at line 251 of file hdlcd.hh.
Referenced by displayTimings(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Horizontal sync width register.
Definition at line 248 of file hdlcd.hh.
Referenced by displayTimings(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
| 
 | protected | 
| 
 | staticconstexprprotected | 
| 
 | protected | 
Interrupt mask register.
Definition at line 236 of file hdlcd.hh.
Referenced by intClear(), intRaise(), intStatus(), readReg(), serialize(), setInterrupts(), and unserialize().
| 
 | protected | 
Interrupt raw status register.
Definition at line 235 of file hdlcd.hh.
Referenced by intClear(), intMask(), intRaise(), intStatus(), readReg(), serialize(), setInterrupts(), and unserialize().
| 
 | staticconstexprprotected | 
Definition at line 178 of file hdlcd.hh.
Referenced by pxlUnderrun().
| 
 | staticconstexprprotected | 
Definition at line 177 of file hdlcd.hh.
Referenced by pxlVSyncBegin().
| 
 | protected | 
Definition at line 260 of file hdlcd.hh.
Referenced by lineNext().
| 
 | staticconstexprprotected | 
max number of beats delivered in one dma burst
Definition at line 159 of file hdlcd.hh.
Referenced by createDmaEngine().
| 
 | protected | 
Definition at line 188 of file hdlcd.hh.
Referenced by writeReg().
| 
 | staticconstexprprotected | 
| 
 | protected | 
Definition at line 219 of file hdlcd.hh.
Referenced by readReg(), and writeReg().
| 
 | protected | 
Picture of what the current frame buffer looks like.
Definition at line 379 of file hdlcd.hh.
Referenced by pxlFrameDone().
| 
 | protected | 
Pixel format register.
Definition at line 254 of file hdlcd.hh.
Referenced by pixelConverter(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Definition at line 116 of file hdlcd.hh.
Referenced by createDmaEngine().
| 
 | protected | 
Definition at line 384 of file hdlcd.hh.
Referenced by cmdDisable(), cmdEnable(), drainResume(), pxlFrameDone(), serialize(), unserialize(), and virtRefresh().
| 
 | protected | 
Polarities register.
Definition at line 252 of file hdlcd.hh.
Referenced by readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Red color select register.
Definition at line 255 of file hdlcd.hh.
Referenced by pixelConverter(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
| 
 | protected | 
Vertical back porch width register.
Definition at line 245 of file hdlcd.hh.
Referenced by displayTimings(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Vertical data width register.
Definition at line 246 of file hdlcd.hh.
Referenced by displayTimings(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Vertical front porch width register.
Definition at line 247 of file hdlcd.hh.
Referenced by displayTimings(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | protected | 
Vertical sync width register.
Definition at line 244 of file hdlcd.hh.
Referenced by displayTimings(), readReg(), serialize(), unserialize(), and writeReg().
| 
 | staticconstexprprotected | 
| 
 | protected | 
Definition at line 370 of file hdlcd.hh.
Referenced by cmdDisable(), cmdEnable(), and virtRefresh().
| 
 | protected | 
Definition at line 117 of file hdlcd.hh.
Referenced by virtRefresh().
| 
 | protected | 
Definition at line 111 of file hdlcd.hh.
Referenced by drainResume(), and pxlFrameDone().
| 
 | protected | 
Definition at line 113 of file hdlcd.hh.
Referenced by createDmaEngine().
| 
 | protected | 
Definition at line 112 of file hdlcd.hh.
Referenced by pixelConverter().