Can the RP2040 output 1080p? I think so, with a little help...

Поделиться
HTML-код
  • Опубликовано: 14 янв 2025

Комментарии • 18

  • @msrblonline
    @msrblonline Год назад +8

    Finally google news recomended some quality content :)

  • @benholroyd5221
    @benholroyd5221 Год назад +2

    I wonder how far you could get with some kind of decompression in the DMA / PIO?
    If you're upscaling low Res graphics that should get you quite far.

    • @TECIST
      @TECIST  Год назад +2

      My sense is pretty far. Any kind of GUI (even the one-way microcontroller to RAM to encoder/transmitter proposed) would need a way to translate the application/OS state to which parts of the frame should be overwritten with what data, so there is already some logic working to keep the state within the MCU, despite the end product being too big to hold in the MCU all at once.
      Before compression, you could go down from RGB888 to RGB565. With some dithering the perceived color depth loss/banding might not be too bad.
      Lower frame rates wouldn't help the size of the 'frame buffer' because it only holds a single frame, *but* might free up some clock cycles to do compression / decompression work. Running on bare metal could eliminate memory cost coming from a runtime/interpreter.
      Image data tolerates lossy compression, so compression ratio can really vary with your image quality standards. Supposedly JPEG can be compressed down to 5% (although it must look 'potato' at that extreme).
      I'm not sure how computationally intense the compression / decompression would be, nor how much could be offloaded to PIO... hmmm... it would be good to keep everything internal to the RP2040.
      To continue (without pixel doubling) via the DVI LUT approach brilliantly demonstrated by Wren6991, you are not only RAM-constrained, but you need more compute power and have little overclock headroom left, which implies a need for multiple RP2040s (there are such projects out there).

  • @RetrospektiveAudio
    @RetrospektiveAudio Год назад +3

    What about DPRAM (Dual-Ported RAM)?

    • @TECIST
      @TECIST  Год назад +2

      Thank you for mentioning DPRAM -- I considered it but didn't mention it in the video. The dual ports would make the read/write timing much simpler. I would have gone with DPRAM if I could locate it in stock at JLCPCB (I was trying to stay within their parts assortment, so the PCB could be fully assembled all in one go).

    • @RetrospektiveAudio
      @RetrospektiveAudio Год назад +1

      @@TECIST but they do global parts sourcing. i can probably help out

    • @bobweiram6321
      @bobweiram6321 Год назад

      Dual port RAM is fairly expensive, but that was a decade ago when I checked. It's eliminates the issue with bus contention which is only an issue if the processor runs out of time due to waiting for access. You can also fire an interrupt to update the frame.

  • @Marc_Wolfe
    @Marc_Wolfe Год назад +1

    SDI to HDMI converters exist. 1 GPIO pin for video and audio.

    • @TECIST
      @TECIST  11 месяцев назад +1

      SDI is very interesting. I hadn't come across it before, but looked into it per your comment. I could see that being used to keep the GPIO pin use low while still being able to bitbang SDI-->HDMI video (where you have a very fast microprocessor / serializer). The headache for the RP2040 is that video bit clocks for higher resolutions are so fast the RP2040 can't be OC'd to keep up with low pin counts, so it needs to parallelize across many pins to have a chance. One pin 1080p video means Gb/sec, which means Ghz bitclock/processor clock, and the highest I've seen the RP2040 going is in the 400Mhz range. Raspberry Pi tried 1Ghz [ www.raspberrypi.com/news/dont-try-this-at-home-overclocking-rp2040-to-1ghz/ ], but TL;DR it was fried after a few benchmark runs.

    • @Marc_Wolfe
      @Marc_Wolfe 11 месяцев назад

      Yeah, I came to the same conclusion. lately I've been struggling with I2S on an ESP32-S3. "E (7) I2S: i2s_set_pin(295): ws_io_num invalid". So much personal tech disappointment over the last few years.

  • @blinking_dodo
    @blinking_dodo Год назад +2

    Why would you want to run at 60fps if the module won't be able to update the screen that fast?
    Just because you can? 🙃

    • @TECIST
      @TECIST  Год назад +3

      Lower frame rates (24/30Hz) just feel too laggy to track cursor movement (I'm thinking of a cursor in applications that are not very demanding, perhaps the PyDOS equivalent of the old MS-DOS text editor).
      The HDMI encoder (SII9022ACNU) pixel input clock for 1080p is 148.5Mhz, which is below the clock speed of the SDRAM and still in the 'mild' overclock range for the RP2040. There are time windows to write to RAM during the HDMI encoder horizontal and vertical blanking intervals. While in theory this could apply *some* updates to each frame, my sense is that you're right, updates would regularly need to be written over the course of multiple frames, resulting in image tearing.
      Also, just because 😂

    • @donovan6320
      @donovan6320 Год назад

      ​@@TECIST or you could just do what most modern GPUs do and use a double buffering setup potentially on two ram chips, but could in theory work on just one, That way your display logic could just happily go about what it's doing while your pi is rendering to the next frame. Or am I misunderstanding something

    • @TECIST
      @TECIST  Год назад

      That could prevent tearing, but at the cost of having to redraw the frame continuously. It is best to think of the RAM here as containing what 'should be on screen' at any given time, rather than single frames. That allows the RP2040 to circumvent the impossibility of keeping a full frame in memory and reduces the redrawing to only changed pixels.

    • @donovan6320
      @donovan6320 Год назад

      ​@@TECIST That being said, it would allow for significantly more time to process... Everything. In theory though, you could just dump the contents into another chip, but I also understand at that point we are talking much more complexity, it was just a suggestion to get more "bang" for the time you have.

  • @fjmazur
    @fjmazur Год назад

    If DVI possible on a rp2040, could we use a esp32 instead? Look more powerful..

    • @TECIST
      @TECIST  Год назад +2

      Yes, although the ESP32 would still require an external PSRAM to keep a large frame in memory -- the good news is that the EP32 ecosystem is relatively graphics-friendly: some dev boards have 8MB PSRAM onboard, LCDs (to 7" 800x480) with an integrated ESP32 are available, and LVGL targets ESP32: github.com/lvgl/lvgl

  • @jrstf
    @jrstf 10 месяцев назад

    I'd rather see a Raspberry Pi zero as GPU with some interface to the less capable processor running my code. That is to say, I want a display and I don't want to do a lot of work.