## **Computer System Overview**

Slide 1

Slide 2

**Operating Systems** 

2005/S2

## What are the objectives of an Operating System?

## $\rightarrow$ convenience & abstraction

- the OS should facilitate the task of application and system programmer
- hardware details should be hidden, uniform interface for
- different I/O devices provided

#### → efficiency

should take up few resources, make good use of resources, and be fast

#### $\rightarrow$ protection

fairness, security, safety



Slide 3

## BASIC ELEMENTS

LAYERS OF A COMPUTER SYSTEM

Programn

Operating System

Designer

End User

**Application Programs** 

Utilities

**Operating System** 

**Computer Hardware** 

#### Simplified view:

- → Processor
- ➔ Main Memory
  - referred to as real memory or primary memory
  - volatile

# Slide 4 → I/O modules

- secondary memory devices
- communications equipment
- terminals
- → System bus
  - communication among processors, memory, and I/O modules

#### LAYERS OF A COMPUTER SYSTEM

1

## **TOP-LEVEL COMPONENTS**



# EXAMPLE: LARGE PENTIUM SYSTEM



## PROCESSOR

- → Fetches intructions from memory, decodes and executes them
- → Set of instructions is processor specific
- $\rightarrow$  Instructions include:

Slide 7

- ★ load value from memory into register
- ★ combine operands from registers or memory
  ★ branch
- → All CPU's have registers to store
  - ★ key variables and temporary results
  - ★ information related to control program execution

## **PROCESSOR REGISTERS**

- → Data and address registers
  - Hold operands of most native machine instructions
  - Enable programmer to minimize main-memory references by optimizing register use
- Slide 8 user-visible

#### → Control and status registers

- Used by processor to control operating of the processor
- Used by operating-system routines to control the execution of programs
- Sometimes not accessible by user (architecture dependent)

## USER-VISIBLE REGISTERS

- → May be referenced by machine language instructions
- → Available to all programs application programs and system programs
- → Types of registers

Slide 9

Address

• Data

- Index
- Segment pointer
- Stack pointer
- Many architectures do not distinguish different types

- **CONTROL AND STATUS REGISTERS**
- → Condition Codes or Flags
  - Bits set by the processor hardware as a result of operations
  - Can be accessed by a program but not altered
  - Examples

Slide 11

- positive/negative result
- zero
- overflow

- **CONTROL AND STATUS REGISTERS**
- → Program Counter (PC)
  - Contains the address of an instruction to be fetched
- → Instruction Register (IR)
- Slide 10
- Contains the instruction most recently fetched
- ➔ Processor Status Word (PSW)
  - condition codes
  - interrupt enable/disable
  - supervisor/user mode

## **INSTRUCTION FETCH AND EXECUTE**

- → Program counter (PC) holds address of the instruction to be fetched next
- → The processor fetches the instruction from memory
- → Program counter is incremented after each fetch
- Slide 12 → Overlapped on modern architectures (pipelining)



## INSTRUCTION REGISTER

- → Fetched instruction is placed in the instruction register
- → Types of instructions

• Processor-I/O

- Processor-memory
- transfer data between processor and memory
- Slide 13
- data transferred to or from a peripheral device
- Data processing
- arithmetic or logic operation on data
- Control
- alter sequence of execution

## CLASSES OF INTERRUPTS

- → Asynchronous (external) events
  - I/O
  - Timer
  - Hardware failure
- Slide 15 → Synchronous interrupts or program exceptions caused by program execution:
  - arithmetic overflow
  - division by zero
  - execute illegal instruction
  - reference outside user's memory space

#### INTERRUPT CYCLE

- ① Fetch next instruction
- ② Execute instruction
- ③ Check for interrupt
- ④ If no interrupts, fetch the next instruction
- ⑤ If an interrupt is pending, divert to the interrupt handler

Slide 16

Execute Cycle Interrupt Cycle



## INTERACTION BETWEEN PROCESSOR AND I/O DEVICES

- → CPU much faster than I/O devices
  - waiting for I/O operation to finish is inefficient
