1 / 40

Reduced Instruction Set Computing

Reduced Instruction Set Computing. Tun,Aung Kyaw Cs-147. Overview. RISC Rationale (Reduced Instruction Set Computers) RISC Instruction Sets Instruction Pipelines and Register Windows Instruction Pipelines Conflicts RISC vs. CISC (Complex Instruction Set computers). RISC Rationale.

Download Presentation

Reduced Instruction Set Computing

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Reduced Instruction Set Computing Tun,Aung Kyaw Cs-147

  2. Overview • RISC Rationale (Reduced Instruction Set Computers) • RISC Instruction Sets • Instruction Pipelines and Register Windows • Instruction Pipelines Conflicts • RISC vs. CISC (Complex Instruction Set computers)

  3. RISC Rationale • The greater the number of instruction in and instruction set, the larger the propagation delay is within the CPU eg. 4- to -16 decoder and- 5 to-32 decoder the second one requires more time to generate its output than the first one ( first one reduces the maximum clock rate of CPU)

  4. Reasons of Reducing the time • Allow the CPU to run at a higher frequency • Perform each instruction more quickly

  5. Instruction Requirements • 1) Fetch • 2)Decode • 3)Execute

  6. Characteristics of RISC Processors • Reduced Instruction set size • Less complex Instructions • Fixed Length Instruction • Limited Loading and Sorting Instructions Access memory • Fewer Addressing Modes • Instruction Pipeline

  7. (Continued) • Large number of Registers • Hardwired Control Unit • Delay loads and Branches • Speculative Execution of Instructions • Optimizing Compiler • Separate instruction and Data Streams

  8. Fixed Length Instruction • In RISC processors, • Every instruction has the same size • Eg. Immediate mode instruction might include an 8 bit operand • Other instructions might use these 8 bits for opcodes or address information

  9. Limited Loading and Sorting Instructions Access Memory • RISC processor limit interaction with memory to loading and sorting data • If a value from memory is to be ANDed with the accumulator, • the CPU first loads the value into a register • Then performs the and operation

  10. Fewer Addressing Modes • Allow only a few addressing modes that can be processed quickly • (register indirect and relative modes)

  11. Instruction Pipeline • Like an assembly Line • Worked on simultaneously and differently • One instruction is executed while the next is being decoded • Its operands are being loaded • Next instruction is being Fetched • CPU executes one instruction per clock cycle

  12. Large Number of Registers • Why is it good? • Allows CPU to store many operands internally • CPU fetches them from the register rather than from the memory • Reduces the access time • Less space for control logic

  13. Hardwired Control • Hardwired control unit can run at a higher clock frequency than its corresponding microcoded control unit • ease of modification

  14. Delayed Loads and Branches • RISC use delay loads and delayed branches to avoid wasting time • it can avoid branch instructions or consecutive instructions which was caused by Instruction Pipeline

  15. Speculative Execution of Instructions • The CPU executes the instruction but doesn’t store its result • The result is stored if the CPU is to be executed the instruction • otherwise, the result is discarded

  16. Optimizing Compiler • It can arrange instructions to facilitate delayed loads and branches • And assign operands to registers • Fewer instructions make RISC processor to design an optimizing compiler

  17. Separating Instruction and Data Streams • The instruction pipeline may need to access instructions and operands from memory simultaneously • Separating the instruction and data streams helps to avoid memory access conflicts

  18. RISC Instruction Set • RISC processors are reduced, or smaller in size than compare to CISC processors • each instruction is executed in a single clock circle • Note: it is important not to reduce the set too much because sometimes removing instruction would decrease the system performance

  19. Types of Instructions • Basic types of instructions include • 1) data move (load, store,and register remove) • 2) ALU (arithmetic,logic,and shift) • 3) Branch Instructions

  20. Example

  21. Data Types • Generally RISC CPU operate integer and floating point • Don’t include instructions to manipulate character strings or data types directly

  22. Notes • In RISC processor,every Instruction must have the same number of bits regardless of format types • CPU must be able to access each instruction in a single memory-read operation • it will make easier in pipelining • eg. using different formats used by 32 bit SPARC CPU

  23. Example

  24. Instruction Set (continued) • Instruction set of RISC processor access memory using load and store instruction • several different types of load • LB (instruction loads a byte(8 bits) of data) • LH(instruction loads half word(16 bits)of data) • LW(instruction loads a word(32 bits)of data)

  25. Characteristics of RISC • RISC contain fewer addressing modes • common things is address can be computed in a single clock cycle

  26. Instruction Pipelines and Register Window • Two techniques commonly use in RISC processors to improve performance • 1) RISC CPU uses pipelined instruction units to break down the fetch-decode-execute procedure • process other techniques in parallel • 2)Incorporation of large numbers of registers within the CPU

  27. Instruction Pipelines • Similar to a manufacturing assembly line • Pipe Instruction works the same way as assembly line process the product

  28. Instruction Pipelines (Continued) • First stage Fetches the instructions from the memory • Second stage Decodes the instructions and Fetches any required operands • Third stage executes the instruction • Fourth stage stores the result

  29. (Continued) • Each stage processes instruction simultaneously • this allows the CPU to execute the instruction per clock cycle

  30. RISC&Stages • The first RISC computer uses a four-stages instruction pipeline

  31. Example • The flow of instruction though each pipeline • One instruction per clock cycle

  32. Pipeline control unit & Advantages • Reduce hardware requirements of the Pipeline • each state performs only a portion of the fetch-decode-and execute process,no stage needs to incorporate the hardware of a complete control unit • eg.Instruction-fetch stage need to read an instruction from the memory (doesn’t need decode or execute instructions)

  33. (Continued) • Second advantage of instructions pipelines is the reduced complexity of the memory interface • Pipeline achieves its maximum performance when all stages have the same delay

  34. Register Windowing • In RISC CPU, always accessible registers are called Global Register • The remaining are windowed • only subset of the registers are accessible at any specific time

  35. Instruction Pipeline conflicts • Two types of conflicts • 1) Data Conflicts: occur when the pipelines causes and incorrect data value to be used • 2)Branch Conflicts: occur when a branch statement results in incorrect instructions being executed

  36. Data Conflicts • It occurs in a pipeline when one instruction stores a result in a register and another instruction uses that value as an operand • occurs when one instruction stores a result in a register and subsequent instruction reads the contents of that register before first instruction has stored its result

  37. Branch Conflicts • Occurs within Branch or Jump statements in RISC instruction pipeline • it does not cause incorrect data values to be used • but it the CPU to execute instructions at a times when they should not be executed

  38. RISC vs.CISC • RISC processors have fewer and simpler instruction than CISC processors • this allow RISC to run at higher clock frequencies than CISC processors • RISC reduces the amount of space needed on the chip than CISC • RISC are less complex than CISC

  39. Conclusion • RISC characteristics • RISC Instruction Sets • Instruction Pipelines • Register Windows • Data conflicts • Branch conflicts • RISC vs. CISC

  40. Thanks You & • “Happy Thanksgivings”

More Related