Go to the documentation of this file.
44 #include "debug/Checkpoint.hh"
45 #include "debug/HDLcd.hh"
48 #include "enums/ImageFormat.hh"
51 #include "params/HDLcd.hh"
64 workaroundSwapRB(
p.workaround_swap_rb),
65 workaroundDmaLineCount(
p.workaround_dma_line_count),
67 enableCapture(
p.enable_capture),
68 pixelBufferSize(
p.pixel_buffer_size),
69 virtRefreshRate(
p.virt_refresh_rate),
71 virtRefreshEvent([
this]{ virtRefresh(); },
name()),
73 imgFormat(
p.frame_format),
74 pixelPump(*
this, *
p.pxl_clk,
p.pixel_chunk),
78 vnc->setFrameBuffer(&pixelPump.fb);
84 : statistics::
Group(parent,
"HDLcd"),
85 ADD_STAT(underruns, statistics::units::Count::get(),
86 "Number of buffer underruns")
88 using namespace statistics;
96 DPRINTF(Checkpoint,
"Serializing ARM HDLCD\n");
127 dmaEngine->serializeSection(cp,
"dmaEngine");
133 DPRINTF(Checkpoint,
"Unserializing ARM HDLCD\n");
175 dmaEngine->unserializeSection(cp,
"dmaEngine");
222 "Unhandled read size (address: 0x.4x, size: %u)",
242 "Unhandled read size (address: 0x.4x, size: %u)",
244 const uint32_t
data = pkt->
getLE<uint32_t>();
261 panic(
"HDLCD INT_CLEAR register is Write-Only\n");
288 panic(
"Tried to read HDLCD register that doesn't exist\n",
offset);
297 panic(
"HDLCD VERSION register is read-Only\n");
309 panic(
"HDLCD INT_STATUS register is read-Only\n");
332 if (
bus_options.max_outstanding != old_bus_options.max_outstanding) {
334 "Changing HDLcd outstanding DMA transactions: %d -> %d\n",
340 if (
bus_options.burst_len != old_bus_options.burst_len) {
342 "Changing HDLcd DMA burst flags: 0x%x -> 0x%x\n",
378 const CommandReg new_command(value);
380 if (new_command.enable !=
command.enable) {
382 new_command.enable ?
"on" :
"off");
384 if (new_command.enable) {
408 panic(
"Tried to write HDLCD register that doesn't exist\n",
offset);
416 ByteOrder byte_order =
417 pixel_format.big_endian ? ByteOrder::big : ByteOrder::little;
449 warn(
"Maximum number of outstanding DMA transfers set to 0.");
453 const uint32_t dma_burst_flags =
bus_options.burst_len;
454 const uint32_t dma_burst_len = dma_burst_flags ?
460 const uint32_t dma_lines =
514 const size_t byte_count = line_length *
conv.
length;
522 for (
size_t i = 0;
i < line_length;
i++) {
551 DPRINTF(
HDLcd,
"Buffer underrun, stopping DMA fill.\n");
563 warn(
"HDLCD %u bytes still in FIFO after frame: Ensure that DMA "
564 "and PixelPump configuration is consistent\n",
603 unsigned request_size,
unsigned max_pending,
604 size_t line_size, ssize_t line_pitch,
unsigned num_lines)
609 lineSize(line_size), linePitch(line_pitch), numLines(num_lines),
636 frameEnd =
fb_base + numLines * linePitch;
638 startFill(nextLineAddr, lineSize);
644 nextLineAddr = frameEnd;
653 inform(
"DMA line size: %u bytes", lineSize);
654 inform(
"DMA line pitch: %i bytes", linePitch);
655 inform(
"DMA num lines: %u", numLines);
661 if (nextLineAddr == frameEnd)
666 nextLineAddr += linePitch;
667 if (nextLineAddr != frameEnd)
668 startFill(nextLineAddr, lineSize);
674 parent.intRaise(INT_DMA_END);
682 inform(
"PixelPump width: %u",
t.width);
683 inform(
"PixelPump height: %u",
t.height);
685 inform(
"PixelPump horizontal back porch: %u",
t.hBackPorch);
686 inform(
"PixelPump horizontal fron porch: %u",
t.hFrontPorch);
687 inform(
"PixelPump horizontal fron porch: %u",
t.hSync);
689 inform(
"PixelPump vertical back porch: %u",
t.vBackPorch);
690 inform(
"PixelPump vertical fron porch: %u",
t.vFrontPorch);
691 inform(
"PixelPump vertical fron porch: %u",
t.vSync);
Tick curTick()
The universal simulation clock.
void stop()
Immediately stop pushing pixels.
HDLcdStats(statistics::Group *parent)
std::unique_ptr< ImgWriter > imgWriter
Helper to write out bitmaps.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
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.
void virtRefresh()
Handler for fast frame refresh in KVM-mode.
#define UNSERIALIZE_SCALAR(scalar)
static constexpr size_t MAX_BURST_LEN
max number of beats delivered in one dma burst
AddrRange RangeSize(Addr start, Addr size)
ColorSelectReg red_select
Red color select register.
Buffered DMA engine helper class.
TimingReg h_sync
Horizontal sync width register.
uint32_t int_mask
Interrupt mask register.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
const FlagsType nozero
Don't print if this is zero.
void start()
Starting pushing pixels in timing mode.
void renderFrame()
Render an entire frame in non-caching mode.
TimingReg v_front_porch
Vertical front porch width register.
bool bypassCaches() const
Should caches be bypassed?
PolaritiesReg polarities
Polarities register.
DisplayTimings displayTimings() const
PixelConverter conv
Cached pixel converter, set when the converter is enabled.
void serialize(CheckpointOut &cp) const override
Serialize an object.
Bitfield< 11, 8 > max_outstanding
uint32_t readReg(Addr offset)
void dmaRead(Addr addr, int size, Event *event, uint8_t *data, uint32_t sid, uint32_t ssid, Tick delay=0)
void schedule(Event &event, Tick when)
Pixel toPixel(uint32_t word) const
Get the Pixel representation of a color word.
OutputStream * create(const std::string &name, bool binary=false, bool no_gz=false)
Creates a file in this directory (optionally compressed).
std::string csprintf(const char *format, const Args &...args)
void makeAtomicResponse()
uint32_t fb_line_length
Frame buffer Line length register.
uint32_t intStatus() const
Masked interrupt status register.
std::vector< uint8_t > lineBuffer
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.
PixelFormatReg pixel_format
Pixel format register.
CommandReg command
Command register.
statistics::Scalar underruns
BusOptsReg bus_options
Bus options register.
std::ostream * stream() const
Get the output underlying output stream.
unsigned length
Bytes per pixel when stored in memory (including padding)
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
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.
virtual std::string name() const
#define SERIALIZE_OBJ(obj)
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
int32_t fb_line_pitch
Frame buffer Line pitch register.
uint64_t Tick
Tick count type.
const Tick virtRefreshRate
virtual void clear()=0
Clear a signalled interrupt.
uint32_t int_rawstat
Interrupt raw status register.
ColorSelectReg blue_select
Blue color select register.
std::unique_ptr< ImgWriter > createImgWriter(enums::ImageFormat type, const FrameBuffer *fb)
Factory Function which allocates a ImgWriter object and returns a smart pointer to it.
void serialize(CheckpointOut &cp) const override
Serialize an object.
void updateTimings(const DisplayTimings &timings)
Update frame size using display timing.
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.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
#define SERIALIZE_SCALAR(scalar)
bool active() const
Is the pixel pump active and refreshing the display?
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...
Internal gem5 representation of a Pixel.
Configurable RGB pixel converter.
EventFunctionWrapper virtRefreshEvent
void deschedule(Event &event)
TimingReg v_sync
Vertical sync width register.
static const std::string & currentSection()
Gets the fully-qualified name of the active section.
void writeReg(Addr offset, uint32_t value)
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
void unserialize(CheckpointIn &cp) override
Unserialize an object.
bool sectionExists(const std::string §ion)
virtual void drainResume()
Resume execution after a successful drain.
void intClear(uint32_t ints)
Convenience function to clear interrupts.
OutputStream * pic
Picture of what the current frame buffer looks like.
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.
ArmInterruptPin *const interrupt
PixelConverter pixelConverter() const
const bool workaroundDmaLineCount
void onIdle() override
Last response received callback.
std::vector< Info * > stats
T getLE() const
Get the data in the packet byte swapped from little endian to host endian.
static constexpr uint32_t INT_VSYNC
TimingReg h_front_porch
Horizontal front porch width reg.
constexpr int findMsbSet(uint64_t val)
Returns the bit position of the MSB that is set in the input.
std::ostream CheckpointOut
HDLcd(const HDLcdParams &p)
virtual void raise()=0
Signal an interrupt.
void setLE(T v)
Set the value in the data pointer to v as little endian.
Derived & flags(Flags _flags)
Set the flags and marks this stat to print at the end of simulation.
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....
ColorSelectReg green_select
Green color select register.
TimingReg v_back_porch
Vertical back porch width register.
static constexpr uint32_t INT_UNDERRUN
TimingReg h_back_porch
Horizontal back porch width reg.
bool scheduled() const
Determine if the current event is scheduled.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Wed Jul 28 2021 12:10:25 for gem5 by doxygen 1.8.17