Topics covered:
Course outline and schedule
Introduction
Computer Organization
1
General information
Course :Computer Organization
Instructor : Assoc. Prof. Abdulwahab AlSammak
Email : sammaka@gmail.com
Lecture time : Thursday 10:00pm – 12:00 pm.
Office hours : By appointment.
(I will hang around for a few minutes at the end of
each class).
Online Resources: http:// bu.edu.eg/staff/abdelwahabalsammak3-
courses/10596/files
Teaching Assistant: Eng. Mufedah Hussien
Email : whiteheart_810@yahoo.com
Office hours : Discuss with the TA
Slides Author :Swapna S. Gokhale
2
Course Objective
 Describe the general organization and architecture of
computers.
 Identify computers’ major components and study their
functions.
 Introduce hardware design issues of modern computer
architectures.
 Learn assembly language programming.
 Build the required skills to read and research the
current literature in computer architecture.
3
Textbooks
•“Computer Organization,” by Carl Hamacher, Zvonko
Vranesic and Safwat Zaky. Fifth Edition McGraw-Hill,
2002.
•“SPARC Architecture, Assembly Language Programming
and C,” Richard P. Paul, Prentice Hall, 2000.
4
Course topics
1. Introduction (Chapter 1): Basic concepts, overall
organization.
2. Addressing methods (Chapter 2): fetch/execute cycle, basic
addressing modes, instruction sequencing, assembly language
and stacks. CISC vs. RISC architectures.
3. Logic Circuits Fundamentals (Appendix A): Logic Gates,
Combinational Circuits, Sequential circuits
4. CPU architecture (Chapter 7): Single-bus CPU, Multiple-bus
CPU Hardware control, and Microprogrammed control.
5. Arithmetic (Chapter 6): Integer arithmetic and floating-
point arithmetic.
6. Memory architecture (Chapter 5): Memory hierarchy,
Primary memory, Cache memory, virtual memory.
7. Input/Output organization (Chapter 4): I/O device
addressing, I/O data transfers, Synchronization, DMA,
Interrupts, Channels, Bus transfers, and Interfacing.
5
Grading System
Midterm Exam : (25)
- Addressing methods, CISC and RISC architectures.
Lab Assignments : (25)
-7 homework assignments.
-Final : (75)
- All topics.
6
Course topics, exams and assignment calendar
Week #1 :
- Introduction
Week #2 :
- Addressing methods
- Lab. Assignment 1.
Week #3 :
-Addressing methods.
Week #4 :
- Logic Circuit Fundamentals
- Lab. Assignment 2.
Week #5 :
- CPU Architecture.
- Lab. Assignment 3.
Week #6 :
- CPU Architecture.
- Lab. Assignment 4.
Week #7 :
- Arithmetic.
7
Course topics, exams and assignment calendar
Week #8 :
Midterm Exam
Week #9 :
- Arithmetic
Week #10:
- Memory architecture.
- Lab. Assignment 5.
Week #11 :
- Memory organization
- Lab. Assignment 6.
Week #12 :
- I/O organization.
Week #13
- I/O devices.
- Lab. Assignment 7.
Week #14:
- Pipelining
Week #15:
- Final Exam
8
Grading policy
•Grading of assignments/exams is handled by the TA, if you cannot
resolve a problem with the TA, see me.
•Assignments may be submitted by email. Hard copy will also be
accepted, but you have to submit in the department office to stamp
the date. Please submit all the assignments to the TA.
• Late assignments are penalized by a loss of 33% per day late (so 3
days late is as late as you can get). Solution will be posted on the
course web page No assignments will be accepted after the solution
is posted.
•The weeks during which exams will be held have been announced.
The actual day of that week, (Tuesday) when the exam will be held
will be announced two weeks prior to the exam.
If you have any conflict with the exam date, please see me in
advance.
9
Important prerequisite material
•Digital Logic Course is fundamental to the Computer
Organization Course.
•Review issues in:
- Basic computer organization: CPU, Memory, I/O,
Registers.
- Fundamentals of combinatorial design and
sequential design.
- Simple ALU, simple register design.
10
Reading
•Reading the text is imperative. ‫إلزامي‬
(
‫أساسي‬
)
•Computer architecture especially processor design,
changes rapidly.
You really have to keep up with the changes in the
industry.
This is especially important for job interviews later.
11
Feedback
Please provide informal feedback early and often,
before the formal review process.
Content Coverage
13
What is a computer?
 a computer is a sophisticated electronic calculating machine
