Introduction to CPU Pipelining

Поділитися
Вставка
  • Опубліковано 18 гру 2024

КОМЕНТАРІ • 99

  • @donaldwright2426
    @donaldwright2426 Рік тому +5

    Breaking down technical topics like micro-electronics is not for everyone, but you've done a great job of translating something complex like a CPU pipeline into a simple, easy-to-grasp and understanding. Just thank you!

  • @eliasrezaei3931
    @eliasrezaei3931 11 місяців тому +5

    Best explanation ever! Never understood pipelining very well but your explanation made it so clear. Thanks!

  • @LG-qz8om
    @LG-qz8om 10 днів тому

    I've been a programmer for a long time and never knew this.
    Thanks.

    • @wizardcraftcode
      @wizardcraftcode  10 днів тому

      Very cool! One of the great things about this career is that there's always something new to learn. I'm glad you found something valuable here!

  • @mtushar
    @mtushar 3 роки тому +7

    Thank you, I never could before but this high level overview has helped me understand how conditional branching introduces inefficiency!

  • @vietC93
    @vietC93 21 день тому

    Thank you for sharing your knowledge! Your videos aid me apply best practices in C programming in my daily work. Going to spare more time to watch and learn from your content.

    • @wizardcraftcode
      @wizardcraftcode  20 днів тому

      Thank you for such a nice comment! I'm really glad you find them helpful!!!

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

    I just wanted to learn about if and else and got the whole pipelining information for free! Thanks very useful

  • @subhajitchatterjee1637
    @subhajitchatterjee1637 10 місяців тому +1

    I love how easy to understand this video is. Subscriber++

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

    Very nice explanation... I've been hearing about Pipelining CPUs, but until now I had no idea what they were talking about.

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

    Thank you for this. Structured, precise and to the point. I gained +5 intelligence from just this video.

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

      Thanks! That's a fun comment and I'm glad it helped!

  • @AlbertDongler
    @AlbertDongler 10 місяців тому

    Superbly explained, thank you for taking the time to put this together! 😁

  • @JJJ-ee5dc
    @JJJ-ee5dc 3 роки тому +2

    Omg so much quality content. blessed to found out this channel

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

      Tell me abt it
      Quality information for free!

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

      Thank you, both! I love it when my videos are helpful!

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

    Thanks for making this! This was very helpful. You also have a great voice for narration and excellent pace! May have to check out all your other videos :)

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

    Hey Merlin, you did fantastic job !!

  • @dghtucs
    @dghtucs 6 місяців тому

    Thank you for sharing knowledge selflessly!!!

    • @wizardcraftcode
      @wizardcraftcode  6 місяців тому

      It makes me really happy when people find them useful! Thank you!

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

    You deserve way more subs, thx :)

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

    super helpful!
    Really love how i understood it in no time

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

    Thank you for this well explanation. It's very helpful.

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

    such beautiful explanation

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

    Thanks so much for this video. I have an interview and I'm sure they will ask me about pipelining!

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

    Great explained and easy to understand!

  • @Dcatts-i2z
    @Dcatts-i2z 3 роки тому

    I'm learning scripting for now but I enjoyed this.

  • @r0m.1b
    @r0m.1b 3 роки тому

    Thanks so much for this video! Very clear insight of cpu pipelining for the noob I am 😊

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

    Thank u mam you taught it so well , please suggest a book for processor architecture( computer architecture in general)

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

      I'm glad you liked it. For a book, I like Computer Organization and Design by Patterson and Hennessy. It's the standard textbook for lots of schools. Maybe other people can chime in with other suggestions!

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

    Yo thanks , i have a very silly doubt here we saw 4 stage instructions and the first stage is fetch cycle , right? Correct me if i am wrong... In the fetch cycle the address of the instruction fetched is given to the address reg. And now the contents of the address reg is passed on the bus, then the instruction is fetched from memory right? Is the whole thing happens only at the first stage? For more clear view i will write like this
    Add reg.

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

      The stages of the pipeline all have to take the same amount of time, so they all have to be as long as the store stage. So, there's time for the fetch of an instruction in the fetch stage. The adding to the PC is done in a separate path, in parallel. That's what the Addr in that phase is doing while the fetch from memory of the instruction is happening. So, the things you wrote happen, but not sequentially. I hope that helps!

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

      @@wizardcraftcode thanks for taking your time to respond me👍

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

    what a gen! 💎 instant subscribe!

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

    Great job ! Thank you for the clear explanation, it is very helpful !

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

    Thanks for nice video and explanation. my question is "How many stages can CPU maximum does in one cycle, I mean what is the limit? I don' think that it is unlimited right?"

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

      The stages of a pipeline run in parallel meaning they all execute every cycle. In theory, you could build an N stage pipeline for any N, but, in reality, there's a limit to how many are useful.

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

    Thank you alot, lets say that we keep all the stages the same but we add an extra execution stage. Would it not affect the speed of the CPU at all?

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

      Just duplicating the existing execution stage doesn't help because you can't get two instructions there fast enough (without duplicating everything). However, all of the stages have to take the same amount of time for the pipeline to work. If you had a really long execution stage and split it into two, then the "tick" of your pipeline (how fast things go from one stage to the next) would be doubled. When your pipeline was completely full, you'd pump out finished instructions at twice the speed.

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

    And what if I have 2 pipelines. Will the speed of the CPU double?

    • @wizardcraftcode
      @wizardcraftcode  2 роки тому +2

      That would essentially be a two core CPU. If your compiler distributes things across those cores well, yes, the speed will double.

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

    Love your vids xx♥️♥️♥️♥️♥️

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

    hi, what is stall and flush and branch penalty in this concept, and what is its impact to pipeline. thank you.

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

      I didn't cover stall in this video. Some pipelines are more complicated than the simple ones I talked about here and can recognize that two sequential instructions interfere with each other. Then they are smart enough to "stall" one until the data it needs is ready. Branch penalty is what I showed here - the cost of taking a conditional branch and how that empties the pipeline. That emptying of the pipeline is what "flush" means.

  • @jpmorallo
    @jpmorallo 7 місяців тому

    This is helpful thank you

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

    for compiled languages, wouldnt the compilers optimise the conditions for the conditional branching?

    • @wizardcraftcode
      @wizardcraftcode  8 місяців тому +1

      The compiler will, and the CPU will. My goal with this video was just to give a high level view of what is happening and why you should understand it

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

      @@wizardcraftcode valuable insight you're sharing. Would love to see how the CPU might be able to do this for itself? I hadn't realised that was an option

    • @wizardcraftcode
      @wizardcraftcode  7 місяців тому

      @@BlueNSour I'll put that on the list of topics I should make videos about. Thanks!

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

    good work!

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

    now im wondering if cpu makers could improve the performance even more with parallelism on a singlethreaded application.
    so for example, if there are two paths of instructions being executed in a single code function, and some instructions didnt have much to do with others, maybe that instruction could be loaded into the cpu way before it is actually ready to be executed, and if the instruction after it doesnt rely on the result of that data, they could be processed in parallel by the same core.
    something like
    fn main() {
    let mut x = 0
    let mut y = 0
    for i in (0..1000).rev() {
    x *= 2
    y *= 2
    }
    }
    so for this code (rust), x and y are separate and dont depend on each other. would it be feasible to separate this into multiple threads purely using the cpu without any kind of explicit code to make it parallel?

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

      Actually, there are already optimizing compiler that will know to put those on different cores in your CPU. Essentially, the compiler can control the parallelism on the cores within a CPU without the programmer having to explicitly code the multi-threading.

    • @mikafoxx2717
      @mikafoxx2717 10 місяців тому

      Even single cores have had multiple execution units and do batches, they also are smart about doing things in a new order so that things don't conflict, they also use unnamed registers to start new operations that other registers haven't yet been cleared for since it's out of order. Pipelining gets you to scalar, or one operation max per clock cycle, since the Pentium 3 or something, we've done out of order super-scalar processing

    • @wizardcraftcode
      @wizardcraftcode  7 місяців тому

      That's so cool! So much magic underlying everything we do!

  • @JJJ-ee5dc
    @JJJ-ee5dc 3 роки тому

    Thanks from india

  • @Brekstahkid
    @Brekstahkid 6 місяців тому

    Awesome

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

    It's a great explanation. Are you a professor?

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

      I'm glad you like it. Yes! I am a Software Engineering professor at Shippensburg University. Don't hold that against me! :)

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

    oooommmg fuck yes the little animation is so helpful and motivating for adhd its such a relief every time hahaha

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

    Thanks lot❤

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

    ALU does not "execute" instruction, it only do the math commanded by CU. It is CU, which does execute the instruction.

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

      You are correct. It executes the math necessary for the instruction. The rest of what I talked about is the high level view of the rest of what you are talking about. This video is intentionally high level, but I could have been more precise with my language at that point.

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

    robotic sound could improve

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

      I'll try to work on that! Thanks for the feedback

  • @sreerajchundayil588
    @sreerajchundayil588 3 роки тому +7

    Overall explanation is good. But that robotic voice part is irritating.

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

      I'll have to work on being a bit more animated. Thanks for the feedback!

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

      @@wizardcraftcode don't believe that, I love the animated part!

    • @KrisRyanStallard
      @KrisRyanStallard 8 днів тому

      ​@wizardcraftcode your voice is fine and plenty animated for the topic and format. It sounds like a typical voice. I think people expect UA-cam presenters to sound like a TV presenter that works with a vocal coach.