SDRAM Hardware & Firmware Tutorial (STM32) - Phil's Lab #80

Поділитися
Вставка
  • Опубліковано 14 січ 2025

КОМЕНТАРІ • 80

  • @nicestmanintheworld
    @nicestmanintheworld 2 роки тому +28

    Love your channel, can't find a better source for STM32 dev than you!

  • @DjordjeNedic
    @DjordjeNedic 2 роки тому +26

    Instead of reading and writing data using pointers or memcpy, what you can do is modify the linkerscript to create a memory segment at the memory region mapped to SDRAM address range and then use the section attribute on your variables: __attribute___((section("sectionname"))).

  • @PCBWay
    @PCBWay 2 роки тому +11

    As always, informative! 👍

  • @yellowcrescent
    @yellowcrescent 2 роки тому +3

    Awesome video, glad you showed the actual implementation details. Implementing support for DRAM has always been mysterious to me. Glad to see ST's implementation with the FMC is mostly straightforward. I think the H7 also supports interfacing via OctoSPI/Hyperbus for Flash devices, so would be cool to explore that as well.

    • @PhilsLab
      @PhilsLab  2 роки тому +1

      Thanks, Jacob! Yes, I actually have a QSPI Flash memory part attached to the H7 on this board and want to make a video on that on the future as well.

  • @RandomValueToBe
    @RandomValueToBe 2 роки тому +1

    Thank you, I'm willing to learn more about embedded systems, and you are one of those channels where I say thank you for sharing your knowledge. At the moment, when I have the money and time, I will be doing your course about Mixed-Signal Hardware Design.

    • @PhilsLab
      @PhilsLab  2 роки тому

      Thank you very much for your support, Edgar!

  • @m1geo
    @m1geo Рік тому +7

    Your memory test is doing "byte by byte" and uint8_t. But your memory interface is 16bit wide.
    You could very easily achieve double the speed by using 16b words!

  • @xpressivemusic4578
    @xpressivemusic4578 2 роки тому +4

    saving up for your course Phil thank you for the amazing videos

    • @PhilsLab
      @PhilsLab  2 роки тому +1

      Thank you very much for your support! :)

    • @aai2962
      @aai2962 2 роки тому

      Where can I find details about the course ? Is it about FPGA hardware design ?

    • @PhilsLab
      @PhilsLab  2 роки тому

      Right now, I just have two KiCad courses available. One is free (Udemy/YT) and the other via Fedevel Education and covers mixed-signal HW design. I'm working on an FPGA/SoC course to be released Q1 2023.

    • @xpressivemusic4578
      @xpressivemusic4578 2 роки тому

      @@PhilsLab fantastic I'm getting the mixed signal course next month will definitely get the fpga soc course too when it's up. I need to get my Hardware skills up

  • @Sovvyy
    @Sovvyy 2 роки тому

    Another well-explaned tutorial - thanks for sharing your knowledge!

    • @PhilsLab
      @PhilsLab  2 роки тому +1

      Thanks for watching!

  • @sandrainthesky1011
    @sandrainthesky1011 3 місяці тому

    Thıs was very affirming that things might work when I try them.whew! Thank you!

  • @jordanpales3503
    @jordanpales3503 2 роки тому

    Thank you for your videos! When I need to measure the exact execution time of a command, I submit a logical unit for output pin at the start of the command and convert it to a logical zero at the end. Of course the output pin must be configured to the maximum speed I measure the time itself with an oscilloscope or a logic analyzer. It turns out very high accuracy. Sorry for my English, it's not my native language

  • @armenian34
    @armenian34 25 днів тому

    perfect video, thanks alot

  • @Xerox482
    @Xerox482 2 роки тому

    great your channel is amazing keep sharing knowledge . may god give you long life

  • @piranha1337
    @piranha1337 2 роки тому +7

    I think its kind of sad that Altium now "invades" every hw design YT channel. Not that altium is bad, I think it's a very desireable piece of software but it's pricing is definitely not made for hobbists and makers which is the major audience of these kind of channels. I liked the videos where you used KiCad.
    Anyway... Thank you so much for your videos. I'll get my order next week and a good portion of the boards arriving will be based on the knowledge I got from your videos!

    • @m1geo
      @m1geo Рік тому +2

      Agreed. Altium and PCBWay. Lol

    • @xxbatman69xx98
      @xxbatman69xx98 Рік тому

      It’s literally all the same concept though. I am just getting into circuit design and I’ve been using kicad. From my understanding between altium and other software there isn’t anything (circuit wise) that you can do in altium that you can’t in something like kicad.

  • @unperrier
    @unperrier 2 роки тому +1

    There are checks you can implement like checkers, climbing bit, alternating bits, etc IIRC JEDEC has document that describes them. That's what is typically used in BIST tests (I mean ATE silicon testing)
    Also one thing that needs checking is whether the refresh rate is properly programmed by waiting much longer than the refresh rate and reading again. Sometimes it's just outside the value and once in a blue moon a bit will flip. Hard to find except by running those pattern tests with enough time between write and reads.

  • @gaurangvadher493
    @gaurangvadher493 2 роки тому

    Thank you so much this helped a lot!!!! You saved my life

    • @PhilsLab
      @PhilsLab  2 роки тому

      Glad to hear that - thanks for watching!

  • @wissamtedros1339
    @wissamtedros1339 Рік тому

    At 6:22 you mentioned that pin swapping for the FMC data line is possible to make the routing easier, could you please state how? Because the datasheet does not provide alternate function for those pins
    On another note, thank you so much for your valuable videos, they've taught me much and they're always insightful.
    Cheers!

  • @bsodmike
    @bsodmike 10 місяців тому

    Hi Phil, have you shared the full schematic by any chance? Thanks!

  • @alexevivi
    @alexevivi 2 роки тому +2

    Great video! When the new course will be available?

    • @PhilsLab
      @PhilsLab  2 роки тому +3

      Thanks, Alex! I just received the FPGA boards for the course - will hopefully have it ready by start of 2023.

  • @codewithdaniel-1
    @codewithdaniel-1 2 роки тому +1

    Nice work

  • @marek_ryn
    @marek_ryn 2 роки тому

    As always excellent video :) To bad it was not available few months ago :) It took me so much time to collect all necessary information for my STM32 gaming console where I also use SDRAM :) Anyway, the idea to put SDRAM chip underneath microcontroler is excellent and I will definitely use it for next iteration of my project. Thank you Phil for your work!

    • @PhilsLab
      @PhilsLab  2 роки тому +1

      Thanks, Marek! It did take me quite some time as well to piece together various bits of information to get it running. Should hopefully be somewhat of a template for future projects!

  • @arcoshpl
    @arcoshpl Рік тому

    Super video. Next please a video how to debug the FMC if it did not work... :D

  • @szymon4602
    @szymon4602 2 роки тому +1

    Nice content. Thanks.

    • @PhilsLab
      @PhilsLab  2 роки тому

      Thanks for watching!

    • @szymon4602
      @szymon4602 2 роки тому

      @@PhilsLab Are you planning to elaborate on this topic regarding the correct routing of paths for the parallel interface? It would be nice to see something below the BGA and on the 4 layer PCB. Some simple project is best in KiCad with such an interface ...

  • @RixtronixLAB
    @RixtronixLAB 2 роки тому

    Creative video, thanks for sharing :)

  • @isaacclark9825
    @isaacclark9825 2 роки тому +1

    Phil, can you tell me what limits the speed for accessing memory? Is the limit based on the processor?

    • @TheBackyardChemist
      @TheBackyardChemist Рік тому

      If you clock the bus too fast you get garbage data. The same also happens if you do not wait the appropriate amount of time between certain operations because the DRAM chip has internal circuitry that has to settle into a definitive state.

  • @swatty2009
    @swatty2009 2 роки тому +1

    I know this was just a basic test but wouldn't it be faster (factor two) to access the data in 2-byte blocks? Basically using uint16_t instead of uint8_t to utilize the full memory width?

  • @raultanasie2111
    @raultanasie2111 2 роки тому +1

    Great demystifying of the SDRAM ! Question > Can the sdram memory be integrated in the linker script so that it replaces the internal memory ? That would allow straight up initializing variables in it at compile time and using memory allocation commands (malloc), instead of just using pointers to it, which are prone to code design errors.

    • @m1geo
      @m1geo Рік тому

      Yes. You can create memory segments and get the linkerscript to use them.

  • @mortezaghorbani7927
    @mortezaghorbani7927 2 роки тому

    excellent video, How to do bit swapping in code in an efficient way(using SDRAM as an LCD framebuffer)?

  • @gtcollection6933
    @gtcollection6933 2 роки тому

    You should have a look at the Expressif S3 with built-in RAM

  • @markburton3306
    @markburton3306 2 роки тому

    Good stuff

  • @LiveEnjoyment
    @LiveEnjoyment 2 роки тому

    Awesome vid btw

  • @smoua4588
    @smoua4588 Рік тому

    Thank you!

  • @utthamsingh
    @utthamsingh 9 місяців тому

    How can we use multiple buffers??

  • @asmi06
    @asmi06 2 роки тому

    I would suggest repeating these tests, but writing 32 bit values instead of bytes. It should be faster, but I'm curious to see by how much.

  • @LiveEnjoyment
    @LiveEnjoyment 2 роки тому

    Knowing that certain adress pins of a sdram chip might be used for specific funtions and other are just for the adress. Would u recommend pin swapping of the adress pins during routing?

    • @PhilsLab
      @PhilsLab  2 роки тому

      Pin swapping of the address pins is generally not recommended (unless you know what you're doing, or can/will adjust the controller to suit). Address pins aren't just for addressing for some are also even control (even ones labelled as 'just address' pins).

  • @mh-le5ov
    @mh-le5ov 2 роки тому +1

    Does the databus width of the SDRAM chip determine what size data you can store at a time?
    Or will the FMC handle 8, 16 or 32 bit loads/stores for you by making multiple requests?

    • @Sumida2
      @Sumida2 2 роки тому

      FMC handles it.

  • @romyaz1713
    @romyaz1713 4 місяці тому

    noob question: does your read or write command have constant delay?
    or is it variable delay due to SDRAM refresh?

  • @arcoshpl
    @arcoshpl Рік тому

    I am confused about the size of the SDRAM how does the 128Mb correspond to the hex size SDRAM_SIZE 0x1000000

  • @RebelCoderX
    @RebelCoderX 11 місяців тому

    Hi Phil, I'm developing a DSP device as well and I wanted to add some external RAM. I found another SDRAM chip, the Winbond W9825G6KH-6 which is slightly cheaper, has double the capacity, and is already in stock at JLC as well as Mouser. So I wondered why you chose this ISSI part over the Winbond one. I have literally 0 experience in working with these SDRAM parts so maybe there is something I'm not aware of. The winbond chip is 166MHz for instance while your ISSI part is 143MHz. Could it be 166MHz is too fast so that it needs a refresh time which the STM32 can't handle? The 16MB of the ISSI one should really be large enough for me and they have it in stock at mouser so I could experiment with it before going in production, but I wondered if the Winbond SDRAM might also work. (Provided I don't kill it while handsoldering 😅)

  • @ricardo_9726
    @ricardo_9726 2 роки тому

    Where did you get your hands on a stm32h7

    • @PhilsLab
      @PhilsLab  2 роки тому +1

      LCSC has quite a few of them still in stock.

  • @energycsdx
    @energycsdx 2 роки тому

    Did you tested SDRAM read performance? a friend of mine accidentally discovered that it`s know issue that FMC inserts dummy read cycles when reading from SDRAM

    • @PhilsLab
      @PhilsLab  2 роки тому +1

      Haven't gone into too much detail testing the SDRAM performance - will be interesting to see if I run into the same issue.

    • @energycsdx
      @energycsdx 2 роки тому

      @@PhilsLab www.st.com/resource/en/errata_sheet/es0491-stm32h72xx73xx-device-errata-stmicroelectronics.pdf 2.6.1

  • @MSP_TechLab
    @MSP_TechLab 2 роки тому

    0.4 sec for read, isn't it too slow for 90MHz? Perhaps DMA can imrove result.

  • @juanchoavid123
    @juanchoavid123 2 роки тому +1

    Hi Phil! I would like to make this question. Maybe I did not understand that part. When do you tell the microcontroller to use external memory and not the internal RAM? Or is the internal RAM attached to one bank and you changed the bank to bank one corresponding to the external memory? And after that when you are creating a variable, for example, it saves the value in the external memory?
    Thanks a lot for the content I love it so much!

    • @marek_ryn
      @marek_ryn 2 роки тому +1

      External SDRAM is assigned to separate pool of address. Starting 0xC0000000 or 0xD0000000 as I remember correctly. You can just write/read directly to those addresses, although this memory is much slower than internal RAM.

    • @Sumida2
      @Sumida2 2 роки тому +2

      The internal memory and external memory are mapped to different addresses. Any read or write will go to the right place depending on the address you choose. Creating a global variable or one on the stack will use the internal memory unless you change the compiler/linker settings to use different memory ranges for those things. That is only because this is set up before hand. You could also add your own memory allocator to keep track of external memory usage. It's more of a software development issue and not something you "tell" the microcontroller about.

  • @tamaseduard5145
    @tamaseduard5145 2 роки тому

    👍🙏

  • @johnadriani7467
    @johnadriani7467 2 роки тому

    I'm really happy to watch your presentation for free, but you should start at a technical school as a lecturer

    • @PhilsLab
      @PhilsLab  2 роки тому

      Thanks a lot, John - who knows maybe someday! :)

  • @raxneff
    @raxneff 2 роки тому +1

    maybe not the best place to ask this, but: what actually is Firmware? (per definition)? Whats the difference between "normal code", an operating system (kernel), and firmware?
    is "firmware" just low level stuff or is there more to it?

    • @helmutlord4335
      @helmutlord4335 2 роки тому +1

      Firmware is code that runs on any device that isn’t easily updated. Another definition is anything that you don’t think of being “a computer” runs firmware. Your car runs firmware. Your microwave runs firmware. Hell your fridge probably runs firmware! It’s not a strict definition (and all firmware is also software) but I hope that helps.

    • @Mr.Leeroy
      @Mr.Leeroy 2 роки тому +1

      originated as meaning hardware microcode, now is probably a short for firmware image/code as a whole software part, which is a deployment ready package of everything programmer generated that is required to run particular hardware.

  • @charlesspringer4709
    @charlesspringer4709 2 роки тому

    Great as usual. One item that is irritating to old-timers. '0x' or zero x, is a C pre-processor flag or directive and not part of the number or part of C. I know it has become common to include it while speaking or in text, but it ain't right. Just say 'hex', and it is zero x, not 'oh x', which is entirely different.
    If these languages had radix modes like Forth and a few others, we could all save a lot of eye strain and typos by typing HEX and then just using hex numbers in tables and arrays. At the end type DECIMAL. Personally I would like BINARY modes when setting up registers or using masks and the like. Cheers.

  • @johnadriani7467
    @johnadriani7467 2 роки тому

    you talk like a commander from a space shuttle.. crazy

  • @chenzora2417
    @chenzora2417 2 роки тому

    Hi Phil’s Lab, I have been following you. You do a great work. I work for NextPCB. We would like to sponsor your projects. You can send a DM for more details.
    /Dolphin