that:
 Accepts input information,
 Processes the information according to a list of internally
stored instructions and
 Produces the resulting output information.
 Functions performed by a computer are:
 Accepting information to be processed as input.
 Storing a list of instructions to process the information.
 Processing the information according to the list of
instructions.
 Providing the results of the processing as output.
 What are the functional units of a computer?
14
Functional units of a computer
I/O Processor
Output
Memory
Input
Control
Arithmetic
& Logic
Instr1
Instr2
Instr3
Data1
Data2
Input unit accepts
information:
•Human operators,
•Electromechanical devices (keyboard)
•Other computers
Output unit sends
results of processing:
•To a monitor display,
•To a printer
Arithmetic and logic unit(ALU):
•Performs the desired
operations on the input
information as determined
by instructions in the memory
Control unit coordinates
various actions
•Input,
•Output
•Processing
Stores
information:
•Instructions,
•Data
15
Information in a computer -- Instructions
 Instructions specify commands to:
 Transfer information within a computer (e.g., from memory to
ALU)
 Transfer of information between the computer and I/O devices
(e.g., from keyboard to computer, or computer to printer)
 Perform arithmetic and logic operations (e.g., Add two numbers,
Perform a logical AND).
 A sequence of instructions to perform a task is called a
program, which is stored in the memory.
 Processor fetches instructions that make up a program from
the memory and performs the operations stated in those
instructions.
 What do the instructions operate upon?
16
Information in a computer -- Data
 Data are the “operands” upon which instructions operate.
 Data could be:
 Numbers,
 Encoded characters.
 Data, in a broad sense means any digital information.
 Computers use data that is encoded as a string of binary
digits called bits.
17
Input unit
Input Unit
Processor
Memory
Computer
Real world
Keyboard
Audio input
……
Binary information must be presented to a computer in a specific format. This
task is performed by the input unit:
- Interfaces with input devices.
- Accepts binary information from the input devices.
- Presents this binary information in a format expected by the computer.
- Transfers this information to the memory or processor.
18
Memory unit
 Memory unit stores instructions and data.
 Recall, data is represented as a series of bits.
 To store data, memory unit thus stores bits.
 Processor reads instructions and reads/writes data from/to
the memory during the execution of a program.
 In theory, instructions and data could be fetched one bit at a
time.
 In practice, a group of bits is fetched at a time.
 Group of bits stored or retrieved at a time is termed as “word”
 Number of bits in a word is termed as the “word length” of a
computer.
 In order to read/write to and from memory, a processor
should know where to look:
 “Address” is associated with each word location.
19
Memory unit (contd..)
 Processor reads/writes to/from memory based on the
memory address:
 Access any word location in a short and fixed amount of time
based on the address.
 Random Access Memory (RAM) provides fixed access time
independent of the location of the word.
 Access time is known as “Memory Access Time”.
 Memory and processor have to “communicate” with each
other in order to read/write information.
 In order to reduce “communication time”, a small amount of
RAM (known as Cache) is tightly coupled with the processor.
 Modern computers have three to four levels of RAM units with
different speeds and sizes:
 Fastest, smallest known as Cache
 Slowest, largest known as Main memory.
20
Memory unit (contd..)
 Primary storage of the computer consists of RAM units.
 Fastest, smallest unit is Cache.
 Slowest, largest unit is Main Memory.
 Primary storage is insufficient to store large amounts of
data and programs.
 Primary storage can be added, but it is expensive.
 Store large amounts of data on secondary storage devices:
 Magnetic disks and tapes,
 Optical disks (CD-ROMS).
 Access to the data stored in secondary storage in slower, but
take advantage of the fact that some information may be
accessed infrequently.
 Cost of a memory unit depends on its access time, lesser
access time implies higher cost.
21
Arithmetic and logic unit (ALU)
 Operations are executed in the Arithmetic and Logic Unit
(ALU).
 Arithmetic operations such as addition, subtraction.
 Logic operations such as comparison of numbers.
 In order to execute an instruction, operands need to be
brought into the ALU from the memory.
 Operands are stored in general purpose registers available in
the ALU.
 Access times of general purpose registers are faster than the
cache.
 Results of the operations are stored back in the memory or
