1 / 17

Understanding CPU and Memory in von Neumann Architecture

Learn about the CPU components (ALU, Control Unit, Registers), Memory, and Input/Output in the von Neumann Architecture. Explore how instructions are stored, executed, and the differences between memory and registers. Discover how the Control Unit fetches, decodes, and executes instructions and how the program counter determines the next instruction to be executed. Gain insights into the high-level view of program execution and the translation of programs from high-level languages to machine language.

Download Presentation

Understanding CPU and Memory in von Neumann Architecture

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. Lecture 9 Stored Program Concept: The Hardware View

  2. The von-Neumann Architecture • Processor • Memory • Input/Output carries out instructions temporary storage allows user interaction

  3. CPU – Central Processing Unit • ALU – arithmetic and Logic Unit performs operations on data (e.g. add, subtract, AND, OR) • Control Unit – oversees functions of CPU • Registers – memory locations built into the CPU for current data

  4. CPU – Central Processing Unit Registers Control Unit (CU) Bus ALU (Arithmetic Logic Unit)

  5. Registers Control Unit (CU) Bus ALU (Arithmetic Logic Unit) Memory and the CPU MEMORY

  6. What is stored in Memory? • Instructions • Data Example of instructions: ADD R0, R2, R1 SUB MEM7, MEM1, MEM9

  7. Executing an Instruction Example: SUB MEM7, MEM1, MEM9 • Copy the value from MEM1 to a register (say R1). • Copy the value from MEM9 to a register (say R2). • Tell the ALU to subtract R1-R2. • Put the sum into location 7 in memory.

  8. Memory vs. Registers • Registers hold the values that the ALU is currently working with. Registers are accessed very fast. • Memory is larger (holds more data), is more permanent than registers, and slower.

  9. Control Unit • Fetch instruction from memory • Decode instruction • Execute instruction

  10. 1: Fetch instruction from memory Copy the next instruction into a special register call the instruction register. How do we know which is the next instruction? Its address is in a special register called the program counter.

  11. 1: Fetch instruction from Memory Example: Program Counter (PC) has the value 10. The control unit fetches the instruction sitting at location 10 in memory, and copies it into the instruction register.

  12. 2: Decode the instruction Break up the instruction into its parts: • Operation (add, sub, etc) • Data (copy data from memory if necessary)

  13. 3: Execute Configure the ALU and the buses to carry out the instruction. (the actual operation is executed by the ALU)

  14. Example of Fetch-Decode-Execute • Say PC=10, the control unit copies an instruction from location 10 in memory into the IR. • Decode the instruction into its parts: SUB R0 R1 R2 • Set the ALU to subtract and set the buses to send registers R1 and R2 to the ALU

  15. Changing the program counter There are two ways to change the program counter: The normal way is that after executing an instruction, the control unit increments the Program counter PC=PC+1 The following instruction in memory will be executed next.

  16. Changing the PC (#2) A jump instruction sets the PC to a certain location in memory. Example: JUMP MEM87 This instruction means: jump to memory location 87 and continue executing. PC = 87

  17. “High-Level” View • A user writes a program in a high-level language (e.g. C++) • The program is translated by a compiler into machine language • The CPU executes the machine language instructions (fetch-decode-execute cycles)

More Related