- Slide 14 - not feasible for mouse, keyboard
  - → I/O module sends an interrupt to CPU to signal completion
  - → Interrupts normal sequence of execution
  - → Interrupts are also used to signal other events

## INTERRUPT HANDLER

→ A program that determines nature of the interrupt and performs

#### Slide 17

Slide 18

- → Control is transferred to this program by the hardware
- → Generally part of the operating system

whatever actions are needed

# MULTIPLE INTERRUPTS

- → Interrupt X occurs
- → CPU disables all interrupts (only those with lower priority)
- → Interrupt handler may enable interrupts
- → Interrupt Y occurs

Slide 19

Slide 20

→ Sequential or nested interrupt handling



CONTROL FLOW WITH AND WITHOUT INTERRUPTS



## **MULTIPLE INTERRUPTS**

#### Sequential Order:

- → Disable interrupts so processor can complete task
- → Interrupts remain pending until the processor enables interrupts
- → After interrupt handler routine completes, the processor checks for additional interrupts

# MEMORY HIERARCHY



#### Memory

#### Sould be

→ fast

 $\rightarrow$  cheap

 $\rightarrow$  abundant

#### Slide 22

Slide 21

Unfortunately, that's not the reality...

#### Solution:

 combination of fast & expensive and slow & cheap memory

| GOING | Down | THE | HIERARCHY |  |
|-------|------|-----|-----------|--|
|       |      |     |           |  |

- → Decreasing cost per bit
- → Increasing capacity
- Slide 24 → Increasing access time
  - → Decreasing frequency of access of the memory by the processor

Locality of reference is essential!

#### MEMORY HIERARCHY

# CACHE/MAIN MEMORY SYSTEM



#### DISK CACHE

- → A portion of main memory used as a buffer to temporarily to hold data for the disk
- Slide 25 → Disk writes are clustered
  - → Some data written out may be referenced again. The data are retrieved rapidly from the software cache instead of slowly from disk
  - → Mostly transparent to operating system

# CACHE MEMORY



- → Contains a portion of main memory
- → Processor first checks cache
- → If not found in cache, the block of memory containing the needed information is moved to the cache replacing some other data

## CACHE DESIGN

→ Cache size

Slide 28

- small caches have a significant impact on performance
- → Line size (block size)

 the unit of data exchanged between cache and main memory

- hit means the information was found in the cache
- larger line size ⇒ higher hit rate until probability of using newly fetched data becomes less than the probability of reusing data that has been moved out of cache

## CACHE DESIGN

#### → Mapping function

• determines which cache location the data will occupy

#### → Replacement algorithm

- determines which line to replace
- Least-Recently-Used (LRU) algorithm

#### → Write policy

- When the memory write operation takes place
- Can occur every time line is updated (write-through policy)
- Can occur only when line is replaced (write-back policy)
- Minimizes memory operations
- Leaves memory in an obsolete state

## PROGRAMMED I/O (POLLING)

- → I/O module performs the action, not the processor
- → Sets appropriate bits in the I/O status

## Slide 31 register

- ➔ No interrupts occur
- ➔ Processor checks status until operation is complete
  - Wastes CPU cycles



## INTERACTION BETWEEN I/O DEVICES AND PROCESSOR

- → Controller (chip or set of chips) provides a simple interface to OS
  - often, embedded OS running on the controller
- → Software that communicates with controller is called device

#### Slide 30

Slide 29

- → Most drivers run in kernel mode
- → To put new driver into kernel, system may have to
  - be relinked

driver

- be rebooted
- dynamically load new driver

## INTERRUPT-DRIVEN I/O

- → Processor is interrupted when I/O module ready to exchange data
   → Processor is free to do other work
- Slide 32
  - → No needless waiting
    → Consumes a lot of processor time because every word read or written

passes through the processor





- → Transfers a block of data directly to or from memory
- → An interrupt is sent when the task is complete

Slide 33

→ The processor is only involved at the beginning and end of the transfer

