CH 04 : Operating Systems And Computer Architecture

Operating Systems

  • ==Operating System(OS)==: It is a computer software running in the background when the computer is on, and performs various operations.   * It is also responsible for the communication between hardware and software.   * Operating systems make it alot easier to use computers.
  • Some of the tasks an OS performs:   * Multitasking   * Multiprogramming   * Error handling   * Loading and running software   * Memory management   * Security (passwords etc)   * Input and output control
  • Windows and Linux are examples of OS.
  • When a computer is turned on:   * The initial starting programs are loaded from ==Read Only Memory(ROM),==   * Different components of the computer are checked for errors,   * The OS is loaded into the computer memory.

Interrupts And Buffers

  • ==Interrupt==: It is a signal sent to the Processor from a device or software, to make the Processor ^^temporarily^^ stop its current operation and service another.   * An Interrupt is sent when for example, a page is jammed in the printer, or when a software error occurs.   * Interrupts allow computers to ^^multitask^^.   * When an Interrupt occurs, the status of the currently running task is saved using an ==Interrupt Handler.== so that the processor can resume it after the Interrupt is serviced.
  • ==Buffer==: It is a ^^temporary^^ memory area.   * Buffers are filled from computer memory and emptied to the hardware, allowing the processor to perform other tasks in the meanwhile.
  • Example to explain how Buffers and Interrupts are used together, while a printer is being used:

   


Computer Architecture

  • ==Von Neumann Architecture==: A computer system which can store programs in a memory. The idea was developed by ^^John von Neumann^^.   * Before Neumann, computers had to be fed data while they were running, so for every task the data had to be fed immediately before-hand.
  • In a von Neumann system, a ==Memory Unit, Processor(containing a Control Unit)== and the hardware are connected through ==Buses== to perform different tasks.

   

  \

  • ==Buses==: The connections which transport data around the system and also maintain data ^^synchronization^^.   * ==Address Bus:== ^^Unidirectional^^ Bus carrying signal related to the addresses of the memory contents.   * ==Data Bus:== ^^Bidirectional^^ Bus responsible for moving the data and contents of the memory around the system.   * ==Control Bus==^^: Unidirectional^^ Bus carrying signals related to control and coordination of all activities in the computer.
  • ==Registers==: High speed storage areas within the computer system, which are needed to store and ^^manipulate^^ data.   * ==Memory Address Register(MAR)==: Address which contains the location of the memory contents.   * ==Memory Data Register(MDR)==: Register which contains the content from memory.   * ==Arithmetic Logic Unit(ALU)==: Register which allows the ^^calculations and logic operations^^ to be performed within the computer.   * ==Program Counter(PC)==: Register which contains the instructions for the next task to be performed.   * ==Current Instruction Register(CIR)==: Register which contains the instructions for the current task.

 

  • ==Memory Unit:== It contains all the data to be processed and its addresses as well.
  • ==Processor==: The part where data is processed and the necassary logic operations are carried out.
  • ==Control Unit==: It controls the operation of the memory, processor and input/output devices.   * Control Unit reads an instruction from memory and tells the other components how to function, through Control Bus.
  • ==Input/Output Devices==: Ways of feeding data into a computer and/or getting it out.

Fetch-Execute Cycle

  • To perform a task, instructions for the said task are ^^Fetched^^ from the memory and Processed before being ^^Executed^^.
  • ==Fetch==:   * Instructions for the next task are fetched from the PC and put into CIR through Data Bus.   * PC is ^^incremented^^ by 1.   * Instructions are sent to the Processor(through Data Bus) to be decoded.
  • ==Execute==:   * Processor sends the decoded instructions as ^^control signals^^ using the Control Bus, to other components of the system, so that the instructions can be executed.

\