This Is 100% How You Should Be Debugging | How to Use OpenOCD to Debug Embedded Software with GDB

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

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

  • @edgeeffect
    @edgeeffect 2 года назад +44

    When you talk about debuggers please don't forget The Black Magic probe.... so cheap, so easy, so cheap! I debug my Blue Pill with... well.... another Blue Pill!!!

    • @Otakutaru
      @Otakutaru 2 года назад +5

      Would someone do a Black Magic Probe for dummies?

    • @syousufimam
      @syousufimam 2 года назад +2

      Yes, that's already there in my to-do list. Black Magic 101 ( From making your own BMP using blue pill to debugging STM 32 with BMP) It's like a Swiss knife for embedded enthusiast.

  • @andybrown-maw1593
    @andybrown-maw1593 2 года назад +12

    Thanks so much, you would not believe how few, straight forward explanations of how to do this there are out there.

  • @gideonz74b
    @gideonz74b 2 года назад +5

    I think I learned more in the last 7 and a half minute than I had expected. Wow! Well done!

  • @Kid420
    @Kid420 2 года назад +12

    This is great, I’ve always wanted to get into embedded systems programming and it seems as your channel is where I’ll start 😁🙏🏽

  • @paulvohs9889
    @paulvohs9889 2 года назад +12

    I wasn't aware you could toggle the display format while inside gdb... I normally just run with --tui when I start.
    Will have to give that a go next time!

  • @eyalgerber
    @eyalgerber 2 года назад +5

    Really informative video. Thanks a lot. For me personally you hit the nail on the head with this video. It was exactly what I was looking for.

  • @chrisidema
    @chrisidema 2 года назад +1

    Thank you so much! It's really hard to find working up-to-date examples like this. So many old examples don't work anymore. I was able to get SWO working. And I also got debugging of the nRF using the st-link working.

  • @magnoelmagnifico957
    @magnoelmagnifico957 2 года назад +6

    Wow, this is really cool! I didn't know gdb could do that

  • @burningglory2373
    @burningglory2373 2 года назад +2

    Almost every embedded system I have worked with, one of the engineers has dedicated a UART for a serial debugging console.

  • @benarcher372
    @benarcher372 9 месяцев назад

    Perfect! I've done something similar with two rpi picos. Now I know also what openOCD actually does! Thanks.

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

    Jesus Christ, I've wasted a week being stuck with debugging because I forgot to add the "target extended-remote" step to my damn notes! Thanks for the video though, the instructions hold up for other boards too.

  • @conorstewart2214
    @conorstewart2214 2 года назад +6

    Not to be that guy but is there a GUI for it? I’ve used the STM32CubeIDE and it has a debug mode that has all the functionality of this and probably more, like having a live view of global variables as the program runs and being able to see the disassembly, and it seems it would be easier just to scroll through your code whilst it running and just click to create a breakpoint wherever you want it, the interface in the IDE seems a lot easier to use with more functionality than this, so is there a non STM GUI version of this for other chips?

    • @brandonallen7748
      @brandonallen7748 2 года назад

      The IDEs are using these exact tools, the user just interacts with it through a GUI.

    • @conorstewart2214
      @conorstewart2214 2 года назад +1

      @@brandonallen7748 I know that, I was asking is there a non vendor specific version of the GUI.

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

      I had the same question. This seems like an overly obtuse command-ljne way to accomplish the same thing that's provided in cube IDE's GUI

    • @youtubeviewer7077
      @youtubeviewer7077 9 месяцев назад

      Almost every editor/IDE can talk to GDB, so it should be usable with any of them, it's a matter of correctly configuring them. There are videos on youtube on how to setup with VSCode and Eclipse (IIRC).

  • @keithlegg7681
    @keithlegg7681 3 дня назад

    for anyone else that is stuck getting this to work (on linux at least) - you may need to do a "st-flash erase" before running the openocd command

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

    Oscilloscope helps with debugging very much. Sometimes I can make all the job using only one or two pins to out either logical states through them or use them as a clock/data pair to see bytes on the oscilloscope directly.

  • @jorgelinares1944
    @jorgelinares1944 2 года назад

    Thank you so much, it is really hard to find simple, relevant information regarding debugging on embedded

  • @cantaff0rd2
    @cantaff0rd2 19 часов назад

    So OpenOCD is some kind of interface between hardware debug probe which is connected to the target and GDB which is the debugger running on our PC? And we need to install some kind of extensions for GDB to debug ARM cores. Did I understand it correctly?

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

    FYI, in Fedora, the st-link package is stlink, not st-link.
    Also, there is no gdb-multiarch on Fedora. Use regular gdb but set arch once you start it.
    Great video.

  • @minirop
    @minirop 2 года назад

    that's why I love my little Arduino Zero, since it has an EDBG included. (I also have a jlink for my other boards)

  • @TheStuartstardust
    @TheStuartstardust 2 года назад +4

    I think it might be easier to just code correct the first time 😁🤓😂 ..just kidding, really nice, did not know this could be done command line like this! Good content! 💪👌👍🤓

    • @LowLevelTV
      @LowLevelTV  2 года назад +1

      😁

    • @bob-ny6kn
      @bob-ny6kn 2 года назад +1

      Do you realize that you are completely correct? Debug allows you to learn to achieve that level. Back when I taught myself to code, I typed-in code from a paper form (hand written or printed), watched it fail, learned to recognize my failures, and poof - eventually coded for top airlines... where bugs do not fly well... So, I live by, you are alive by, and want to emphasize your post: "Code right or die."

    • @hackvlix
      @hackvlix 2 года назад +2

      @@bob-ny6kn Maybe one of the top airline's engineers should have done some debugging on their 737 MAX.

    • @bob-ny6kn
      @bob-ny6kn 2 года назад

      @@hackvlix eeek. That was a managerial failure. Reliving the space shuttle.

    • @hackvlix
      @hackvlix 2 года назад +5

      @@bob-ny6kn Fair enough. Debugging the management is probably harder.

  • @ryanmckenna2047
    @ryanmckenna2047 2 месяца назад

    Thanks, this helped me a lot! I had one issue though the source code wasn't showing for me in gdb, does anyone know why this could be?

  • @michaelsnater2345
    @michaelsnater2345 Месяц назад

    Howdy! Thanks for this. Your video helped me quite a bit. I'm debugging a c++ project on a Pi Pico W using the pi debugger. Is it possible to get your advice what I'm doing wrong. Id be happy to pay you for your time.

  • @diegopinilla3431
    @diegopinilla3431 2 года назад

    great video! never debugged a microcontroller, but it doesn't seems too difficult.

  • @CorneliusHart-bd7rl
    @CorneliusHart-bd7rl 2 месяца назад

    this is such a good tutorial!

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

    Hold up could I use one of these little chips instead of a PLC for some basic robotics? Like I would have to use different relays but that may be worth the sacrifice if I don’t have to use ladder programming

  • @AlessioSangalli
    @AlessioSangalli 2 года назад +1

    Another fantastic video, thanks.

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

    Great tutorial, thank you.

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

    Just spent 2 days banging my head against the desk trying to get I2C working on the blue-pill using the libopencm3 library. By the way, you have to gpio_set(I2CPORT, SDA|SCL) to get it to work (at least in master-mode). Question: I found some 'optimized out' variables while debugging INSIDE libopencm3 code. I don't know if the debugger symbols were optimized out or if the variables were, any thoughts? I changed the -O level in the library's makefile, and re-compiled. Thanks so much for these videos, man. I tried cubeIDE and hated it; register level programming is fun and all, but I want to actually get stuff done. You introduced me to this library that fits my style.

    • @coolink243
      @coolink243 8 месяцев назад

      Hey man, I am also trying to setup i2c using libopencm3 with no luck. Seems you have it set up. Could you help me out?

    • @adammontgomery7980
      @adammontgomery7980 8 месяцев назад

      @@coolink243 I'd like to. Have you got the libopencm3-template repo cloned?

    • @coolink243
      @coolink243 8 месяцев назад

      @@adammontgomery7980 hey man thanks for reaching out. Yes I have cloned the repo

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

    I have 250pcs STM32 bluepill witch is same variant with this video (black jumper and wrong device ID). and having issue USB not recognized. Need help....

  • @krishnakhandelwal9466
    @krishnakhandelwal9466 2 года назад

    Thank you. Atleast I could see the ST-link V2 leds blink after so long.
    After target extended-remote localhost:3333 command, OpenOCD gives an error: "undefined debug reason 7 - target needs reset" and GDB gives: "0x00000000 in ?? ()"
    What does these two error mean and how to resolve it ?

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

    whats the different to hit debug in eclipse ide with openocd or stlink, jlink Interface?

  • @ikefir
    @ikefir 2 года назад +1

    Hello, LLL, may i humbly request a dive into GD32VF103 MCU. It's a 32-bit RISC-V chip. It is rather basic at the moment, but something tells me that as time goes on this architecture will become more and more mainstream. And a lot of folks would like to watch series on RISC-V assembly as well as corresponding GCC stack. Cheers.

    • @meanxmeanx1763
      @meanxmeanx1763 2 года назад +1

      Gigadevice does not seem interested in selling it. it's becoming harder & more expensive to find them on ali express. Too bad, it's a good enough chip.

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

    Do you have any course/video playlist/certificate where i can learn to program stm32 based systems using this method?

  • @MarkusBurrer
    @MarkusBurrer 7 месяцев назад

    The package st-link doesn't seem to exist on Ubuntu 24.04. Any suggestions?

    • @MarkusBurrer
      @MarkusBurrer 7 месяцев назад

      Package name is now stlink-tools

  • @OthnielCundangan
    @OthnielCundangan 2 года назад

    My only experience with embedded is from messing around with Arduino using PlatformIO in vscode. Is this better than PIO? Or maybe they can compliment each other?

  • @MrKristian252
    @MrKristian252 2 года назад

    What's the difference between PyOCD and OpenOCD?
    I haven't used them directly, but I have used software that relies on PyOCD

  • @jbvalle
    @jbvalle 2 года назад

    Thank you sooo much for this tutorial!

  • @hwhat
    @hwhat 2 года назад +1

    Hello,just found ur channel,i want to ask if arduino is a good entry to low level programming

    • @LowLevelTV
      @LowLevelTV  2 года назад +1

      Arduino is a great place to start!

    • @hwhat
      @hwhat 2 года назад

      @@LowLevelTV thanks for the reply! I just saw ur video about arduino too,cant wait to get started

    • @edgeeffect
      @edgeeffect 2 года назад

      I "restarted" low level on Arduino. Then moved onto "AVR style" C. And then got back into assembly. But I wouldn't have done any of it without Arduino to get me started... it's a great introduction.

  • @bennguyen1313
    @bennguyen1313 2 года назад

    Is there a command-line-parameter to scan the JTAG chain for devices?
    Any thoughts on using a GUI for debugging.. VSCode , Eclipse, or VisualGDB? For example VisualGDB supports OpenOCD, yet it doesn't support popular debuggers that use OpenOCD, like the Black Magic Pro.
    (Perhaps the BMP debugger is a little different as it doesn't seem to require any server software running on your computer (OpenOCD /STLink/urjtag/etc).. Instead, I think the Black Pill just appears as a remote (serial) GDB debugger.. with all the JTAG/SWD-TRACESWO support handled on the BMP itself?)
    Speaking of debuggers, I'm a little confused as to the difference between JTAG and SWO/SWD, and "ETM Traces". Segger has tons of different J-Link/J-Trace models.. and there's also plenty of cheap clones (EDU Mini, RealView U-Link2, etc). I have an AT ATMEL-ICE debugger, which supports CMSIS-DAP/SW/JTAG but no SWO. Perhaps this explains why ITM_SendChar doesn't work when I tried it with Keil (limited version 32KB).
    Does OpenOCD support the advanced streaming/tracing capability?

    • @arnabbiswasalsodeep
      @arnabbiswasalsodeep 2 года назад

      Jtag & swd are the same thing, except Jtag is more versatile & designed for multichip while swd removes the extra wires needed & their signalling requirements.
      Kind of think of spi, with more devices u need multiple chip enable lines. But if its just single device, then you can remove the chip enable signal & use few wires.
      Thus swd is Jtag compatible (since u can just not connect the wires from Jtag) but not vice versa (since swd doesn't generate & use the signals needed for daisy chaining Jtag)

  • @felixbaum2180
    @felixbaum2180 2 года назад

    awesome tutorial, thanks!

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

    Why would I do this instead of just using SWD's SWO pin via STM32Cube IDE?

    • @ninjoetsu
      @ninjoetsu 5 месяцев назад

      imo the power of openocd is that it can be used with many types of chip, and can use something more generic as your programmer such as a raspberry pi, which lets you program loads of kinds of chips without specialised hardware or software. Do whatever works for you really, i mainly use it so i don't have to buy an st link and so i can program and debug from the terminal

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

    I could only find the jlink for like 500 Euros. Are they really that expensive?

  • @Dygear
    @Dygear 2 года назад +1

    I take it it's possible to do this with rust code as well?

  • @shahinhaque95
    @shahinhaque95 2 года назад

    Do you have an stm32 openocd tutorial on the raspberry pi? f4 preferably

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

      STM32F4 or Raspberry Pi? Which one?

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

      @@CandyHam not too sure, this was a year ago. I now use gdb for debugging

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

    This is a good demonstration for a basic understanding of the embedded system debug process. BUT IMHO it's a fucking nightmare to debug an actual project like that. Any ide GUI is much more convinient. And for the remote target, it's easier to log in to the PC with a debugger by RDP and use GUI.

  • @kayakMike1000
    @kayakMike1000 2 года назад

    I brought this in for show and tell at work... They adopted it for a piece of legacy firmware.

  • @cebubikebootcamp
    @cebubikebootcamp 2 года назад

    I can't seem to run OpenOCD, why is it so hard to use this?

  • @mustafaenany9388
    @mustafaenany9388 2 года назад

    where do I get the configuration file for my controller : stm32f401ccu6

  • @germanvelardez7947
    @germanvelardez7947 2 года назад

    You are great man. That's all.

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

    Maybe you could make a video on why unix/linux developers give their products just goofy names.

  • @KushalGandhi-z9p
    @KushalGandhi-z9p Год назад

    You are love my dear. I want to give you a hug!!

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

    First time heard thoughts it was about someone is keep washing his hand

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

    Really, really good video! Thanks!

  • @bob-ny6kn
    @bob-ny6kn 2 года назад +1

    When you say "bare metal" is that AtmelStudio or are you digging into the .h files to use lowest command possible. I just saw AtmelStudio is 1 GB in size (ugh) and Arduino is in Linux's Synaptic Package Manager and only 20 MB (yeay). Thank you.

    • @LowLevelTV
      @LowLevelTV  2 года назад +1

      Baremetal to me just means I'm using as little abstraction's as possible. Here we use libopencm3, which technically is an HAL but it doesn't add a ton of bloat middleware like Arduino or Atmel libraries.

    • @bob-ny6kn
      @bob-ny6kn 2 года назад

      @@LowLevelTV thank you

    • @AlessioSangalli
      @AlessioSangalli 2 года назад

      @@LowLevelTV or Rust 😂 ahah 😂😂

    • @LowLevelTV
      @LowLevelTV  2 года назад +2

      @@AlessioSangalli RUST IS THE FUTURE I WILL NOT BE CONVINCED OTHERWISE🤣

    • @brianwest7344
      @brianwest7344 2 года назад

      C++ is the future and I will be laughing at all the Rust programmers sleeping in shop doorways.

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

    ty

  • @terlumunjoseph6779
    @terlumunjoseph6779 4 месяца назад

    What about non Linux users

  • @BogdanSerban
    @BogdanSerban 2 года назад

    Nah just print everything to serial console and hope for the best. Why is all this stuff so damn complicated? I couldn't even understand what all of these do before watching this.

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

      Sure, just as long as you're aware that depending on where in the code is the print used, how often it is triggered, how much data formatting it needs to do and how long the message is it can easily cause absolutely unacceptable delays, on an MCU that is more often than not expected to perform hard real-time duties.

  • @negvorsa
    @negvorsa 2 года назад +1

    First!!