how reverse engineering makes you a better programmer
HTML-код
- Опубликовано: 31 дек 2024
- Learning about how computers work through learning a lower level language like C, Rust or Assembly will make you a better programmer, regardless of what language you code in.
One of the best ways to learn about how computers work is through playing capture the flag. In this video, we'll walk through an easy capture the flag challenge where we take apart some ARM code.
Go play CTF at picoctf.org
🏫 COURSES 🏫 Learn to code in C at lowlevel.academy
👕 MERCH 👕 Like the shirt? lowlevel.store
📰 NEWSLETTER 📰 Sign up for our newsletter at mailchi.mp/low...
🛒 GREAT BOOKS FOR THE LOWEST LEVEL🛒
Blue Fox: Arm Assembly Internals and Reverse Engineering: amzn.to/4394t87
Practical Reverse Engineering: x86, x64, ARM, Windows Kernel, Reversing Tools, and Obfuscation : amzn.to/3C1z4sk
Practical Malware Analysis: The Hands-On Guide to Dissecting Malicious Software : amzn.to/3C1daFy
The Ghidra Book: The Definitive Guide: amzn.to/3WC2Vkg
🔥🔥🔥 SOCIALS 🔥🔥🔥
Low Level Merch!: lowlevel.store/
Follow me on Twitter: / lowleveltweets
Follow me on Twitch: / lowlevellearning
Join me on Discord!: / discord
Come learn ARM assembly at lowlevel.academy (use code ARMASSEMBLY20 for 20% off lifetime access). or dont. i'm not a cop.
Or just look up the instruction set and read it
Hey I wanted to know if the videos on LowLevelAcademy were available for download/offline viewing? I want to sign up, but my internet bandwidth's highest speed can be measured in kilobits per second. So almost all of my RUclips/video process is go into town, grab a data dump, and come home to watch.
sir can you guide me from where I should start learning about reverse engineering right now I only known basic c/c++
got lifetime access a while back, finishing up BootDev right now and cant wait to dive deeper on LLL. thanks as always for the content bud. Superb
meaow
I wanted to learn assembly for a long time. you should make a whole series about gcc assembly.
Agreed
for an assembler i very much recommend fasm
its simple fast and lightweight
it has macros and helper function and has been developed for like 25 years if not longer
@@RedstonekPL you know some time ago I actually learned nasm assembly, and made my own framework, which made it easier to manage memory and such. I gave up on it almost immediately, so it didn't go much further than a basic concept and a quick and dirty implementation.
Agreed
For sure, making a frontend for GCC assembler would be so damn cool xD
Unlike a lot of other RUclipsrs, You actually know what you're doing and have a passion for it. One of my favorite tech channels on the platform.
You are not real developer until you recording yourself do some coding.
@@halanonot at all
@@halano so Dennis Richie, Ken Tompson, Richard Stallman and Linus Torvalds are not real developers? Got it, thanks!
My suggestion for learning low level stuff (and, in some sort, assembly) is to play Zachtronics' games, especially TIS-100, Shenzhen I/O and Exapunks. Although you won't learn a specific set of instructions, given each game uses it's own assembly language for ficticious architectures, you will learn how it is like to use assembly, by dealing with registers, memory, circuit design, CPU cycles, control flow, etc. Besides, you'll have lots of fun!
Thank you for the thoughtful suggestion.
@@JayDee-b5u Exapunks has a special place in my heart, given I'm a fan of retrofuturism/sci-fi/cyberpunk literature, but TIS-100, with it's 80's charm, and Shenzhen I/O, in it's setting, are also really great!
What I like the most about their games is how they're narrative-driven: it's not LeetCode, i.e, coding for the sake of it; but programming puzzles you're personally invested in due to how they're presented and how the narrative is set up. They're really great games!
The main issue here is Zach's games have (deliberately) awful architectures, extremely limited and quirky.
This leads to interesting gameplay, because you can't just reuse a solution you figured out earlier, but it also makes it seem way harder than it actually is on real machines.
How is that a problem lol@@SimonBuchanNz
@@Zeni-th. mostly that it's pretty easy to be discouraged by thinking that "I'm not smart enough for assembly"
Normally the game version of a thing is simpler and easier, but I think that's inverted in this case. Real assembly problems don't come with unit tests, but otherwise they're often easier than an equivalent in Zachtronics games. (Though of course this is very subjective)
This man is a wizard at CS. This dude is my inspiration. So glad I found his channel.
You are reason why I learn C and I am glad I got into low level programming
birb
Me who can't even code properly in c++ : "Yup, assembly is the right choice for me"
C++ is one of the worst programming languages.
It’s a minefield of ineffective specialized functions and keywords. Slow polymorphism and weird multiple standard libraries.
You either go performant, unsafe and with more code using C, or with lower performance, low code in python. C++ is the weird inbetween.
@@rethardotv5874 I'm a openGL dev so I kinda have to use c or c++
@@rethardotv5874 or go all in and use c#. Using c# after a year of c++ was probably the nicest feeling ever
Tbf C++ is probably harder than ASM
@@angelcaru I learned c++ in 1 week
I heard that everything is open source when you know assembly 😂
I get it now, because in my college every single projects are ALL with the exception of none made with C in first year of college. We code 24h/7 in C. In seconde year we do C++ and Assembly and its only in third fourth and fifth year that we do high level languages like python, javascript, java etc...
I was just doing the same ctf question yesterday and got headache reading and understanding assembly code again that I've read in my second year at the college. This time I understood it. Thanks.
We need Intel x86 course on the low level academy platform
No make it RISC-V to prevent recycling code for example
I've had that in college twice & they made us program the x86 ones using the original way they were programmed, that being use another x86 board with a flashing/burning software connected to addresses gen chip & external storage, where you type in the instructions using a ps/2 keyboard in assembly that you had to manually write it down first and mistake meant waiting to finish then overwrite that particular memory address.
All of that just to get led blinking or it posting "hello world" on 2x16 lcd display after 2 hours of pain.
Ahh, those were the days. I hated when thry did the same for arm assembly too, but i just used Internet to write it as assignment & through credibility amongst teachers was able to lie about having finished it quickly.
we learned asm on 486 back in school. But back then we wrote directly to memory, like the graphics ram etc :) so would be fun to learn how to do it today. but I prefered asm on the Motorla 68k cpus.
Today everything is so complicated. Back in the day I learned it on the C64 where it was actually easy. When I switched to PC I fiddled a bit with assembly but the abandoned it for Turbo Pascal which was both easy to write as well as performant. Plus if you really wanted you could use inline assembly.
@@mudi2000a To me this still seems like haven to what my visions of learning that in the future. Lets hope I am juvenoic
i've started picoCTF based on your video, best time invested ever!
couldn‘t have said it any better. reverse engineering got me deep into software development, because i wanted to understand what was going on under the hood. Nothing else makes you understand race conditions like injecting code into another process and randomly crashing, while other times having a perfectly running program.
This is so so true mate, I'm a self-taught student and I get overwhelmed by all the different tools and language, but after I learn about C++, I start to understand what is happening
For those who can afford (and could make use of - some people don't like them) a textbook, CMU is also home (so to say) to _Computer Systems: A Programmer’s Perspective_. (Disclaimer: I took the course this is used in - or a version thereof - 20+ years ago while a student there in Logic and Computation.) I do echo our host's recommendation of CTFs for the subject - the text might be useful as a reference.
More of these please.
We appreciate videos that show and explain how.
Something i really like about this kind of video is that there is no cringe music in the background that sometimes can get on top of your voice ;
No, there is just you, talking fluently about a really interesting concept. As a french who tries to learn computer science AND english at the same time, thank you.
Dude the way you explain things feels very organic and coherent, even though I don't even know half of what you're saying- I wish I could :)
I just started learning a little bit of JavaScript but at the same can't help but feel fascinated by low level programming. Someday, I'll have enough knowledge to be able to understand and appreciate the things you describe in your videos 🙏
Thanks!
The only stuff I remember from writing basic assembly is registers (RAX RBX RDX etc)
And their use to store information
been looking for this for a long time cant wait for the full series
Any decent CS program would include a course using assembly, C/C++... Those people asking are definitely from an 8hours online JavaScript/python course
Could you do a tutorial on static analysis, this is useful if working on embedded projects
Khud se kuch karle bhai, bhik mangne ka adat chodde
9:59: ERROR: INVALID MNEMONIC INTERPRETATION
DETAILS:
`BLS` is "Branch if Lower or Same," which is _distinct_ from Branch if Less Than (`BLT`). BLS is used to compare unsigned integers; BLT gets used with signed integers.
I always had difficulty conceptualizing the compare (`CMP`) operation, until I finally realized: `CMP` is identical to `SUB` (Subtract), except that it throws the result away and keeps the flags. So `CMP w1, w0` can be thought of as `SUB w1, w0` (i.e. result = w1 - w0) and thinking about the result of that subtraction. Is the signed result Less Than zero? If so, `BLT` is what you want. For unsigned integers, is the result underflowed (Lower) or equal to zero (Same)? If so, `BLS` is what you want.
The best way to learn assembly, is to learn microcontrollers and turn a LED in a protoboard.
The best way to be a programmer is to know how your bits a flowing.
I actually did a project in school where we wrote assembly directly. What we did a lot is to write step makers (because we had interrupts) and even had a semi custom font engine run the display with a microcontroller.
Nowadays I do the most high level stuff there is, it's all python scripts... But I really enjoy watching these videos or similar talks. Never did CS - but might pivot my masters.
I watch Ben Eater's videos about his breadboard computer, so I actually have seen quite some assembly before, but assembly meant to run on raw hardware without any OS. So he had to implement the serial print function etc. all by himself.
That was his own version of assembly.
@@black53342
But it's still assembly. And it isn't his own, it's 65C02 assembly.
Great video and information. Thank you.
Thanks for picoGym recommendations. Do more like this one
This is a very useful video. I really learn along the way.
bro it just dropped a minute ago, cut the cap
You should consider having an option on your site to purchase access to individual courses! I'm sure I'm not the only one who thinks buying lifetime access is a bit too much of a financial commitment, especially when I don't know if I'll ever have time for any other courses. Love your videos!
My first experience with reverse-engineering was decompiling in Ghidra a mobile phone's (SoC Mediatek MT6765, Model OPPO A12) bootloader "Little Kernel" to patch it and basically disable Android Verified Boot. Now when I'm reversing a normal ELF binary I feel like I'm on easy mode
As someone who has dealt with hacking mediatek phones, i feel you
For anyone wanting to learn computer architecture, the Elements of Computing Systems book is a great one, takes you all the way from what is a 16 bit adder, to a high level language that runs on a cpu you built.
Do u have a pdf for it?
@@Zeni-th. f.javier.io/rep/books/The%20Elements%20of%20Computing%20Systems(dot)pdf
Not gonna say too much on here but my CO recognized you when I was watching your video while working on the JQR for basic tool dev lol
When I watch your content I really get motivated. You're helpful and smart, a rare combination 😊
Would have praised you more but gotta go coding🎉
Appreciate your channel my d00d
I think this is why so many software companies poach hardware/firmware developers so often
Just grind crackmes even just once a week, I used to do those endlessly for years back when I was 13.
Reverse engineering is how I learn most anything if it's possible.
this was such an awesome video!
For me, in university learning the fundamentals of programming and then data structures all in C was 90% of the way
Awesome channel ! Been forwarding and reversing bits for quite a while now but I don't know half of what I need to learn... Or something like that. Some day, some where I would love to see a C instructional on more advanced compiler errors and warnings. Beyond the usual missing semi-colon. There may be one of these on this channel even already. Will look
That was amazing thankyou :)
I have the privilege of knowing a low-level and a high-level language... The perfect synergy to hate both.
One is either slow or an expensive wrapper for C functions underneath. The other is very fast yet every millisecond using it feels like a lifetime.
I remember... I remember when _sudo_ was a synonym of power, when XML-RPC was the future for data, when machine-learning and logic each had their role, when WebAssembly promised to bring harmony to us all...
My reference to hope has long been freed but sorrow keeps leaking. Should I hang up, give the final signal? I hear my soul - kernel of my being - panicking: *"No !"*
When stuck in that eternal recursion, when linkers scream in a long-forgotten dialect, when heap and stack overflow...
I tell myself: "At least I don't code in JS."
Pity that the code had a BLS instruction, not BLE - this would have made a good case for showing how signed numbers are encoded in binary and how the seemingly smaller number in the example would have turned out to be the larger one
The lower level languages might seem hard and assembly language sure is hard, but at the same time the complexity level in the language tends to not be very high.
It's true that C++ compilation errors can be some of the biggest headaches a human will ever experience in life, but I feel the language itself is very straight forward as opposed to C# WPF with it's unholy XAML--C# hybrid language.
My journey was through Commodore 64's 6510 (a varient 6502), Sinclair's Z80, and IBM PC's 8088 (using TASM, then MASM). My $0.02 for learning assembly is to go through VICE (Commodore 64 emulator) and/or a Sinclair emulator. Their design philosophies are very interesting.
Thank you so much for this video
I hope you are planning a reverse engineering course on the low level learning platform
implying im going to go to picogym and be part of the llm dataset
I got started with low level programming by making small cheats and mods in Cheat Engine.
Personally, the most education I've learned from low-level stuff was from OS development.
I always wanted to learn assembly, And so far i have only managed to learn very basics. Im still trying to learn assembly by reading assembly code and dunping C binaries to assembly!
brother, you are the one
I'm so inspired right now I wanna port the whole Vulkan SDK to Assembly then to pure Machine code, then down to the logic gate 1s and 0s 😅
Oddly enough the first language I learned was Arm asm from hacking the gameboy advanced.
Was trying to make a arm thumb disassembler but that has been a process to say the least 😅
love your videos!
I've never seen Arm Assembly or had it explained to me before so it was revealing to see that fundamentally, while it has it's own unique ISA, it pretty much does the same tasks that you would find in older chips like the 6502, Z80, x86, or 68000k. For some reason I assumed since CPUs have way more registers now it would be too complex to grasp but surprisingly nope, still the same building block process of moving values to and from CPU, to and from Memory, and to and from the Stack. 😃
I was watching your previous video on reverse engineering
Only binary reverse engineering? Is there no reverse engineering of webpage JavaScript source code? For example, cookies are encrypted. Find the location of the encryption function in the source code.
Quick question: Isn't BLS 'branch if lower or same' rather than 'branch if less than'? So it would be used for conditions where argv[1]
I would be interested in a video about learning the systems that the assembly interfaces with and how you would, for example, learn x86_64 assembly calling conventions, syscalls, stack frame setups, etc. Also, my terminology might be off, so apologies if my question isn't intelligible
Security in an industry that employs people who write their passwords on paper and willingly share it with others?
I'm sorry, but social engineering will always beat anything else due to human nature. 256-bit encryption has nothing on someone who was just "sloppy" one day and forgot to log out (classic PEBKAC).
hey ! thanks for the vid !
did you configure something to have arm executables running on your machine ? (you might be arm ahha but is there any way on x86 ?)
sudo apt install qemu-user
THIS MAKES LIKE SO MUCH MORE SENSE HOLY SHIT MAYBE IM NOT COOKED
yesterday I learned about ImHex and ended up reverse-engineering game save files for fun till 2am 😆 it's so cool
Oh nice... Thanks for that one, didn't know about it. I'm used to just having having the hex ed, a text ed for notes and writing a "reader" as i go, but having some "integrated all in one" software for it sure would save time...
@@ErazerPT yep, their pattern language is really powerful
I just realised that I've always been a nerd.
And I love it
Do you study instruction sets or what? Seems pretty in depth, more than I expected even, needing to understand ARM architecture in this case.
Maybe just use compiler explorer, and you'll be able to figure out what instructions mean what quite quickly.
@@spaghettiking653 That doesn't sound right, but I don't know enough about stars to dispute it.
@@Sluggernaut Stars? What do you mean?
it goes the other way too with knowing the high level stuff (ie design patterns) :3
I imagine that before you do these you'd still need to first learn some of the basics of assembly though.
Damn that was a smooth intro.
I tried getting into reverse engineering to get an old program made for Windows XP to work better through Wine on Linux. I'm a novice when it comes to assembly and only have trace amounts of computing principles from college. There was such an insane amount of information that I wasn't used to and I could only occasionally get a glimpse of what was going on under the hood. I'd have better luck trying to read a foreign language with no translator. Wonder if doing small challenges like the one you're showing help to remove the obfuscation.
not gonna lie, i’m kind of annoyed by the fact that there’s multiple kinds of assembly syntax like a know quite a bit of x86 64bit nasm assembly but the arm assembly syntax is so different that I don’t know any instructions apart from like mov and add
That's one reason assembly is hard. There are a lot and they are all different and specific to each cpu architecture.
Great video! It reminds me when I designed a small cpu with vhdl!
Really great video
Should have mentioned „calling convention“
what am i missing, why is the first number greather than second one
Thank you, subbed
I am new to programming, but with a bg in maths
There is also the legend of R4ndom, even if it is pretty old by now.
This was so very clearly articulated. I appreciate the thorough walk through!
Excellent video! Thank you! Are there any considerations for showing a similar video, but focused on RISC-V? Thank you, again, and I look forward to more videos like this. :-)
Why does the C compiler use stack space and cpu cycles to swap the function parameters before starting the logic in func1()?
Best way to learn programming is learn to read code base asap and get the idea behind.
This was really fun and informative, I felt like watching Sherlock Holmes!
what s the font used in the terminal ? love your content
That was wild hearing your spell atoi the first time. I spell it completely differently :D
I've only worked with ARM since last year, for a short while. So I don't exactly know much of great place to start with reverse engineering.....
Ahh why are you using the default dwm config? It takes like 15 minutes to set one up to look relatively decent with gaps and thicker more defined window edges and bigger text and even custom icons if you use a font like awesome and change window labels from numbers to character icons included in the font you install. Like yeah it might sound hard at first but when you actually do it and follow someone's tutorial you'll be done in an instant.
But is it expected to analyze the assembly for this ctf like you did? Couldn't one just compile and test?
Lol i had this crazy idea ab reverse engineering passwd.
My logic was that if it were written in C, then at the point where stdin is opened an youre promted to input a password, there should be a strcmp() between the inputted pw & the current users "stored password", in which case 1 out of 2 branches are taken, where the password is a match and where its not.
Tried using objdump to dump the disassembly of the binary & see if i could try to find the cmp instruction, fast forward to numerous grep results of cmp & je instructions, i encountered a skill issue real quick.
Decided that if im actually gonna do it, to use ghidra instead coz im hopless at asm 😂
I don't get one thing here. The "func1" does that stack allocation and value swap between w0 and w1. Can't it just do "cmp w0, w1" instead of swapping the arguments in the registers and doing "cmp w1, w0"? Or is it just a part of the challange, to make the code more complex and throw you off a bit?
This is probably just the result of some compiler foo, given that it came from a C file, rather than an intentional obfuscation. Thanks for watching!
Do you have an arm processor? normally you cant run arm binaries on intel based processors right? or are you using some virtualization?
How was he able to run arm assembly code on hislinux machine?
I would like a Risc v assemply playlist from u
Any thoughts on windows kernel programming book for 4 reverse engineering ?
seems like, Iam the only one who does not understand s***
You will
If you search the meaning of terms you don’t understand.
Keep it up
Bro, then I'm better than you
Practice every single day. Solve problems with concepts you don't understand so you can understand them
@@Devdevbruh nahh , assembly does not interest me at all , stick with C and well of course try to go to hardware description language
you aint the only one... but you gotta start somewhere... im here because ive been playing with base2 math a lot and im curious how 01 makes hardware understand anything
ASM for write shaders in pixel shader and vertex shader i think, and understand GLSL and HLSL, like Blender or Unreal engine
great timing. i am heading into summer (with no internship :( ) and i thought of picking up reverse engineering. what do you think about utilizing books for learning rev eng?
Do you have an official documentation on x86 assembly to advise from which I can learn assembly ?