retained in the processor for immediate use.
22
Output unit
•Computers represent information in a specific binary form. Output units:
- Interface with output devices.
- Accept processed results provided by the computer in specific binary form.
- Convert the information in binary form to a form understood by an
output device.
Output Unit
Processor
Memory
Computer Real world
Printer
Graphics display
Speakers
……
23
Control unit
 Operation of a computer can be summarized as:
 Accepts information from the input units (Input unit).
 Stores the information (Memory).
 Processes the information (ALU).
 Provides processed results through the output units (Output
unit).
 Operations of Input unit, Memory, ALU and Output unit are
coordinated by Control unit.
 Instructions control “what” operations take place (e.g. data
transfer, processing).
 Control unit generates timing signals which determines
“when” a particular operation takes place.
24
How are the functional units connected?
•For a computer to achieve its operation, the functional units need to
communicate with each other.
•In order to communicate, they need to be connected.
Memory
Input Output Processor
•Functional units may be connected by a group of parallel wires.
•The group of parallel wires is called a bus.
•Each wire in a bus can transfer one bit of information.
•The number of parallel wires in a bus is equal to the word length of
a computer
Bus
25
Organization of cache and main memory
Main
memory Processor
Bus
Cache
memory
Why is the access time of the cache memory lesser than the
access time of the main memory?
Computer Components: Top-Level View
Basic Operational Concepts
A Partial Program Execution Example
A Partial Program Execution Example
Interrupt
 Normal execution of programs may be interrupted if some
device requires urgent servicing
 To deal with the situation immediately, the normal execution of the
current program must be interrupted
 Procedure of interrupt operation
 The device raises an interrupt signal
 The processor provides the requested service by executing an
appropriate interrupt-service routine
 The state of the processor is first saved before servicing the
interrupt
• Normally, the contents of the PC, the general registers, and some
control information are stored in memory
 When the interrupt-service routine is completed, the state of the
processor is restored so that the interrupted program may
continue
Classes of Interrupts
 Program
 Generated by some condition that occurs as a result of an
instruction execution such as arithmetic overflow, division
by zero, attempt to execute an illegal machine instruction,
or reference outside a user’s allowed memory space
 Timer
 Generated by a timer within the processor. This allows the
operating system to perform certain functions on a regular
basis
 I/O
 Generated by an I/O controller, to signal normal completion
of an operation or to signal a variety of error conditions
 Hardware failure
 Generated by a failure such as power failure or memory
parity error
Bus Structures
 A group of lines that serves a connecting path for several
devices is called a bus
 In addition to the lines that carry the data, the bus must
have lines for address and control purposes
 The simplest way to interconnect functional units is to use a
single bus, as shown below
Drawbacks of the Single Bus Structure
 The devices connected to a bus vary widely in their speed of
operation
 Some devices are relatively slow, such as printer and
keyboard
 Some devices are considerably fast, such as optical disks
 Memory and processor units operate are the fastest parts of
a computer
 Efficient transfer mechanism thus is needed to cope with this
problem
 A common approach is to include buffer registers with the
devices to hold the information during transfers
 An another approach is to use two-bus structure and an
additional transfer mechanism
• A high-performance bus, a low-performance, and a bridge
for transferring the data between the two buses. ARMA
Bus belongs to this structure
Software
 In order for a user to enter and run an application
program, the computer must already contain some system
software in its memory
 System software is a collection of programs that are
executed as needed to perform functions such as
 Receiving and interpreting user commands
 Running standard application programs such as word
processors, etc, or games
 Managing the storage and retrieval of files in
secondary storage devices
 Controlling I/O units to receive input information and
produce output results
Software
 Translating programs from source form prepared by
the user into object form consisting of machine
instructions
 Linking and running user-written application programs
with existing standard library routines, such as
numerical computation packages
 System software is thus responsible for the
coordination of all activities in a computing system
Operating System
 Operating system (OS)
 This is a large program, or actually a collection of routines,
that is used to control the sharing of and interaction among
various computer units as they perform application programs
 The OS routines perform the tasks required to assign computer
resource to individual application programs
 These tasks include assigning memory and magnetic disk
space to program and data files, moving data between
memory and disk units, and handling I/O operations
 In the following, a system with one processor, one disk, and one
printer is given to explain the basics of OS
 Assume that part of the program’s task involves reading a
