Тёмный

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

Low Level Learning
Подписаться 601 тыс.
Просмотров 61 тыс.
50% 1

Finding bugs in your embedded code is hard. Without print statements and minimal LED's to show signs of life, finding out why your embedded code is crashing is never easy. In this video, we use OpenOCD to debug our embedded code and watch the system as it runs. OpenOCD provides a seamless interface via Telnet and GDB to allow an embedded developer to watch their system as it runs.
Low Level Merch!: www.linktr.ee/lowlevellearning
Code from the Video: www.github.com/lowlevellearni...
🏫 COURSES 🏫
Learn to code in C at lowlevel.academy
Follow me on Twitter: / lowlevellearni1
Follow me on Twitch: / lowlevellearning
Join me on Discord!: / discord

Наука

Опубликовано:

 

11 мар 2022

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 100   
@andybrown-maw1593
@andybrown-maw1593 2 года назад
Thanks so much, you would not believe how few, straight forward explanations of how to do this there are out there.
@Kid420
@Kid420 2 года назад
This is great, I’ve always wanted to get into embedded systems programming and it seems as your channel is where I’ll start 😁🙏🏽
@gideonz74b
@gideonz74b 2 года назад
I think I learned more in the last 7 and a half minute than I had expected. Wow! Well done!
@edgeeffect
@edgeeffect 2 года назад
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 года назад
Would someone do a Black Magic Probe for dummies?
@syousufimam
@syousufimam 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.
@eyalgerber
@eyalgerber 2 года назад
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.
@jorgelinares1944
@jorgelinares1944 2 года назад
Thank you so much, it is really hard to find simple, relevant information regarding debugging on embedded
@chrisidema
@chrisidema Год назад
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.
@LowLevelLearning
@LowLevelLearning Год назад
Glad it helped!
@paulvohs9889
@paulvohs9889 2 года назад
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!
@benarcher372
@benarcher372 2 месяца назад
Perfect! I've done something similar with two rpi picos. Now I know also what openOCD actually does! Thanks.
@diegopinilla3431
@diegopinilla3431 2 года назад
great video! never debugged a microcontroller, but it doesn't seems too difficult.
@magnoelmagnifico957
@magnoelmagnifico957 2 года назад
Wow, this is really cool! I didn't know gdb could do that
@LowLevelLearning
@LowLevelLearning 2 года назад
Thanks for watching!
@hacksontable5850
@hacksontable5850 7 месяцев назад
Great tutorial, thank you.
@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)
@jbvalle
@jbvalle Год назад
Thank you sooo much for this tutorial!
@burningglory2373
@burningglory2373 Год назад
Almost every embedded system I have worked with, one of the engineers has dedicated a UART for a serial debugging console.
@felixbaum2180
@felixbaum2180 Год назад
awesome tutorial, thanks!
@AlessioSangalli
@AlessioSangalli 2 года назад
Another fantastic video, thanks.
@LowLevelLearning
@LowLevelLearning 2 года назад
Glad you enjoyed it!
@germanvelardez7947
@germanvelardez7947 Год назад
You are great man. That's all.
@jakehallam2113
@jakehallam2113 10 месяцев назад
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.
@SomeTechGuy666
@SomeTechGuy666 Год назад
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.
@TheStuartstardust
@TheStuartstardust 2 года назад
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! 💪👌👍🤓
@LowLevelLearning
@LowLevelLearning 2 года назад
😁
@bob-ny6kn
@bob-ny6kn 2 года назад
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 года назад
@@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 года назад
@@bob-ny6kn Fair enough. Debugging the management is probably harder.
@Ma_X64
@Ma_X64 Год назад
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.
@BinGanzLieb
@BinGanzLieb Год назад
thats bad
@Ma_X64
@Ma_X64 Год назад
@@BinGanzLieb that's fast)
@user-jr8kv2fh4e
@user-jr8kv2fh4e 11 месяцев назад
@@Ma_X64 For sure, but how many of us have an oscilloscope?)
@user-io4sr7vg1v
@user-io4sr7vg1v 7 месяцев назад
​@@user-jr8kv2fh4ewe all should
@DeLaCruzer11
@DeLaCruzer11 4 месяца назад
Are you sure you're not just trying to brag?
@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
@ikefir
@ikefir 2 года назад
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 года назад
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.
@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?
@pingburner
@pingburner Год назад
ty
@conorstewart2214
@conorstewart2214 2 года назад
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 года назад
@@brandonallen7748 I know that, I was asking is there a non vendor specific version of the GUI.
@CandyHam
@CandyHam 4 месяца назад
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 3 месяца назад
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).
@user-sg2kr1wg8u
@user-sg2kr1wg8u Год назад
You are love my dear. I want to give you a hug!!
@krishnakhandelwal9466
@krishnakhandelwal9466 Год назад
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 ?
@jorgeguerrerorocha8140
@jorgeguerrerorocha8140 Год назад
Do you have any course/video playlist/certificate where i can learn to program stm32 based systems using this method?
@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....
@adammontgomery7980
@adammontgomery7980 11 месяцев назад
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 2 месяца назад
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 2 месяца назад
@@coolink243 I'd like to. Have you got the libopencm3-template repo cloned?
@coolink243
@coolink243 2 месяца назад
@@adammontgomery7980 hey man thanks for reaching out. Yes I have cloned the repo
@kayakMike1000
@kayakMike1000 2 года назад
I brought this in for show and tell at work... They adopted it for a piece of legacy firmware.
@BinGanzLieb
@BinGanzLieb Год назад
whats the different to hit debug in eclipse ide with openocd or stlink, jlink Interface?
@CandyHam
@CandyHam 4 месяца назад
Why would I do this instead of just using SWD's SWO pin via STM32Cube IDE?
@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
@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)
@timsmith2525
@timsmith2525 9 месяцев назад
Maybe you could make a video on why unix/linux developers give their products just goofy names.
@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.
@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?
@Ruhgtfo
@Ruhgtfo 9 месяцев назад
First time heard thoughts it was about someone is keep washing his hand
@cebubikebootcamp
@cebubikebootcamp Год назад
I can't seem to run OpenOCD, why is it so hard to use this?
@mustafaenany9388
@mustafaenany9388 Год назад
where do I get the configuration file for my controller : stm32f401ccu6
@m1geo
@m1geo 10 месяцев назад
Really, really good video! Thanks!
@hwhat
@hwhat 2 года назад
Hello,just found ur channel,i want to ask if arduino is a good entry to low level programming
@LowLevelLearning
@LowLevelLearning 2 года назад
Arduino is a great place to start!
@hwhat
@hwhat 2 года назад
@@LowLevelLearning 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.
@MarkusBurrer
@MarkusBurrer Месяц назад
The package st-link doesn't seem to exist on Ubuntu 24.04. Any suggestions?
@MarkusBurrer
@MarkusBurrer Месяц назад
Package name is now stlink-tools
@Dygear
@Dygear 2 года назад
I take it it's possible to do this with rust code as well?
@LowLevelLearning
@LowLevelLearning 2 года назад
Teehee maybe
@shahinhaque95
@shahinhaque95 Год назад
Do you have an stm32 openocd tutorial on the raspberry pi? f4 preferably
@CandyHam
@CandyHam 4 месяца назад
STM32F4 or Raspberry Pi? Which one?
@shahinhaque95
@shahinhaque95 4 месяца назад
@@CandyHam not too sure, this was a year ago. I now use gdb for debugging
@bob-ny6kn
@bob-ny6kn 2 года назад
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.
@LowLevelLearning
@LowLevelLearning 2 года назад
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 года назад
@@LowLevelLearning thank you
@AlessioSangalli
@AlessioSangalli 2 года назад
@@LowLevelLearning or Rust 😂 ahah 😂😂
@LowLevelLearning
@LowLevelLearning 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.
@BogdanSerban
@BogdanSerban Год назад
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.
@imlassuom
@imlassuom 2 года назад
First!!
@LowLevelLearning
@LowLevelLearning 2 года назад
:D
Далее
EEVblog #499 - What is JTAG and Boundary Scan?
28:59
Просмотров 462 тыс.
*Next-door 10x Software Engineer* [FULL]
4:50
Просмотров 186 тыс.
malicious javascript injected into 100,000 websites
12:28
Debugging Embedded Systems With GDB?
13:51
Просмотров 43 тыс.
one of the craziest exploits i've ever seen
8:40
Просмотров 363 тыс.
Самый СТРАННЫЙ смартфон!
0:57
Просмотров 36 тыс.