Running a Buffer Overflow Attack - Computerphile

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

КОМЕНТАРІ • 1,2 тис.

  • @aadeshsalecha4951
    @aadeshsalecha4951 8 років тому +2242

    This was by far the best video.....
    Normally Computerphile tries to address a wider audience, but I personally would like to see more of these kind of in-depth videos.

    • @kipchickensout
      @kipchickensout 6 років тому +10

      exactly

    • @CP-hd5cj
      @CP-hd5cj 6 років тому +38

      Check out liveoverflow if you like this. He has tons of similar stuff, and decently in-depth

    • @dvorak2676
      @dvorak2676 5 років тому +11

      this is an introduction

    • @iraianbu3388
      @iraianbu3388 5 років тому +2

      May i know what content is on cat shell_code

    • @cheesescrust5399
      @cheesescrust5399 4 роки тому +5

      Dvo rak yeah I learned how to do basic stack overflows and run stack overflows back in the XP days, but I never learned in depth, complex attacks. I learned enough to run a debugger, find the memory address, write a nopales, etc but I never got deep enough to learn heap spraying, etc. They can get really complex now to bypass ASLR and other measures. I am trying to revisit this and learn more!

  • @tristant9686
    @tristant9686 8 років тому +2770

    You can see he is very excited to tell this.

    • @mcx6-e9d
      @mcx6-e9d 6 років тому +71

      Tristan T I'm excited to learn this.

    • @germangamingvideos6069
      @germangamingvideos6069 6 років тому +10

      @@mcx6-e9d Me too

    • @matze3596
      @matze3596 6 років тому +25

      Frist time he can show what i spend his time on...Most people would not listen maybe cause they dont understand or maybe because they believe its something illegal.

    • @buzifalus
      @buzifalus 5 років тому +7

      Because people are usually not interested or afraid of complex computer stuff

    • @iraianbu3388
      @iraianbu3388 5 років тому +1

      May i know what content is on cat shell_code

  • @MaxJNorman
    @MaxJNorman 8 років тому +4075

    I really like this guy

    • @TheCFJB
      @TheCFJB 6 років тому +60

      I'd 100% agree.

    • @gregoriysharapov1936
      @gregoriysharapov1936 6 років тому +17

      Absolutely, max!

    • @benchiang8235
      @benchiang8235 5 років тому +21

      Me too, he's cool.

    • @gentiorelon
      @gentiorelon 5 років тому +100

      It's refreshing to see positivity and enthusiasm towards typically dry subjects. This whole channel is great, but this guy in particular is probably their most enjoyable to watch.

    • @ashleybishton742
      @ashleybishton742 5 років тому +10

      Dude can hack anything I bet lol. He could devastate a system lol

  • @ElagabalusRex
    @ElagabalusRex 8 років тому +1187

    I would love to see a series on micro-architectures, machine code, and assembly

    • @TheRomichou
      @TheRomichou 8 років тому +10

      +ElagabalusRex Agreed!

    • @Funderpanda
      @Funderpanda 7 років тому +6

      and micro-waves!

    • @akam9919
      @akam9919 7 років тому +1

      Yes!

    • @kanpitcha54
      @kanpitcha54 6 років тому

      please!

    • @AbuDoujana
      @AbuDoujana 6 років тому +9

      @stephen schneider it may be tricky but it is definitely not 'insanely hard'... U just need to know at least the basics of forward programming ( C programing for example) and you can start from there, i would say i love it more than any other field but everyone has an opinion

  • @ItsNotJustRice
    @ItsNotJustRice 3 роки тому +159

    I know this particular video was years ago, but this guy is actually fun to watch. I'm terrible at learning, but he makes sense of a lot of things without dragging on the boring part.

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

      Are you that mad at someone you don’t even know?

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

      @@Stopinvadingmyhardware You replied to the wrong guy

  • @colossalbreacker
    @colossalbreacker 4 роки тому +33

    I'm a cs major, but I don't normally like watching cs related youtube channels. These videos are awesome though, some of them are things I thought I had a decent grasp on and I end up learning something. I also love how happy Dr. Pound seems when he is talking about something, you can tell he really likes what he does.

  • @ButzPunk
    @ButzPunk 8 років тому +356

    This was brilliant. More like it, please!

    • @cloveramv
      @cloveramv 6 років тому +1

      Powerrrrrrrrrrrrrrrrrrrrrrr
      BUHAHAHAHAHAAHAHA
      whoami
      .
      .
      I am root baby.

    • @iraianbu3388
      @iraianbu3388 5 років тому

      May i know what content is on cat shell_code

    • @Triantalex
      @Triantalex Місяць тому

      false.

  • @Elite7555
    @Elite7555 3 роки тому +41

    Absolutely brilliant demonstration. All universities that I know teach C/C++, but they don't teach the essence of software security, which should be pounded into every student's head right from the beginning.

    • @NightLife094
      @NightLife094 2 роки тому +8

      In my university in germany, they taught us these. But i mean the courses are called cybersecurity and reverse engineering

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

      @@NightLife094same. The info was taught in an intro to cyber course which made us do a lab that required us to attain root access using buffer overflow just like in the video.

    • @Triantalex
      @Triantalex Місяць тому

      false.

  • @IrishH2
    @IrishH2 5 років тому +11

    Fun fact, buffer overflows are where most of the famous glitches in the original Pokemon games come from. From Missingno. to fighting Professor Oak, to getting a Mew in Cerulean City. All done through buffer overflowing and putting numbers where they shouldn't be.

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

      Interesting. Those games were coded directly in assembly though so I don't think they used stack-allocated buffers.

    • @JohnDoe-m8i
      @JohnDoe-m8i 3 місяці тому

      @@williamdrum9899 How else are they meant to store information?

    • @williamdrum9899
      @williamdrum9899 3 місяці тому +1

      @@JohnDoe-m8i Back then it was easier to predefine your array sizes since you had complete control over the CPU and memory. The downside to this is that you had no segfaults or anything to stop a mistake like a buffer overrum

  • @dantesalighieri
    @dantesalighieri Рік тому +1

    The way this man explains things is absolutely DIAMOND.

  • @qgysugfq3935
    @qgysugfq3935 2 роки тому +9

    This hits especially hard since I just finished my assembly and computer systems class. Great video!

  • @jurepustoslemsek7882
    @jurepustoslemsek7882 5 років тому +2

    I watched this a long time ago, but after taking an Assembly class in uni, I suddenly completely understand what he did and why it works! this is an absolutely amazing video as it actually gives an incentive to continue learning low-level programming and such.

  • @realeques
    @realeques 8 років тому +121

    i love how he explains every topic like its the best in the world... i could use him as my personal coach !

  • @TheMagAirsoft
    @TheMagAirsoft 4 роки тому +1

    Dr Mike Pound, i do not know if you know this but you are saving a lot of network security students with your videos on these subjects. They are incredibly informative and makes a whole subject comprehensible in the matter of minutes. A Great thank you.

  • @34521ful
    @34521ful 6 років тому +6

    Just a slight error for future viewers, at the 7:10 minute mark, he points from "a" to the start of "buffer". What he meant was that we are at "ebp" to the start of the buffer is what sub $0x1f4, %esp does :)

    • @mustafadurukan6893
      @mustafadurukan6893 5 років тому

      So the buffer starts from esp minus 500 and the buffer progresses towards ebp, right?

  • @sivalley
    @sivalley 8 років тому +646

    To err is human, but to really foul things up requires the root password.
    -Unknown

    • @U014B
      @U014B 8 років тому +5

      Love it.

    • @sophiacristina
      @sophiacristina 5 років тому +11

      It was Aristotle!

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

      sivalley Stealing-no, borrowing this

    • @xBZZZZyt
      @xBZZZZyt 4 роки тому +4

      Or SUDOer's password.

    • @masonhunter2748
      @masonhunter2748 4 роки тому +4

      To err is human.
      -Grammarly

  • @Anvilshock
    @Anvilshock 8 років тому +163

    Nice presentation, thanks! It would be even nicer to have the stack video segment made clickable, given UA-cam's tendency to "Suggest" everything but related videos.

    • @Computerphile
      @Computerphile  8 років тому +35

      +Anvilshock I'll sort that! >Sean

    • @Anvilshock
      @Anvilshock 8 років тому +2

      ***** Much obliged, thanks!

    • @zavvie809
      @zavvie809 8 років тому +2

      +Computerphile I suggest heap sort for that.
      :)

    • @MamboBean343
      @MamboBean343 8 років тому +3

      +Computerphile Still not really fixed. It's currently neither a card or an annotation.

    • @ChaimS
      @ChaimS 8 років тому

      +Anvilshock Also, it would be awesome if it was mentioned where in the video he talks about them, since we may not necessarily have 10-15 minutes to watch the whole video.

  • @jonahansen
    @jonahansen 6 років тому +2

    Damn! Excellent presentation on how stack overflow exploits work! No hand-waving; a complete demonstration of how it's done, down to aligning the return address and the no-op sled mitigation.

  • @DFX2KX
    @DFX2KX 8 років тому +52

    messing with, and forcibly messing with the stack is the source of a few old school console hacks if I recall, particularly on NES games. You write memory by doing very specific things to set certain memory values in an unusual way

    • @hamstsorkxxor
      @hamstsorkxxor 8 років тому +21

      Pokemon! If I remember correctly, that missingno nonsense in Pokemon Red was a stack overflow.

    • @UmVtCg
      @UmVtCg 8 років тому +2

      The game genie does this

    • @ns2304
      @ns2304 3 роки тому

      Think its how PS1 and onwards did it as well. Gameshark and Gamemaster ripped the values off the game corresponding to a particular attribute. Then you tweak the code to get outcome like inf items, inf health etc. Never knew this was the science behind it hah

  • @johnconnor7978
    @johnconnor7978 6 років тому

    The only truly knowledgeable bunch of geeks on the internet that also know how to explain what they know. You sirs earned by EIP hi5

  • @geonerd
    @geonerd 8 років тому +83

    Mike has a certain Dr. Evil vibe in that he clearly enjoys writing "Malicious Code." :)

  • @ne12bot94
    @ne12bot94 6 років тому

    Excellent job on video, I still don't understand why ppl hate your video. Your is more detailed and professional , then the other I video saw on UA-cam.look like they don't know what there talking about.

  • @x1g5dj7dh4
    @x1g5dj7dh4 8 років тому +13

    This was amazingly informative, especially for someone not using Linux. Well done!

  • @cyberwithtom7714
    @cyberwithtom7714 5 років тому +1

    for years ive been reading and trying to work out the ins and outs of bufferoverflow i can honestly say this is one of the most simple and effective videos out there on BO well done and Kudos loved watching it (for the 100th time)

  • @lolbajset
    @lolbajset 8 років тому +29

    I absolutely love videos on things like malware, exploits and similar stuff, feel free to upload more of it if you can :D

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

    Might be by far the best explanation i’ve ever watched

  • @gassnake2004
    @gassnake2004 8 років тому +23

    Great video! There's a lot of virus "concept" videos that explain how they work, but not many that show the actual implementation and writing of specific attacks. More please!

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

    Best explanation of a buffer overflow I’ve ever seen.

  • @__-xl1zi
    @__-xl1zi 5 років тому +240

    Everyone else:
    *makes a 20 char buffer*
    Mike: "We allocate a buffer that's 500 characters long"

    • @username17234
      @username17234 5 років тому +44

      You need the buffer to be big enough to be able to comfortably hold your machine code plus a hefty padding for memory address variations.

    • @dicksonZero
      @dicksonZero 5 років тому +67

      still wondering how he is going to type all 500 characters until he pulls out his python

    • @cheesescrust5399
      @cheesescrust5399 4 роки тому +3

      Eduardo I didn’t think it matters. I thought even small buffers could be exploited because the exploit payload just overflows and gets thrown into the stack. As long as you nopsled is hit by the pointer it just keeps running until it hits the return address which jumps to the shell code? Is that not correct?

    • @rampage_sl
      @rampage_sl 4 роки тому +8

      @@dicksonZero I see what you did there

    • @mu11668B
      @mu11668B 4 роки тому

      Well...
      If I'm not writing codes for dev boards that has memory capped at few KBs, I usually allocate a lot more, like 4096 bytes.
      It has hardly any drawback for machines with GBs of RAM and lowers the risks of writing data beyond the buffer zone.

  • @sweetspotendurance
    @sweetspotendurance 8 років тому +1

    I am a C++ programmer and this is an awesome easy-to-understand introduction to gdb. Thanks for this video, I love low level C, bash, and Linux commands (like the Heartbleed video, for example)

    • @JuddMan03
      @JuddMan03 8 років тому

      Gdb is damn good. Also try valgrind

  • @JaisMathews
    @JaisMathews 4 роки тому +11

    It would have been pleasure to sit in his classes. We need more professors like this.

  • @jasonford2877
    @jasonford2877 5 років тому

    This video explains it better than a $2000 course I've been doing in Cyber Security (which goes into far more than just BOF) Drawing it tremendously helped me understand it!

  • @MrJoao6697
    @MrJoao6697 8 років тому +5

    What a video! Great job on explaining this attack, I'll definitely be looking forward to learn more of this as I get into assembler at University!

  • @dingdong3021
    @dingdong3021 4 роки тому

    Seriously im going all around youtube looking for perfect explanation of buffer overflow. I always ignore this video thinking that it wont explain it. But man i was wrong. the best video about buffer overflow explaining things like nopsled deym. Tyyyyy

  • @xSCOOTERx2
    @xSCOOTERx2 8 років тому +11

    Had this for a homework assignment. It was quite hard to understand how to manipulate the stack at first, but this video helped a lot.

  • @paladinpaterson5385
    @paladinpaterson5385 7 років тому

    Been reading my textbook for a while wondering what the hell the author is talking about and you cleared it up in the first fifteen seconds. Thanks!

  • @furetosan
    @furetosan 8 років тому +13

    Awesome video. Especially the bit about the no-op slope.

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

    Ok, I was finally able to translate from Brit: "Buffalo, Buffalo at Work" =="Buffer Overflow Attack" Great video and explanation.

  • @hellterminator
    @hellterminator 8 років тому +450

    And this, kids, is why you should always sanitize your inputs.

    • @michaeltorres1263
      @michaeltorres1263 8 років тому

      +hellterminator HAHAHAHAAHA!

    • @SUFHolbek
      @SUFHolbek 8 років тому +23

      +hellterminator Little Robby Drop Tables

    • @hellterminator
      @hellterminator 8 років тому +8

      Simon WoodburyForget Interesting language. I'm probably gonna stick with C/C++, but Rust is definitely interesting.

    • @Triantalex
      @Triantalex Місяць тому

      false.

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

    youtube algorithms are like now this guy has just finished watching bootstrap in 1 hours & that more than enough to recommend him buffer overflow attack videos

  • @HavelockBanana
    @HavelockBanana 8 років тому +6

    yeah! A technical video :-) Nice to see some actual code on this channel (even though it's being explained in a simple way :) )

  • @JaceLansing
    @JaceLansing 4 роки тому +1

    Man! How am I only finding your channel now!? This was great. Thank you for taking the time to put this together.

  • @saultube44
    @saultube44 7 років тому +8

    The guy is quite smart and he knows his stuff

  • @Tithis
    @Tithis 6 років тому

    Studying for a security certificate and was having a hard time understanding exactly what was going on with the way they explained it in their videos. Your video really helped me understand it better, mostly by visualizing how the memory is laid out.

  • @eliausi9696
    @eliausi9696 8 років тому +7

    Welldone on explaining this so well

  • @0noam
    @0noam 5 років тому

    it has taken me at least 5 times the duration of the video and a lot of zapping around to understand most of it. but it was extremely instructive, so thank you.

  • @tiannimyers1204
    @tiannimyers1204 5 років тому +3

    The more I learn about computers, the more I realize how easy they are. Great video.

  • @timm9301
    @timm9301 5 років тому

    I have studied exploit dev for a number of years and this is by far one of the best explanations ever! Keep it up!

  • @athanoslee
    @athanoslee 8 років тому +212

    I like his playful manners and smiles. I think I have a crush.

    • @nofrag25
      @nofrag25 6 років тому +21

      He s married bro

    • @firstnamelastname7319
      @firstnamelastname7319 6 років тому +81

      I want him to overflow my buffer 😍

    • @jscorpio1987
      @jscorpio1987 5 років тому +10

      Thibaud so? Are we supposed to intensively research a person’s personal life now to make sure they’re absolutely 100% single before we’re allowed to have an innocent crush on them? It’s not as if you can control such feelings and it’s not like OP was exactly sending the guy a marriage proposal.

    • @kbs1212
      @kbs1212 4 роки тому +4

      J T Maybe OP isn’t but I am. Marry me Mr. Pound

    • @untilted9126
      @untilted9126 4 роки тому

      I do as well

  • @MarcinKonarski
    @MarcinKonarski 8 років тому

    One of the best videos on Computerphile. Mike really knows his trade.

  • @GenGariczek
    @GenGariczek 8 років тому +16

    More on similar topics please :)

  • @shumakriss
    @shumakriss 8 років тому

    Thank you! I've never seen this explained in its entirety and there are lots nuances that have always inhibited my own educational endeavors. Knowing GDB, assembler, endianness, no-op sleds, etc were all concepts I understood but could never completely tie together. Excellent video.

  • @MiSt3300
    @MiSt3300 4 роки тому +14

    Apart from the attack, it's so interesting to see how the computer actually processes the programme... I mean, I never really thought about it, that all the functions and returns and variables have to be stored somewhere and that it has to know how to execute it... I really like to think of a computer as a human being XD

  • @anyonetube
    @anyonetube 8 місяців тому

    the first 3 minutes of video give me more efficient information than any other videos i watched about this title

  • @user-eh5wo8re3d
    @user-eh5wo8re3d 8 років тому +7

    very nice Video. would love to See more of this sort in the future

    • @gegdim9307
      @gegdim9307 8 років тому +2

      Fear not my friend! Botnets and iPhone decryption coming soon!

    • @user-eh5wo8re3d
      @user-eh5wo8re3d 8 років тому

      Well that is a truly marvelous thing to hear. Am looking forward to it!

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

    the stack content visualization and the no-op sled animation were really awesome

  • @DrRChandra
    @DrRChandra 8 років тому +36

    On the original diagram: Functions do not (normally) go on the stack. The stack is only data (including return addresses). With architectures having hardware support for not executing data (often called an "NX" bit), such as a lot of the Intel processors, trying to execute a function on the stack with the NX bit set would cause an exception, which in Linux in turn would generate a signal (something like SIGSEGV), and without a signal handler would kill the process. (Yay, memory protection!)
    oh...and I think you mean backslash x ninety.

    • @Computerphile
      @Computerphile  8 років тому +21

      +rchandraonline I've a feeling that's what Mike was talking about at the end.... >Sean

    • @DrRChandra
      @DrRChandra 8 років тому +12

      ***** , oh, yeah...
      As Mike says (paraphrasing), there are so many things which would make great videos on what goes on in GDB and assembly...simply fascinating how all that stuff was developed over the years.

    • @JAN0L
      @JAN0L 8 років тому +4

      +rchandraonline Function code doesn't, but all the local variables used by the function go on stack, otherwise recursive functions wouldn't be possible.

    • @NyanSten
      @NyanSten 8 років тому +2

      +rchandraonline For running shell (or other simple tasks), NX bit is quite easy to workaround with return-to-libc attack. But that can be hardened with address randomization.

    • @GegoXaren
      @GegoXaren 8 років тому

      gcc -fstack-protector-strong -std=c11 foo.c -o foo

  • @hannahwhitham3539
    @hannahwhitham3539 4 роки тому

    I'm so happy this channel exists

  • @VaultRaider
    @VaultRaider 8 років тому +25

    These types of videos are better than the robots/drones stuff

    • @anujmchitale
      @anujmchitale 5 років тому

      Not for a person who isn't interested in SW security or programming in general.

  • @ghnna
    @ghnna 7 років тому

    this guys is my favourite out of all others on Computerphile tbh

  • @Tommus1997
    @Tommus1997 6 років тому +46

    "I'm assuming you know what a stack is."
    *defines function*

    • @Juasml
      @Juasml 5 років тому +19

      When you know a lot about something, sometimes it's hard to tell when you're being overwhelming and when you're going too slow. I guess he just randomizes it to keep going.

    • @dderudito
      @dderudito 4 роки тому

      Hahaha

    • @jag831
      @jag831 4 роки тому +1

      Haha that's why I love this kind of videos. "Look at this ebp register, for example. B stands for base and B is the second letter of the latin alphabet. It is allocated in 0x6404whatever5A in memory"

    • @fetchstixRHD
      @fetchstixRHD 3 роки тому +1

      To be fair, there was the video on stacks which anyone who wasn't familiar with could go and watch, so there isn't [wasn't] much point of repeating what's been done already.

  • @panman101mw3
    @panman101mw3 6 років тому

    I don't know why, but this felt a lot more interesting than all the other topics he's talked about. Rock on!

  • @5upl1an
    @5upl1an 5 років тому +15

    The real question is, how can someone be so damn motivated at 7 in the morning?!

  • @nikhilnarayanan5949
    @nikhilnarayanan5949 5 років тому

    This channel is by far one of the best....I made a computer application similar to chain reaction using the swing framework of java....I got a stackOverFlow error because of infinite recursion....this video really sorted me out....thanks!!!😁😁😊

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

    I really liked the way he taught, didn't get it,but liked it xD

  • @Edgewalker001
    @Edgewalker001 8 років тому +1

    This is actually very interesting, because the noop sled trick actually reminds me of something we use when looking for things in genetic code. I guess there is a lot of overlap that isn't immediately apparent between programming and genetics.

    • @MrTridac
      @MrTridac 8 років тому +1

      +Edgewalker001 I learned programming first and then genetics, and all I see when I look at DNA is program code. It's a state machine, a sequencer and self modifying code at the same time. Awesome!

  • @harleyspeedthrust4013
    @harleyspeedthrust4013 7 років тому +8

    Ignorant friend: "Why would you ever use Assembly?"
    Me: "..."

  • @ITRIEDEL
    @ITRIEDEL 6 років тому

    Finally a solid explanation of BO’s

  • @another-person-on-youtube
    @another-person-on-youtube 4 роки тому +20

    "Can't type while people are watching."
    I'm not the only one!

  • @Aemilindore
    @Aemilindore 8 років тому +1

    I truly love the method Cumputerphine explains things. These are very advanced concepts explained so simply. Hats off for your effort.
    I am a researcher in the field of WSN. But I truly love this type of work. I would love to know what research field are related to this type of work.
    Once again. Great explanation. Love your videos!

  • @woutervandenputte1356
    @woutervandenputte1356 6 років тому +6

    at 13:40 which command exactly do you use to list those 200 registers at the stack pointer minus 550

    • @nahue345
      @nahue345 5 років тому +3

      x/200xg $rsp (i think)

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

      i dont get why stack ptr minus 550 but not just 508 if the program stopped at the return address, can anyone explain it please ?

  • @Denverse
    @Denverse 4 роки тому

    Today is the day I finally exploited a full buffer overflow attack to gain shell.
    Thank you Mike.
    And the animation is so helpful.

  • @ttttt_
    @ttttt_ 8 років тому +302

    "there is nothing you can't do as root"
    except makepkg on arch :(

    • @nik123true
      @nik123true 8 років тому +2

      nice one xD

    • @sauron1427
      @sauron1427 8 років тому +49

      but you can create a user with whatever password you like, su into that user and run makepkg. you can still get ANYTHING done if you have root access.

    • @pedro.raimundo
      @pedro.raimundo 7 років тому

      I LOLed.

    • @cybrhckr
      @cybrhckr 7 років тому +8

      and some programmes does not allow you to run on root :D for security reasons

    • @Reth_Hard
      @Reth_Hard 6 років тому +5

      You can't run VLC on root :(
      But you can patch it easily :)

  • @DArnez-c5n
    @DArnez-c5n 4 роки тому

    Very clearly explained... I have been looking for a tutorial like this for about ten years.

  • @anirudhsarma4233
    @anirudhsarma4233 8 років тому +8

    Can anyone explain why 10 duplicates of the return address was needed as "padding"?

  • @mOczakowski
    @mOczakowski 6 років тому

    These type of guys gimme the chills, he's literally accessing chip register buffer memory, and it's making him giddy... YAIKS!

  • @umarsalmanrao5
    @umarsalmanrao5 5 років тому +3

    13:53 which command did he use here?
    x/200x $(ebp-100)
    Was it this?

  • @hassanussutteri170
    @hassanussutteri170 6 років тому +1

    You can truly see the passion gleaming outta his face it's so obvious and i love that so much reminds me of myself :) he can barely stop smiling i love this guy!

  • @ryanofarrell186
    @ryanofarrell186 8 років тому +103

    Video is 17:29 long.
    Mathematicians, unite!

    • @tennicktenstyl
      @tennicktenstyl 8 років тому +11

      What's so special about this? I'm not familiar with numbers and stuff

    • @Keithfert490
      @Keithfert490 8 років тому +65

      It's the smallest "taxi cab number": a positive integer expressible as the sum of two positive integer cubes in two different ways (1729=12^3+1^3=9^3+10^3).

    • @tennicktenstyl
      @tennicktenstyl 8 років тому +10

      Oh, that's nice.

    • @sadrien
      @sadrien 8 років тому +56

      Don't worry if you don't understand why that is important, because it really isn't.

    • @AndyChamberlainMusic
      @AndyChamberlainMusic 7 років тому +6

      Keith its not the smallest taxi cab number lol it was just the number of a cab which some guy noticed was a boring number and then he told his even smarter friend that it was boring to which the smarter friend said na bro its the smallest number that you can get by adding two cubes in two different ways

  • @stephana7785
    @stephana7785 4 роки тому

    Best explanation of shell code injection by far!

  • @GegoXaren
    @GegoXaren 8 років тому +5

    and this, kids, is why strcpy is removed from C11.
    Many of the string functions were removed and replaced with safe versions in C11.

    • @GegoXaren
      @GegoXaren 8 років тому

      also use
      -fstack-protector,
      -fstack-protector-all
      or
      -fstack-protector-strong
      with gcc for non-time-critical stuff.

    • @anujmchitale
      @anujmchitale 5 років тому

      strncpy is the replacement. The n is a parameter asking how much to copy. If more than the buffer length being used, the function itself won't compile.

  • @Areejms5
    @Areejms5 5 років тому

    Thaaaaaank you soooo much, You don't know how much this video helped me understanding this topic for my finals !!!

  • @timt.4040
    @timt.4040 6 років тому +20

    Very helpful! What is the gdb command (not shown on screen) to list the 200 registers at the stack point of -550?

    • @jbrhsn8406
      @jbrhsn8406 4 роки тому

      Google it Pal!

    • @abindieflasche100
      @abindieflasche100 4 роки тому +1

      @@jbrhsn8406 what is it

    • @zerozone1412
      @zerozone1412 4 роки тому +1

      @Tim Thompson did you find out what the command was? I need it😫 ..... thanks

    • @jag831
      @jag831 4 роки тому +1

      Something like "x/500xw $esp -550" could work. I may be wrong

  • @tommybenshaul3443
    @tommybenshaul3443 6 років тому +2

    a very good video, explains beautifully the why stack works and how to exploit a buffer overflow

  • @bluekeybo
    @bluekeybo 7 років тому +9

    How would the "hacker" get the correct return address? They'd have to run gdb and list the addresses like in the video? How'd they do it automatically without root access?

    • @aneeshjoshi6641
      @aneeshjoshi6641 6 років тому +2

      I think:
      Since every process works assuming it has the full RAM and in C you can get the address of anything using & you can probably get it.

    • @chasehiatt5595
      @chasehiatt5595 4 роки тому +1

      Gdb doesn't require root access

    • @bluekeybo
      @bluekeybo 4 роки тому

      @@chasehiatt5595 interesting

    • @rrestoring_faith
      @rrestoring_faith 3 роки тому

      gdb is just a debugging tool. Can run it on any executable if you have permissions to execute that executable.

  • @Nekology87
    @Nekology87 3 роки тому +1

    wow! such an insightful glimpse at how computers "think" and Dr. Pound you are so charimastic ^___^ thank you Computerphile for this video!! I'm just begining my programing education and this fills my cup with drive to push through learning the basics knowing later i will be able to excecute as my will wills

  • @Dusk-MTG
    @Dusk-MTG 4 роки тому +6

    *Segmentation fault*
    Me: "Oh damn, I fcked up."
    Peter Parker: "That's exactly what we wanted."

  • @jongeduard
    @jongeduard 3 роки тому +1

    Really nice educational video! Learned new things here. Even as an experienced developer like me.
    So basically, this is in fact just yet another example of a "code injection", probably the most important thing that exists in the art of hacking.

  • @gabrielguedes6643
    @gabrielguedes6643 8 років тому +21

    What was the command that he typed at 13:40 ?

    • @unforkableonion5081
      @unforkableonion5081 8 років тому +27

      +Gabriel Salles I think he used the function 'x' for examine memory, something like 'x/200xw $sp-500' which means examine 200 words in hex format starting at stack pointer minus 500 ;)

    • @Eveninn
      @Eveninn 5 років тому

      @@unforkableonion5081 thank you :o

  • @soccer7901
    @soccer7901 8 років тому

    I learn more from Dr. Mike then i do from my profs at uni. You are an inspiration Sir :)

  • @CreativeVery
    @CreativeVery 6 років тому +7

    You know you're 1337 when you use Kali.

    • @mitsukaritas
      @mitsukaritas 6 років тому

      Black arch ftw

    • @mustafakhalid9348
      @mustafakhalid9348 6 років тому

      Newbies think it's cool

    • @alejandroflores7565
      @alejandroflores7565 4 роки тому

      Actually it's very handy, i've been pentesting and bug hunting for a long time and Kali is always my go-to.

  • @Acid113377
    @Acid113377 8 років тому

    probably one of the best computerphile videos yet. Thank you Dr. Pound!

  • @Calin42
    @Calin42 8 років тому +3

    when a video on the ROP chains? with ASLR on and nX :p

  • @MeditatingDennis
    @MeditatingDennis 3 роки тому

    I like how the guy gets excited and makes me excited aswell!!

  • @marsgal42
    @marsgal42 8 років тому +6

    I'm guess I'm showing my age when I mention that this was how the Morris worm back in 1988 infected systems. :-)

    • @jag831
      @jag831 4 роки тому

      Cool! I was wondering on actual, real cases in which this has happened

  • @15danie
    @15danie 7 років тому

    Like how he not only talks about stuff but also demonstrates

  • @amine250
    @amine250 3 роки тому +4

    who's watching this after the discovery of the sudo exploit ? x)

    • @loneranger4282
      @loneranger4282 3 роки тому

      what is the sudo exploit
      ?

    • @amine250
      @amine250 3 роки тому +1

      @@loneranger4282 Barron Samedit

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

    His best yet IMO. Love the level of detail and honesty enthusiasm of the topic 😁

  • @supernaturalswampaids8083
    @supernaturalswampaids8083 8 років тому +9

    Cover the iPhone/Apple/FBI issue!

    • @Computerphile
      @Computerphile  8 років тому +24

      +Reck Tominvayed Can you wait til Friday.... :) >Sean

    • @supernaturalswampaids8083
      @supernaturalswampaids8083 8 років тому +11

      +Computerphile
      Yay! Thanks for the reply as well! I'm a huge fan!
      ....but I used to be a small air conditioner.
      Had to :P

    • @jasonneu81
      @jasonneu81 7 років тому +2

      +Player Name If you used to be a small air conditioner and now you're a huge fan then you must have been an intermediate ventilation system at some point, right :D ?

  • @SaeedAlFalasi
    @SaeedAlFalasi 4 роки тому

    Iv seen a bunch of videos on the same topic BUT THIS BY FAR is the best explanation !