data file from the disk into the memory, performing some
computation on the data, and printing the results
User Program and OS Routine Sharing
Multiprogramming or Multitasking
Performance
 The speed with which a computer executes programs
is affected by the design of its hardware and its
machine language instructions
 Because programs are usually written in a high-level
language, performance is also affected by the
compiler that translates programs into machine
languages
 For best performance, the following factors must be
considered
 Compiler
 Instruction set
 Hardware design
Performance
 Processor circuits are controlled by a timing signal
called a clock
 The clock defines regular time intervals, called clock cycles
 To execute a machine instruction, the processor
divides the action to be performed into a sequence of
basic steps, such that each step can be completed in
one clock cycle
 Let the length P of one clock cycle, its inverse is the
clock rate, R=1/P
 Basic performance equation
 T=(NxS)/R, where T is the processor time required to
execute a program, N is the number of instruction executions,
and S is the average number of basic steps needed to execute
one machine instruction
Performance Improvement
 Pipelining and superscalar operation
 Pipelining: by overlapping the execution of successive
instructions
 Superscalar: different instructions are concurrently
executed with multiple instruction pipelines. This means that
multiple functional units are needed
 Clock rate improvement
 Improving the integrated-circuit technology makes
logic circuits faster, which reduces the time needed
to complete a basic step
Performance Improvement
 Reducing amount of processing done in one basic
step also makes it possible to reduce the clock
period, P.
 However, if the actions that have to be performed
by an instruction remain the same, the number of
basic steps needed may increase
 Reduce the number of basic steps to execute
 Reduced instruction set computers (RISC) and complex
instruction set computers (CISC)

More Related Content

PPTX
Ptosis workup
PPT
Glaucoma good
PPT
Acanthamoeba keratitis case presentation
PPTX
Retina Grand Rounds 2015
PPTX
Fluorescein in Ophthalmology
PPTX
Glaucoma Agudo de ângulo fechado - Acute Angle-Closure Glaucoma
PPTX
Choroidal melanoma
PPTX
Advances in glaucoma surgeries
Ptosis workup
Glaucoma good
Acanthamoeba keratitis case presentation
Retina Grand Rounds 2015
Fluorescein in Ophthalmology
Glaucoma Agudo de ângulo fechado - Acute Angle-Closure Glaucoma
Choroidal melanoma
Advances in glaucoma surgeries

Similar to abdelwahab alsammak_lecture-1-Introduction.ppt (20)

PPT
Module-1.ppt............notes of coa 1st module
PPT
Coa module1
PDF
coa-module1-170527034116.pdf
PPT
lecture 1(1).ppt
PPT
Computer organisation Module 1.ppt
PDF
Computer organization and architecture|KTU
PPT
Co module1a introdctnaddressingmodes
PPTX
components of computer
PPTX
CO--MODULE-1 (a) - Basic-Structure-of-Computers.pptx
PPTX
introduction COA(M1).pptx
DOC
Ise iv-computer organization [10 cs46]-notes new
PPTX
bms_complete_co_ppt.aaaaaaaaaaaaaaaaaaaaa
PPTX
MODULE-1(a) - Basic-Structure-of-Computers.pptx
PPTX
MODULE-1(a) - Basic-Structure-of-Computers.pptx
PDF
DLD1.pdf
PPTX
Computer Organisation unit 1 basics of computer Organisation
PPT
COA-Unit-1-Basics.ppt
DOC
PPTX
Computer architecture unit 1 ppt for IT students
PDF
unit-i.pdf
Module-1.ppt............notes of coa 1st module
Coa module1
coa-module1-170527034116.pdf
lecture 1(1).ppt
Computer organisation Module 1.ppt
Computer organization and architecture|KTU
Co module1a introdctnaddressingmodes
components of computer
CO--MODULE-1 (a) - Basic-Structure-of-Computers.pptx
introduction COA(M1).pptx
Ise iv-computer organization [10 cs46]-notes new
bms_complete_co_ppt.aaaaaaaaaaaaaaaaaaaaa
MODULE-1(a) - Basic-Structure-of-Computers.pptx
MODULE-1(a) - Basic-Structure-of-Computers.pptx
DLD1.pdf
Computer Organisation unit 1 basics of computer Organisation
COA-Unit-1-Basics.ppt
Computer architecture unit 1 ppt for IT students
unit-i.pdf
Ad

