Go to the documentation of this file.
73 #ifndef __DEV_ARM_HDLCD_HH__
74 #define __DEV_ARM_HDLCD_HH__
97 HDLcd(
const HDLcdParams &
p);
175 static constexpr uint32_t INT_DMA_END = (1UL << 0);
198 Bitfield<0> vsync_polarity;
346 size_t line_length)
override
391 unsigned request_size,
unsigned max_pending,
392 size_t line_size, ssize_t line_pitch,
unsigned num_lines);
size_t nextLine(std::vector< Pixel >::iterator pixel_it, size_t line_length) override
Get the next line of pixels directly from memory.
This is a simple scalar statistic, like a counter.
const AddrRangeList addrRanges
Bitfield< 31, 5 > reserved_31_5
HDLcdStats(statistics::Group *parent)
Bitfield< 3 > data_polarity
std::unique_ptr< ImgWriter > imgWriter
Helper to write out bitmaps.
static constexpr size_t AXI_PORT_WIDTH
AXI port width in bytes.
size_t lineNext(std::vector< Pixel >::iterator pixel_it, size_t line_length)
TimingReg v_data
Vertical data width register.
gem5::HDLcd::HDLcdStats stats
void virtRefresh()
Handler for fast frame refresh in KVM-mode.
static constexpr size_t MAX_BURST_LEN
max number of beats delivered in one dma burst
bool nextPixel(Pixel &p) override
Get the next pixel from the scan line buffer.
Bitfield< 31, 16 > product_id
ColorSelectReg red_select
Red color select register.
Buffered DMA engine helper class.
TimingReg h_sync
Horizontal sync width register.
PixelPump(HDLcd &p, ClockDomain &pxl_clk, unsigned pixel_chunk)
uint32_t int_mask
Interrupt mask register.
TimingReg v_front_porch
Vertical front porch width register.
Bitfield< 31, 12 > reserved_31_12
PolaritiesReg polarities
Polarities register.
DisplayTimings displayTimings() const
RegisterOffset
ARM HDLcd register offsets.
PixelConverter conv
Cached pixel converter, set when the converter is enabled.
Bitfield< 11, 8 > max_outstanding
uint32_t readReg(Addr offset)
uint32_t fb_line_length
Frame buffer Line length register.
uint32_t intStatus() const
Masked interrupt status register.
Bitfield< 4, 3 > bytes_per_pixel
std::vector< uint8_t > lineBuffer
Bitfield< 15, 8 > version_major
constexpr uint64_t mask(unsigned nbits)
Generate a 64-bit mask of 'nbits' 1s, right justified.
void startFrame(Addr fb_base)
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
Bitfield< 7, 5 > reserved_7_5
PixelFormatReg pixel_format
Pixel format register.
size_t size() const
Get the amount of data stored in the FIFO.
CommandReg command
Command register.
statistics::Scalar underruns
BusOptsReg bus_options
Bus options register.
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
static constexpr uint32_t INT_BUS_ERROR
void onVSyncEnd() override
Callback on the first pixel of the line after the end VSync region (typically the first pixel of the ...
void serialize(CheckpointOut &cp) const override
Serialize an object.
void onEndOfBlock() override
End of block callback.
std::unique_ptr< DmaEngine > dmaEngine
TimingReg h_data
Horizontal data width register.
void onFrameDone() override
Finished displaying the visible region of a frame.
The ClockDomain provides clock to group of clocked objects bundled under the same clock domain.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
EndBitUnion(VersionReg) static const expr uint32_t INT_DMA_END
int32_t fb_line_pitch
Frame buffer Line pitch register.
uint64_t Tick
Tick count type.
const Tick virtRefreshRate
uint32_t int_rawstat
Interrupt raw status register.
ColorSelectReg blue_select
Blue color select register.
Bitfield< 31 > big_endian
void serialize(CheckpointOut &cp) const override
Serialize an object.
void drainResume() override
Resume execution after a successful drain.
uint32_t fb_base
Frame buffer base address register.
DmaEngine(HDLcd &_parent, size_t size, unsigned request_size, unsigned max_pending, size_t line_size, ssize_t line_pitch, unsigned num_lines)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Bitfield< 1 > hsync_polarity
void onUnderrun(unsigned x, unsigned y) override
Buffer underrun occurred on a frame.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Bitfield< 23, 16 > default_color
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
Internal gem5 representation of a Pixel.
Configurable RGB pixel converter.
EventFunctionWrapper virtRefreshEvent
TimingReg v_sync
Vertical sync width register.
Bitfield< 4 > pxlclk_polarity
void writeReg(Addr offset, uint32_t value)
static constexpr size_t BUS_OPTIONS_RESETV
Reset value for Bus_Options register.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void intClear(uint32_t ints)
Convenience function to clear interrupts.
Bitfield< 2 > dataen_polarity
Overload hash function for BasicBlockRange type.
OutputStream * pic
Picture of what the current frame buffer looks like.
Bitfield< 31, 1 > reserved_31_1
void intRaise(uint32_t ints)
Convenience function to raise a new interrupt.
const Addr pixelBufferSize
static constexpr size_t MAX_PIXEL_SIZE
Maximum number of bytes per pixel.
Bitfield< 30, 5 > reserved_30_5
PixelConverter pixelConverter() const
BitUnion32(VersionReg) Bitfield< 7
const bool workaroundDmaLineCount
void onIdle() override
Last response received callback.
enums::ImageFormat imgFormat
Image Format.
static constexpr uint32_t INT_VSYNC
void onVSyncBegin() override
First pixel clock of the first VSync line.
TimingReg h_front_porch
Horizontal front porch width reg.
std::ostream CheckpointOut
HDLcd(const HDLcdParams &p)
void setInterrupts(uint32_t ints, uint32_t mask)
Assign new interrupt values and update interrupt signals.
void intMask(uint32_t mask)
Convenience function to update the interrupt mask.
const bool workaroundSwapRB
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Timing generator for a pixel-based display.
ColorSelectReg green_select
Green color select register.
Bitfield< 31, 24 > reserved_31_24
TimingReg v_back_porch
Vertical back porch width register.
static constexpr size_t VERSION_RESETV
Reset value for Version register.
Bitfield< 15, 12 > reserved_15_12
static constexpr uint32_t INT_UNDERRUN
TimingReg h_back_porch
Horizontal back porch width reg.
static const PixelConverter rgba8888_le
Predefined 32-bit RGB (red in least significant bits, 8 bits/channel, little endian) conversion helpe...
Generated on Wed May 4 2022 12:13:56 for gem5 by doxygen 1.8.17