Syscalls, Kernel vs. User Mode and Linux Kernel Source Code - bin 0x09

  Рет қаралды 251,703

LiveOverflow

LiveOverflow

Күн бұрын

Пікірлер: 175
@xXoSmegZoXx
@xXoSmegZoXx 8 жыл бұрын
It's a shame you have so little views. I think your videos are awesome! It's very hard to get into "hacking" or basically understanding how computers really work in a fun way. I appreciate your effort to make this knowledge easier to acquire. Thank you!
@LiveOverflow
@LiveOverflow 8 жыл бұрын
+Shalev Keren Thank you very much! You can help sharing it with other people who might be interested in it :)
@damejelyas
@damejelyas 6 жыл бұрын
not any more
@rj-nj3uk
@rj-nj3uk 5 жыл бұрын
@@LiveOverflow hey. thanks for making this video.
@martiananomaly
@martiananomaly Жыл бұрын
Lol
@dimimate5522
@dimimate5522 8 жыл бұрын
Your videos are very good. I have searched and watched many videos on the topic in matter and your work is what exactly i was looking for. Well explained terms, examples with live hands-on-keyboard, short length, references from books used, no sleepy voicing and many more. Your videos are an example of how video tutorials-lectures should be made. Congrats
@Chastor97
@Chastor97 2 жыл бұрын
Your English is quite clear and easy to understand by non-native English users
@bitcode_
@bitcode_ 9 жыл бұрын
im learning a lot from your videos, thanks for taking the time to make them, i appreciate it
@LiveOverflow
@LiveOverflow 9 жыл бұрын
+mylampdatabases thank you for those kind words :) If you have any topics you are interested in, or a topic that was too confusing and you need more information, please give me feedback
@MonaJalal
@MonaJalal 8 жыл бұрын
+LiveOverflow please talk about softirq and tasklets :)
@housemusic325
@housemusic325 8 жыл бұрын
It could be really cool to have a video about badass bash coding.
@EchoNote
@EchoNote 7 жыл бұрын
9:06 "Imagine if a process try to read some secrets from another process". A few days ago (January 2018) the google project zero team discovered a bug that does exactly this (meltdown and spectre) hahahaha
@alojzybabel4153
@alojzybabel4153 5 жыл бұрын
Gee, I wonder what they needed this vulnerability for :q
@abdarafi
@abdarafi 5 жыл бұрын
Wow...
@ruadeil_zabelin
@ruadeil_zabelin 3 жыл бұрын
@@alojzybabel4153 It's a hardware vulnerability. It had nothing to do with google. Blame intel and arm.
@alalala132whyisthishandletaken
@alalala132whyisthishandletaken 3 жыл бұрын
this wasn't google, the core behind spectre has been known for quite a while (paper published in ~2003). it's also not "intel and arm"'s fault; it's just a fault of the entire architecture. spectre involves cache speculation being obviously faster than just random accessing of memory; you can use the CPU's cache speculation to read memory in a process that is not yours because it works above paging and the time difference between reading something which is cached and which is not-so could be catastrophically huge. it's a fault of the von neumann architecture as a whole. while he did envision that "near instantaneous accessible memory" was required for his architecture he never saw the fact that with an electronic computer (that is able to do shit almost instantly) the sheer size of any memory would be a hinderance, and the mere millimeters that it exists away from the cpu would bottleneck instructions to the point that you can execute millions of instructions before certain pieces of data are returned in a fetch. in our greed for speed, we implemented caching in such a way that it breaks another concept we implemented around about the same time (paging). i'm sure we sorta also violated von neumann's vision - a computer program not being able to read the entirety of the memory available to it? that's just silly.
@Linaiz
@Linaiz 5 жыл бұрын
This is amazing, never seen a video before that actually links all these concepts together, this gave me a totally new point of view on this as a student, thank you!
@themanyone
@themanyone 6 жыл бұрын
This is more my speed. A lot of condensed information in a short time here. Definitely going to have to wake up and drink another cup of coffee before watching it again.
@figloalds
@figloalds 7 жыл бұрын
I thought Linux kernel was complicated. Now I'm sure. Actually it's the simpler it can be, computing is complex and providing a safe reliable bed for applications to run, live and exit is indeed... Magic. Highest rank of Computer Magic.
@darshannn10
@darshannn10 2 жыл бұрын
no matter how many times I come back to this playlist, I always learn something new🙌
@krzysztofadamski2884
@krzysztofadamski2884 8 жыл бұрын
This video is very good and you are really good at explaining complex stuff. This of course requires making some simplifications and it's quite easy to make things wrong when you do that. Claiming that the mov instruction inside of __get_user_asm is an example. While this is possible, its not what will usually happen. In most cases the page will be available in the memory (won't be swapped out) and no page fault will be done. As you explained before, resolving virtual addresses is done transparently by MMU, which is reprogrammed each time a process is scheduled.
@LiveOverflow
@LiveOverflow 8 жыл бұрын
+Krzysztof Adamski thanks for the additional info. I don't know the low level kernel stuff too much but was hoping that it's enough to create some intuition for it.
@niente11111111111111
@niente11111111111111 4 жыл бұрын
@@LiveOverflow if i supply a virtual address to copy_from_user and eventually there will be the mov when the process hits that mov won't the MMU translate automatically the virtual address into a physical one?
@chri-k
@chri-k 3 жыл бұрын
@@niente11111111111111 that is exactly what the original comment said
@BurningApple
@BurningApple 6 жыл бұрын
It was sure I/Opening :D
@prithivirathinam
@prithivirathinam 4 жыл бұрын
Dad joke, huh? Nice.
@chigozie123
@chigozie123 3 жыл бұрын
It sure was*
@Nunya58294
@Nunya58294 2 жыл бұрын
Lol
@chaoskong2987
@chaoskong2987 Жыл бұрын
Eat shit, that joke was horrible /j
@chaoskong2987
@chaoskong2987 8 ай бұрын
OH BROTHER THIS GUY STINKS!
@j.santana7552
@j.santana7552 4 ай бұрын
alot of this went over my head tbh. It's quite informative, yet quick paced. I'm still new to understanding syscalls. I'm definitely gonna be coming back to this video
@DurgaPrasad3496
@DurgaPrasad3496 7 жыл бұрын
you are amazing!. this compliment is not for what i learn from your videos. it is for your way of explanation. because, even some topics i don't understand my temptation doesn't stop me that not see your videos. #LiveOverflow is one of the best channel i am following thank you.
@guitarscholar
@guitarscholar 8 жыл бұрын
I love your videos. It is good to dive into topics like this sometimes. It is a taster that makes me want more.
@graysoncroom
@graysoncroom 7 жыл бұрын
Great series so far. You are the first person I have found that goes deep enough to make me think, but not to the point of confusion. I appreciate what you are doing, keep up the good work!
@graysoncroom
@graysoncroom 7 жыл бұрын
just realized that this video was made a long while ago. All the same, thanks for the content!
@shravankumarsheri
@shravankumarsheri 4 жыл бұрын
watched 2 times to get the grasp of it. Man it was really profound amount of knowledge.
@renunciant
@renunciant 6 жыл бұрын
0:50 the funny thing about calling them an interface between things, is that the interface itself must then exist in a domain of its own (otherwise it isn't an "interface" but part of one "face" inside another - difference is crucial), of course being again either user or kernel land. In reality syscall implementation always exists in both of course.
@jitendra.khasdev
@jitendra.khasdev 9 жыл бұрын
LiveOverflow....I just see your 1st video.................Damn Its awesome :-)
@ajaysureshkumar1533
@ajaysureshkumar1533 5 жыл бұрын
One of the best playlists for hackers...And the best playlist for reverse engineering!!! And I am sad that this playlists have less views than the other stupid hack vdos..where most of them are fake ones ..And most of them are like making use of tools which contributes 0% to computer knowledge which are making backdoor and getting control of data..Hacking is something far than that.......This channel teaches us the real skills required for hacking like knowing the inner working of computer and how do they process data and how can you trick the computer.. Most channel teaches us how to do it..But this channel teaches how to do it and why did this happen..And huge respects to this man who did this vdos free for us to watch .May ur channel grows exponentially over time..And really sorry bcoz of posting the comment after u have asked the feedback ..Ur teaching is really great dude.And pls make a new playlist for web application penetration testing by starting from sql injection to advanced web application attacks ..Pls sir ur teaching is really gud ..And btw i am a great fan of ur vlogs
@abclonqht
@abclonqht 3 жыл бұрын
I started learning the assembly and found it really difficult. Hope watching your video will help me more in learning :D
@Darksider95
@Darksider95 3 жыл бұрын
awesome video man, in-depth and easy to understand
@oliver5204
@oliver5204 8 жыл бұрын
Very clear and easy to follow, thanks heaps. I know you briefly touched on how to implement a call but perhaps a quick live demonstration would be the only thing missing. Again, awesome work.
@kltf34cgsdawe9
@kltf34cgsdawe9 3 жыл бұрын
nice , but you wrong at 11:57 there will be no page fault ( only happen on special cases like addresses not belong to the process address space or swapped ) kernel will be mapped across all processes ( but protected from access ) so kernel can access process memory just by VA and MMU will convert to PA as usual
@alkeryn1700
@alkeryn1700 6 жыл бұрын
first time i watched this video few month ago i didn't quite understood everything learnt assembly recently and now i'm like "bruh its the basics" but thanks anyway you made few things more clear
@noicecu8868
@noicecu8868 5 жыл бұрын
I always new about Ring0 and Ring3 but I never knew the technical side. Thanks for the useful information and the deadly rabbit hole you just got me in!
@jpmastermarketing5716
@jpmastermarketing5716 3 ай бұрын
Gosh this went way over my head but I wish I could learn like you
@MrGeekGamer
@MrGeekGamer 7 жыл бұрын
strace just blew my mind.
@sususu9
@sususu9 3 жыл бұрын
this channel is a blessing
@10FactsShow-10factshow
@10FactsShow-10factshow Жыл бұрын
RDMSR(Read MSR) is a kernel level command how it can be execute in user mode,so there is much detail you are missing but its a great video
@migueld2456
@migueld2456 8 жыл бұрын
Your videos are fantastic!
@vspxleoo
@vspxleoo 6 жыл бұрын
AWESOME!!! So clear and compact! ... thanks for being so smart and communicative! :D
@lookback6314
@lookback6314 2 жыл бұрын
Thanks! Your videos are invaluable!
@balkan917
@balkan917 5 жыл бұрын
this is exactly I was looking for, thank you!
@sharatht8909
@sharatht8909 4 жыл бұрын
I was always afraid of binary exploitation and stuff around binaries. I really appreciate your work here. Thanks for the big help. As you said, I got lost in your series and wonder what I can get more in this video series.
@理科角度看历史
@理科角度看历史 6 жыл бұрын
You want feedback? Here is the fb. You job is really good! Very clear and good enough !
@arivanhouten6343
@arivanhouten6343 3 жыл бұрын
Still a good series! Can recommend this to everyone!
@Enrico-Migliore
@Enrico-Migliore 3 жыл бұрын
Great video thanks. Very detailed contents. The author did a great job.
@edgeeffect
@edgeeffect 3 жыл бұрын
I'm at some grey area between n00b and leet.... and I these videos are neither too simple nor too complicated for me.. NICE!
@fpostolache
@fpostolache 2 жыл бұрын
Great introduction. Thanks for sharing !
@hl2mukkel
@hl2mukkel 7 жыл бұрын
This one was very interesting! Thanks for this one =D
@JohnSmith-he5xg
@JohnSmith-he5xg 8 жыл бұрын
Fantastic intro to syscalls!
@jt-kv3mn
@jt-kv3mn 6 жыл бұрын
Simple and honest ! thaaaank youuu ! great great great !
@JGunlimited
@JGunlimited 6 жыл бұрын
@3:00 Is it possible to just skip to 'syscall' instead of stepping through each instruction?
@mnemonic6502
@mnemonic6502 5 жыл бұрын
This is excellent! At the level I wanted to know.
@four0two167
@four0two167 9 жыл бұрын
Great videos! Although you are right in making assumptions that we understand what is clear to you, this makes us read more in detail about this. (And when you do this, it does not create any big gaps in - my - understanding.) For example the reverse engineering of the license check program, which I did not understand fully to begin with. Thank you! I would like to see some videos about reverse engineering in general, to help make life easier. Keep on doing this please!
@LiveOverflow
@LiveOverflow 9 жыл бұрын
+four0 two1 could you elaborate on "reverse engineering in general"? What is your imagination of reverse engineering? Any particular example in mind? I reverse engineered a simple C program with the license check. But you could also reverse engineer a protocol. Or hardware. Or a fileformat... etc
@four0two167
@four0two167 9 жыл бұрын
I would like to know everything. So maybe some more advanced examples of code in C, Python and ASM? Because I am not really educated enough on such subjects to make good guesses on what code do.
@johnhammer8668
@johnhammer8668 6 жыл бұрын
You videos are way too good. Can't believe i have'nt found more than 2.5 years.
@suryasikharej5511
@suryasikharej5511 Жыл бұрын
@3:42 Where does the address stored in IA32__LSTARMSR POINT TO.? I mean what does that address contain?
@effexon
@effexon 4 жыл бұрын
Is it that Vic20 or Commodore64 dont have these rings, but you can write and run which opcode you want? Then 486 already has those rings and this applies...
@patrickmullen2914
@patrickmullen2914 2 жыл бұрын
Great video, a thumbs up 👍
@SolomonUcko
@SolomonUcko 4 жыл бұрын
Around 3:20: FWIW, I think `puts` would probably have much less wrapper overhead than `printf`, since it doesn't have to do all the format string parsing and processing.
@SSB2706
@SSB2706 4 жыл бұрын
Superb explaination
@sashastadnik9347
@sashastadnik9347 2 жыл бұрын
if you reach this error `implicit declaration of function ‘write’` when compile `write_test.c` just add `#include `
@Mike-kq5yc
@Mike-kq5yc Жыл бұрын
Why length is 5? What is about the Null Byte?
@mrwayofwarrior7853
@mrwayofwarrior7853 4 жыл бұрын
hey liveoverflow, du bist mein totemtier :D
@itZMySound
@itZMySound 6 жыл бұрын
At 5:24 we load the number corresponding to the write syscall. Would it be possible using a debugger (or something else?) to change what is loaded into eax and make the syscall invoke another function?
@Julesoby
@Julesoby 6 жыл бұрын
Yeah, definitely. The result would be quite random tho, as the different syscall signatures can differ a lot.
@coolwinder
@coolwinder 8 жыл бұрын
i love you man
@LiveOverflow
@LiveOverflow 8 жыл бұрын
@uohwhoru3473
@uohwhoru3473 4 жыл бұрын
bruh and i thought learning this is hard lmao thanks for the ez explaining ❤️
@snorman1911
@snorman1911 2 жыл бұрын
Enjoying your instruction on Lennox Cisco's sir!
@LiveOverflow
@LiveOverflow 2 жыл бұрын
what is Lennox Cisco?
@TildaAzrisk
@TildaAzrisk 6 ай бұрын
Lol. I'm guessing you used speech to text to write your comment. Close in sound, but translated poorly.
@snorman1911
@snorman1911 6 ай бұрын
LOL wow I obviously didn't proof read 🤣
@samarthtandale9121
@samarthtandale9121 2 жыл бұрын
Amazing Content !!!
@ziyangxie8607
@ziyangxie8607 3 жыл бұрын
that's a really great video
@tomservo5007
@tomservo5007 8 жыл бұрын
What I'm confused about is how userland programs execute a privileged cpu opcode. Example, get the value of opcode RDPMC (x86) #include int main() { unsigned long long int x; __asm__ volatile (".byte 0x0f, 0x31" : "=A" (x)); printf("x = %lld ", x); } --------------------- does this cause a general protection fault and the kernel 'runs' this ?
@Andruhass
@Andruhass 4 жыл бұрын
Wow. That was awesome 👍
@samarthtandale9121
@samarthtandale9121 2 жыл бұрын
Basically what that means is the kernal gives some address space to each process and this chunk of address space is called as linear address in that process, Right?
@stankojankovic
@stankojankovic 9 жыл бұрын
This is great. Thanks!
@bradlee9242
@bradlee9242 6 жыл бұрын
Great video, thanks
@RamakrishnaJK
@RamakrishnaJK Жыл бұрын
Great Great Great Video.. Thanks a lot..
@Jonathan-ru9zl
@Jonathan-ru9zl 2 жыл бұрын
Excellent. Should i see the former videos to understand this?
@peyastig6371
@peyastig6371 6 жыл бұрын
And how did you exactly learn all of this? Just from reading documentations??
@呂奕珣
@呂奕珣 5 жыл бұрын
thank i love your video~ please do more
@AlanMedina314
@AlanMedina314 3 жыл бұрын
I hope to someday have a basic understandig of the linux kernel. Video reinforces how much I still need to learn. My brain overheated for a good reason.
@00eunderscore70
@00eunderscore70 2 жыл бұрын
Hi are there any other things books that can help me understand the Memory - -and kernel basics
@phoenix2464
@phoenix2464 6 жыл бұрын
2:47 what version of radare2 is this ? how did you get this view ?
@phoenix2464
@phoenix2464 6 жыл бұрын
never mind turns out i had an old version..
@yonite4355
@yonite4355 2 жыл бұрын
awesome video
@shaswata56
@shaswata56 6 жыл бұрын
I've watched some hacking videos of yours. I was amazed by your pace! You're 1337 . You deserve more subscriber(I know you don't need that). You show everything so precisely!!! Respect 👍👍
@techtalk668
@techtalk668 5 жыл бұрын
Awesome content just awesome
@Ajithkumarsekar96
@Ajithkumarsekar96 6 жыл бұрын
12:30 very true words
@Aragubas
@Aragubas 8 ай бұрын
wow great video
@_sudipidus_
@_sudipidus_ 4 жыл бұрын
I guess I am not ready for this yet.. but I will come again soon :)
@whocares3061
@whocares3061 8 жыл бұрын
sehr gutes video!
@kimchi_taco
@kimchi_taco 6 жыл бұрын
the world is wide and genius are abundant
@supertren
@supertren 8 жыл бұрын
wow!!. Thank you very much!.
@revoiceful
@revoiceful 7 жыл бұрын
Thank u so much
@lilp4p1
@lilp4p1 8 жыл бұрын
i love youre videos :)
@F1mus
@F1mus 6 жыл бұрын
Very cool video :)
@ifthekharhasan7817
@ifthekharhasan7817 8 жыл бұрын
Just awesome.
@hiimthelegend6644
@hiimthelegend6644 6 жыл бұрын
You recommend some documentation but it's good to paste links for them in the description of video.
@sagarbanwa218
@sagarbanwa218 6 жыл бұрын
Is it possible to write root exploit with this ?? Just a question still I am a learner
@zatochiSiberian
@zatochiSiberian 4 жыл бұрын
Thanks!
@markmadafaka5633
@markmadafaka5633 5 жыл бұрын
can you help me to fix this issue? warning: implicit declaration of function ‘write’ [-Wimplicit-function-declaration] 2 | write(1, "HACK ", 5); |
@Leo-il2hs
@Leo-il2hs 5 жыл бұрын
Hi, the 'write' function is defined in the header 'unistd.h'. linux.die.net/man/3/write You need to include it by adding at the beginning of your source file "#include " (without the quotes). I don't know why he doesnt need it in the video ; it s weird...
@gardedesombres3254
@gardedesombres3254 4 жыл бұрын
Thank you. Is there a book or a resource where can i learn this kind of stuffs deeply ?
@BeLuckyDaf
@BeLuckyDaf 4 жыл бұрын
Hey there, yes here are the two books you'll get the most of it from. Modern Operating Systems, by Andrew S. Tanenbaum; The Linux Programming Interface , by Michael Kerrisk.
@robbrock9766
@robbrock9766 8 жыл бұрын
I love your videos, can you do a video going over the Memory Sinkhole issue on x86 intel chips. I saw a video on it but I would love to see the code to make it happen.
@procrast
@procrast 6 жыл бұрын
yeah, thank you
@HootanHM
@HootanHM 6 жыл бұрын
It's ~9 years that I'm learning about computers. so, I already know something. I was thinking how many years I would have saved if there was someone to teach me these things as you do. please go on with this series. and if you have some experience in embedded systems security, please share it with us. It would be fun to hack into things and learn how to write more secure code. tnx
@kumarkumar-md7ee
@kumarkumar-md7ee 4 ай бұрын
awesome!!!!!
@carlosgarcialalicata
@carlosgarcialalicata 3 жыл бұрын
I would like to see such a deep dive for hypervisor. and maybe compare with this. PS: how can I give double or triple likes to a video?
@Borgimanio
@Borgimanio 9 жыл бұрын
Where did you learn all this? All by yourself or somewhere in university?
@LiveOverflow
@LiveOverflow 9 жыл бұрын
+Borgimanio Mostly by myself. I studied computer science and I went to an IT school. So those lectures certainly provided some information that helped to get me started.
@pedrofam8302
@pedrofam8302 3 жыл бұрын
god, this is awsome
@vequeemnheveque3778
@vequeemnheveque3778 8 жыл бұрын
Thanks
@Alexex2353
@Alexex2353 Жыл бұрын
I understood barely a 10% of that, but very interesting
@unicojeito
@unicojeito 6 жыл бұрын
Best video ever! Thanks. Just didn't get at 6:48 when it shows four gdb windows and the note says "look at the address of main() it's always 0x4005db"
The deal with numbers: hexadecimal, binary and decimals - bin 0x0A
8:26
Ful Video ☝🏻☝🏻☝🏻
1:01
Arkeolog
Рет қаралды 14 МЛН
Counter-Strike 2 - Новый кс. Cтарый я
13:10
Marmok
Рет қаралды 2,8 МЛН
Маусымашар-2023 / Гала-концерт / АТУ қоштасу
1:27:35
Jaidarman OFFICIAL / JCI
Рет қаралды 390 М.
How Do Linux Kernel Drivers Work? - Learning Resource
17:02
LiveOverflow
Рет қаралды 568 М.
How Docker Works - Intro to Namespaces
12:56
LiveOverflow
Рет қаралды 172 М.
Linux Kernel 6.12 | This is Historic
1:07:22
Maple Circuit
Рет қаралды 128 М.
Fast Inverse Square Root - A Quake III Algorithm
20:08
Nemean
Рет қаралды 5 МЛН
I Designed My Own 16-bit CPU
15:46
AstroSam
Рет қаралды 2,1 МЛН
The mind behind Linux | Linus Torvalds | TED
21:31
TED
Рет қаралды 6 МЛН
But, what is Virtual Memory?
20:11
Tech With Nikola
Рет қаралды 342 М.
How Linux Kernel Runs Executables
16:46
Nir Lichtman
Рет қаралды 53 М.
The Making of Linux: The World's First Open-Source Operating System
11:33
ForrestKnight
Рет қаралды 1,3 МЛН
Ful Video ☝🏻☝🏻☝🏻
1:01
Arkeolog
Рет қаралды 14 МЛН