Recently uploaded (20)

PDF
EXPLORING LEARNING ENGAGEMENT FACTORS INFLUENCING BEHAVIORAL, COGNITIVE, AND ...
PDF
Accra-Kumasi Expressway - Prefeasibility Report Volume 1 of 7.11.2018.pdf
PPTX
CURRICULAM DESIGN engineering FOR CSE 2025.pptx
PDF
null (2) bgfbg bfgb bfgb fbfg bfbgf b.pdf
PPTX
Management Information system : MIS-e-Business Systems.pptx
PPTX
tack Data Structure with Array and Linked List Implementation, Push and Pop O...
PDF
August 2025 - Top 10 Read Articles in Network Security & Its Applications
PDF
Exploratory_Data_Analysis_Fundamentals.pdf
PPT
Total quality management ppt for engineering students
PDF
Artificial Superintelligence (ASI) Alliance Vision Paper.pdf
PPTX
Amdahl’s law is explained in the above power point presentations
PPTX
Fundamentals of safety and accident prevention -final (1).pptx
PDF
ChapteR012372321DFGDSFGDFGDFSGDFGDFGDFGSDFGDFGFD
PPTX
introduction to high performance computing
PDF
22EC502-MICROCONTROLLER AND INTERFACING-8051 MICROCONTROLLER.pdf
PDF
Human-AI Collaboration: Balancing Agentic AI and Autonomy in Hybrid Systems
PDF
BIO-INSPIRED HORMONAL MODULATION AND ADAPTIVE ORCHESTRATION IN S-AI-GPT
PDF
August -2025_Top10 Read_Articles_ijait.pdf
PPTX
CyberSecurity Mobile and Wireless Devices
PPTX
Information Storage and Retrieval Techniques Unit III
EXPLORING LEARNING ENGAGEMENT FACTORS INFLUENCING BEHAVIORAL, COGNITIVE, AND ...
Accra-Kumasi Expressway - Prefeasibility Report Volume 1 of 7.11.2018.pdf
CURRICULAM DESIGN engineering FOR CSE 2025.pptx
null (2) bgfbg bfgb bfgb fbfg bfbgf b.pdf
Management Information system : MIS-e-Business Systems.pptx
tack Data Structure with Array and Linked List Implementation, Push and Pop O...
August 2025 - Top 10 Read Articles in Network Security & Its Applications
Exploratory_Data_Analysis_Fundamentals.pdf
Total quality management ppt for engineering students
Artificial Superintelligence (ASI) Alliance Vision Paper.pdf
Amdahl’s law is explained in the above power point presentations
Fundamentals of safety and accident prevention -final (1).pptx
ChapteR012372321DFGDSFGDFGDFSGDFGDFGDFGSDFGDFGFD
introduction to high performance computing
22EC502-MICROCONTROLLER AND INTERFACING-8051 MICROCONTROLLER.pdf
Human-AI Collaboration: Balancing Agentic AI and Autonomy in Hybrid Systems
BIO-INSPIRED HORMONAL MODULATION AND ADAPTIVE ORCHESTRATION IN S-AI-GPT
August -2025_Top10 Read_Articles_ijait.pdf
CyberSecurity Mobile and Wireless Devices
Information Storage and Retrieval Techniques Unit III
Ad

abdelwahab alsammak_lecture-1-Introduction.ppt

  • 1. Topics covered: Course outline and schedule Introduction Computer Organization
  • 2. 1 General information Course :Computer Organization Instructor : Assoc. Prof. Abdulwahab AlSammak Email : [email protected] Lecture time : Thursday 10:00pm – 12:00 pm. Office hours : By appointment. (I will hang around for a few minutes at the end of each class). Online Resources: http:// bu.edu.eg/staff/abdelwahabalsammak3- courses/10596/files Teaching Assistant: Eng. Mufedah Hussien Email : [email protected] Office hours : Discuss with the TA Slides Author :Swapna S. Gokhale
  • 3. 2 Course Objective  Describe the general organization and architecture of computers.  Identify computers’ major components and study their functions.  Introduce hardware design issues of modern computer architectures.  Learn assembly language programming.  Build the required skills to read and research the current literature in computer architecture.
  • 4. 3 Textbooks •“Computer Organization,” by Carl Hamacher, Zvonko Vranesic and Safwat Zaky. Fifth Edition McGraw-Hill, 2002. •“SPARC Architecture, Assembly Language Programming and C,” Richard P. Paul, Prentice Hall, 2000.
  • 5. 4 Course topics 1. Introduction (Chapter 1): Basic concepts, overall organization. 2. Addressing methods (Chapter 2): fetch/execute cycle, basic addressing modes, instruction sequencing, assembly language and stacks. CISC vs. RISC architectures. 3. Logic Circuits Fundamentals (Appendix A): Logic Gates, Combinational Circuits, Sequential circuits 4. CPU architecture (Chapter 7): Single-bus CPU, Multiple-bus CPU Hardware control, and Microprogrammed control. 5. Arithmetic (Chapter 6): Integer arithmetic and floating- point arithmetic. 6. Memory architecture (Chapter 5): Memory hierarchy, Primary memory, Cache memory, virtual memory. 7. Input/Output organization (Chapter 4): I/O device addressing, I/O data transfers, Synchronization, DMA, Interrupts, Channels, Bus transfers, and Interfacing.
  • 6. 5 Grading System Midterm Exam : (25) - Addressing methods, CISC and RISC architectures. Lab Assignments : (25) -7 homework assignments. -Final : (75) - All topics.
  • 7. 6 Course topics, exams and assignment calendar Week #1 : - Introduction Week #2 : - Addressing methods - Lab. Assignment 1. Week #3 : -Addressing methods. Week #4 : - Logic Circuit Fundamentals - Lab. Assignment 2. Week #5 : - CPU Architecture. - Lab. Assignment 3. Week #6 : - CPU Architecture. - Lab. Assignment 4. Week #7 : - Arithmetic.
  • 8. 7 Course topics, exams and assignment calendar Week #8 : Midterm Exam Week #9 : - Arithmetic Week #10: - Memory architecture. - Lab. Assignment 5. Week #11 : - Memory organization - Lab. Assignment 6. Week #12 : - I/O organization. Week #13 - I/O devices. - Lab. Assignment 7. Week #14: - Pipelining Week #15: - Final Exam
  • 9. 8 Grading policy •Grading of assignments/exams is handled by the TA, if you cannot resolve a problem with the TA, see me. •Assignments may be submitted by email. Hard copy will also be accepted, but you have to submit in the department office to stamp the date. Please submit all the assignments to the TA. • Late assignments are penalized by a loss of 33% per day late (so 3 days late is as late as you can get). Solution will be posted on the course web page No assignments will be accepted after the solution is posted. •The weeks during which exams will be held have been announced. The actual day of that week, (Tuesday) when the exam will be held will be announced two weeks prior to the exam. If you have any conflict with the exam date, please see me in advance.
  • 10. 9 Important prerequisite material •Digital Logic Course is fundamental to the Computer Organization Course. •Review issues in: - Basic computer organization: CPU, Memory, I/O, Registers. - Fundamentals of combinatorial design and sequential design. - Simple ALU, simple register design.
  • 11. 10 Reading •Reading the text is imperative. ‫إلزامي‬ ( ‫أساسي‬ ) •Computer architecture especially processor design, changes rapidly. You really have to keep up with the changes in the industry. This is especially important for job interviews later.
  • 12. 11 Feedback Please provide informal feedback early and often, before the formal review process.
  • 14. 13 What is a computer?  a computer is a sophisticated electronic calculating machine that:  Accepts input information,  Processes the information according to a list of internally stored instructions and  Produces the resulting output information.  Functions performed by a computer are:  Accepting information to be processed as input.  Storing a list of instructions to process the information.  Processing the information according to the list of instructions.  Providing the results of the processing as output.  What are the functional units of a computer?
  • 15. 14 Functional units of a computer I/O Processor Output Memory Input Control Arithmetic & Logic Instr1 Instr2 Instr3 Data1 Data2 Input unit accepts information: •Human operators, •Electromechanical devices (keyboard) •Other computers Output unit sends results of processing: •To a monitor display, •To a printer Arithmetic and logic unit(ALU): •Performs the desired operations on the input information as determined by instructions in the memory Control unit coordinates various actions •Input, •Output •Processing Stores information: •Instructions, •Data
  • 16. 15 Information in a computer -- Instructions  Instructions specify commands to:  Transfer information within a computer (e.g., from memory to ALU)  Transfer of information between the computer and I/O devices (e.g., from keyboard to computer, or computer to printer)  Perform arithmetic and logic operations (e.g., Add two numbers, Perform a logical AND).  A sequence of instructions to perform a task is called a program, which is stored in the memory.  Processor fetches instructions that make up a program from the memory and performs the operations stated in those instructions.  What do the instructions operate upon?
  • 17. 16 Information in a computer -- Data  Data are the “operands” upon which instructions operate.  Data could be:  Numbers,  Encoded characters.  Data, in a broad sense means any digital information.  Computers use data that is encoded as a string of binary digits called bits.
  • 18. 17 Input unit Input Unit Processor Memory Computer Real world Keyboard Audio input …… Binary information must be presented to a computer in a specific format. This task is performed by the input unit: - Interfaces with input devices. - Accepts binary information from the input devices. - Presents this binary information in a format expected by the computer. - Transfers this information to the memory or processor.
  • 19. 18 Memory unit  Memory unit stores instructions and data.  Recall, data is represented as a series of bits.  To store data, memory unit thus stores bits.  Processor reads instructions and reads/writes data from/to the memory during the execution of a program.  In theory, instructions and data could be fetched one bit at a time.  In practice, a group of bits is fetched at a time.  Group of bits stored or retrieved at a time is termed as “word”  Number of bits in a word is termed as the “word length” of a computer.  In order to read/write to and from memory, a processor should know where to look:  “Address” is associated with each word location.
  • 20. 19 Memory unit (contd..)  Processor reads/writes to/from memory based on the memory address:  Access any word location in a short and fixed amount of time based on the address.  Random Access Memory (RAM) provides fixed access time independent of the location of the word.  Access time is known as “Memory Access Time”.  Memory and processor have to “communicate” with each other in order to read/write information.  In order to reduce “communication time”, a small amount of RAM (known as Cache) is tightly coupled with the processor.  Modern computers have three to four levels of RAM units with different speeds and sizes:  Fastest, smallest known as Cache  Slowest, largest known as Main memory.
  • 21. 20 Memory unit (contd..)  Primary storage of the computer consists of RAM units.  Fastest, smallest unit is Cache.  Slowest, largest unit is Main Memory.  Primary storage is insufficient to store large amounts of data and programs.  Primary storage can be added, but it is expensive.  Store large amounts of data on secondary storage devices:  Magnetic disks and tapes,  Optical disks (CD-ROMS).  Access to the data stored in secondary storage in slower, but take advantage of the fact that some information may be accessed infrequently.  Cost of a memory unit depends on its access time, lesser access time implies higher cost.
  • 22. 21 Arithmetic and logic unit (ALU)  Operations are executed in the Arithmetic and Logic Unit (ALU).  Arithmetic operations such as addition, subtraction.  Logic operations such as comparison of numbers.  In order to execute an instruction, operands need to be brought into the ALU from the memory.  Operands are stored in general purpose registers available in the ALU.  Access times of general purpose registers are faster than the cache.  Results of the operations are stored back in the memory or retained in the processor for immediate use.
  • 23. 22 Output unit •Computers represent information in a specific binary form. Output units: - Interface with output devices. - Accept processed results provided by the computer in specific binary form. - Convert the information in binary form to a form understood by an output device. Output Unit Processor Memory Computer Real world Printer Graphics display Speakers ……
  • 24. 23 Control unit  Operation of a computer can be summarized as:  Accepts information from the input units (Input unit).  Stores the information (Memory).  Processes the information (ALU).  Provides processed results through the output units (Output unit).  Operations of Input unit, Memory, ALU and Output unit are coordinated by Control unit.  Instructions control “what” operations take place (e.g. data transfer, processing).  Control unit generates timing signals which determines “when” a particular operation takes place.
  • 25. 24 How are the functional units connected? •For a computer to achieve its operation, the functional units need to communicate with each other. •In order to communicate, they need to be connected. Memory Input Output Processor •Functional units may be connected by a group of parallel wires. •The group of parallel wires is called a bus. •Each wire in a bus can transfer one bit of information. •The number of parallel wires in a bus is equal to the word length of a computer Bus
  • 26. 25 Organization of cache and main memory Main memory Processor Bus Cache memory Why is the access time of the cache memory lesser than the access time of the main memory?
  • 29. A Partial Program Execution Example
  • 30. A Partial Program Execution Example
  • 31. Interrupt  Normal execution of programs may be interrupted if some device requires urgent servicing  To deal with the situation immediately, the normal execution of the current program must be interrupted  Procedure of interrupt operation  The device raises an interrupt signal  The processor provides the requested service by executing an appropriate interrupt-service routine  The state of the processor is first saved before servicing the interrupt • Normally, the contents of the PC, the general registers, and some control information are stored in memory  When the interrupt-service routine is completed, the state of the processor is restored so that the interrupted program may continue
  • 32. Classes of Interrupts  Program  Generated by some condition that occurs as a result of an instruction execution such as arithmetic overflow, division by zero, attempt to execute an illegal machine instruction, or reference outside a user’s allowed memory space  Timer  Generated by a timer within the processor. This allows the operating system to perform certain functions on a regular basis  I/O  Generated by an I/O controller, to signal normal completion of an operation or to signal a variety of error conditions  Hardware failure  Generated by a failure such as power failure or memory parity error
  • 33. Bus Structures  A group of lines that serves a connecting path for several devices is called a bus  In addition to the lines that carry the data, the bus must have lines for address and control purposes  The simplest way to interconnect functional units is to use a single bus, as shown below
  • 34. Drawbacks of the Single Bus Structure  The devices connected to a bus vary widely in their speed of operation  Some devices are relatively slow, such as printer and keyboard  Some devices are considerably fast, such as optical disks  Memory and processor units operate are the fastest parts of a computer  Efficient transfer mechanism thus is needed to cope with this problem  A common approach is to include buffer registers with the devices to hold the information during transfers  An another approach is to use two-bus structure and an additional transfer mechanism • A high-performance bus, a low-performance, and a bridge for transferring the data between the two buses. ARMA Bus belongs to this structure
  • 35. Software  In order for a user to enter and run an application program, the computer must already contain some system software in its memory  System software is a collection of programs that are executed as needed to perform functions such as  Receiving and interpreting user commands  Running standard application programs such as word processors, etc, or games  Managing the storage and retrieval of files in secondary storage devices  Controlling I/O units to receive input information and produce output results
  • 36. Software  Translating programs from source form prepared by the user into object form consisting of machine instructions  Linking and running user-written application programs with existing standard library routines, such as numerical computation packages  System software is thus responsible for the coordination of all activities in a computing system
  • 37. Operating System  Operating system (OS)  This is a large program, or actually a collection of routines, that is used to control the sharing of and interaction among various computer units as they perform application programs  The OS routines perform the tasks required to assign computer resource to individual application programs  These tasks include assigning memory and magnetic disk space to program and data files, moving data between memory and disk units, and handling I/O operations  In the following, a system with one processor, one disk, and one printer is given to explain the basics of OS  Assume that part of the program’s task involves reading a data file from the disk into the memory, performing some computation on the data, and printing the results
  • 38. User Program and OS Routine Sharing
  • 40. Performance  The speed with which a computer executes programs is affected by the design of its hardware and its machine language instructions  Because programs are usually written in a high-level language, performance is also affected by the compiler that translates programs into machine languages  For best performance, the following factors must be considered  Compiler  Instruction set  Hardware design
  • 41. Performance  Processor circuits are controlled by a timing signal called a clock  The clock defines regular time intervals, called clock cycles  To execute a machine instruction, the processor divides the action to be performed into a sequence of basic steps, such that each step can be completed in one clock cycle  Let the length P of one clock cycle, its inverse is the clock rate, R=1/P  Basic performance equation  T=(NxS)/R, where T is the processor time required to execute a program, N is the number of instruction executions, and S is the average number of basic steps needed to execute one machine instruction
  • 42. Performance Improvement  Pipelining and superscalar operation  Pipelining: by overlapping the execution of successive instructions  Superscalar: different instructions are concurrently executed with multiple instruction pipelines. This means that multiple functional units are needed  Clock rate improvement  Improving the integrated-circuit technology makes logic circuits faster, which reduces the time needed to complete a basic step
  • 43. Performance Improvement  Reducing amount of processing done in one basic step also makes it possible to reduce the clock period, P.  However, if the actions that have to be performed by an instruction remain the same, the number of basic steps needed may increase  Reduce the number of basic steps to execute  Reduced instruction set computers (RISC) and complex instruction set computers (CISC)