Interrupts STOP!!! Do this!!!. CMPE12cGabriel Hugh Elkaim 2 Interrupts Have device tell OS/CPU it is ready Requires hardware to support. OS/CPU can then.

Slides:



Advertisements
Similar presentations
Computer Architecture
Advertisements

1 Exceptions, Interrupts & Traps Operating System Hebrew University Spring 2007.
Tutorial 3 - Linux Interrupt Handling -
Input and Output CS 215 Lecture #20.
Interrupts Chapter 8 – pp Chapter 10 – pp Appendix A – pp 537 &
1/1/ / faculty of Electrical Engineering eindhoven university of technology Architectures of Digital Information Systems Part 1: Interrupts and DMA dr.ir.
CSCI 4717/5717 Computer Architecture
68HC11 Polling and Interrupts
ECE 372 – Microcontroller Design Parallel IO Ports - Interrupts
Chapter 12 Interrupts STOP!!! Do this!!!. Interrupts Have device tell OS it is ready OS can then interrupt what it is doing to: Determine what device.
COMP3221: Microprocessors and Embedded Systems Lecture 15: Interrupts I Lecturer: Hui Wu Session 1, 2005.
1 Exceptions, Interrupts, and the OS STOP!! Do this!!!
Architectural Support for OS March 29, 2000 Instructor: Gary Kimura Slides courtesy of Hank Levy.
OS Fall ’ 02 Introduction Operating Systems Fall 2002.
OS Spring’03 Introduction Operating Systems Spring 2003.
Midterm Tuesday October 23 Covers Chapters 3 through 6 - Buses, Clocks, Timing, Edge Triggering, Level Triggering - Cache Memory Systems - Internal Memory.
Hardware Support for Operating Systems Sunny Gleason Vivek Uppal COM S 414
1 Last Class: Introduction Operating system = interface between user & architecture Importance of OS OS history: Change is only constant User-level Applications.
Input and Output How things get into and out of the CPU.
1 OS & Computer Architecture Modern OS Functionality (brief review) Architecture Basics Hardware Support for OS Features.
What are Exception and Interrupts? MIPS terminology Exception: any unexpected change in the internal control flow – Invoking an operating system service.
MIPS I/O and Interrupt. SPIM I/O and MIPS Interrupts The materials of this lecture can be found in A7-A8 (3 rd Edition) and B7-B8 (4 th Edition).
Interrupts. 2 Definition: An electrical signal sent to the CPU (at any time) to alert it to the occurrence of some event that needs its attention Purpose:
Introduction to Embedded Systems
COMP201 Computer Systems Exceptions and Interrupts.
Input and Output Computer Organization and Assembly Language: Module 9.
Three fundamental concepts in computer security: Reference Monitors: An access control concept that refers to an abstract machine that mediates all accesses.
CHAPTER 3 TOP LEVEL VIEW OF COMPUTER FUNCTION AND INTERCONNECTION
Recall: Three I/O Methods Synchronous: Wait for I/O operation to complete. Asynchronous: Post I/O request and switch to other work. DMA (Direct Memory.
1 CS/COE0447 Computer Organization & Assembly Language Chapter 5 part 4 Exceptions.
The Functions of Operating Systems Interrupts. Learning Objectives Explain how interrupts are used to obtain processor time. Explain how processing of.
Lecture 3 Process Concepts. What is a Process? A process is the dynamic execution context of an executing program. Several processes may run concurrently,
MIPS I/O and Interrupt. .data val1:.float 0.6 val2:.float 0.8 msg_done:.asciiz "done\n".text.globl main main: li.s $f0, mfc1 $a0, $f0 jal calsqrt.
13-Nov-15 (1) CSC Computer Organization Lecture 7: Input/Output Organization.
Interrupt driven I/O. MIPS RISC Exception Mechanism The processor operates in The processor operates in user mode user mode kernel mode kernel mode Access.
1 CSE451 Architectural Supports for Operating Systems Autumn 2002 Gary Kimura Lecture #2 October 2, 2002.
1 Interrupts, Resets Today: First Hour: Interrupts –Section 5.2 of Huang’s Textbook –In-class Activity #1 Second Hour: More Interrupts Section 5.2 of Huang’s.
CE Operating Systems Lecture 2 Low level hardware support for operating systems.
1 Computer Systems II Introduction to Processes. 2 First Two Major Computer System Evolution Steps Led to the idea of multiprogramming (multiple concurrent.
MIPS I/O and Interrupt.
Microprogramming and Exceptions Spring 2005 Ilam University.
CE Operating Systems Lecture 2 Low level hardware support for operating systems.
1 Lecture 1: Computer System Structures We go over the aspects of computer architecture relevant to OS design  overview  input and output (I/O) organization.
Interrupt driven I/O Computer Organization and Assembly Language: Module 12.
Interrupts STOP!!! Do this!!!. Interrupts Have device tell OS it is ready OS can then interrupt what it is doing to: Determine what device wants service.
بسم الله الرحمن الرحيم MEMORY AND I/O.
9/20/6Lecture 3 - Instruction Set - Al1 Exception Handling.
Interrupts and Exception Handling. Execution We are quite aware of the Fetch, Execute process of the control unit of the CPU –Fetch and instruction as.
Introduction to Exceptions 1 Introduction to Exceptions ARM Advanced RISC Machines.
Embedded Real-Time Systems Processing interrupts Lecturer Department University.
Computer System Structures Interrupts
Interrupts and exceptions
Interrupts and signals
68HC11 Interrupts & Resets.
Microprocessor Systems Design I
Timer and Interrupts.
Computer Architecture
MIPS I/O and Interrupt.
Architectural Support for OS
Interrupts and Exception Handling
CSE 451: Operating Systems Autumn 2003 Lecture 2 Architectural Support for Operating Systems Hank Levy 596 Allen Center 1.
CSE 451: Operating Systems Autumn 2001 Lecture 2 Architectural Support for Operating Systems Brian Bershad 310 Sieg Hall 1.
Interrupt handling Explain how interrupts are used to obtain processor time and how processing of interrupted jobs may later be resumed, (typical.
MIPS I/O and Interrupt.
CSE 451: Operating Systems Winter 2003 Lecture 2 Architectural Support for Operating Systems Hank Levy 412 Sieg Hall 1.
Architectural Support for OS
ECE/CS 552: Pipelining and Exceptions
COMP3221: Microprocessors and Embedded Systems
Interrupts and Exception Handling
Presentation transcript:

Interrupts STOP!!! Do this!!!

CMPE12cGabriel Hugh Elkaim 2 Interrupts Have device tell OS/CPU it is ready Requires hardware to support. OS/CPU can then interrupt what it is doing to: Determine what device wants service Determine what service it wants Perform or start the service Go back to what OS/CPU was doing “External condition related to IO devices”

CMPE12cGabriel Hugh Elkaim 3 Interrupts Examples of Interrupts Disk drive at sector/track position (old days) Mouse moved Keyboard key pressed Printer out of paper Video card wants memory access Modem sending or receiving USB scanner has data

CMPE12cGabriel Hugh Elkaim 4 Interrupts Interrupt Properties They arrive asynchronously Can’t communicate with a running program (no args or return values) They are associated with various priorities You want to handle them soon (interrupt latency) (usually) want to resume program

CMPE12cGabriel Hugh Elkaim 5 Trap “Internal conditions related to instruction stream” Trap Examples: syscall Illegal instruction Arithmetic overflow “lw” from unaligned address

CMPE12cGabriel Hugh Elkaim 6 Traps Trap Properties they arrive synchronously get trap in same place if you re-run program they are associated with various priorities must handle immediately (usually) want to resume program

CMPE12cGabriel Hugh Elkaim 7 Exceptions “Mechanism used to handle both interrupts and traps” HW handles initial reaction Then invokes SW called an Exception Handler to take care of the interrupt/trap

CMPE12cGabriel Hugh Elkaim 8 HW (MIPS) 1. Sets state giving cause of exception 2. Changes to Kernel mode, saving the previous mode in a hardware stack – for dangerous work ahead. 3. Disables further exceptions – to prevent infinite loop 4. Saves current PC – to be able to resume previously running program 5. Jumps to hardware address 0x Exceptions

CMPE12cGabriel Hugh Elkaim 9 Exceptions HW (HC11) 1.Wait for current instruction to complete 2.Disable further interrupts 3.Save all CPU registers and return address on stack 4.Access “interrupt vector table” according to source 5.Jump to where the interrupt routine is specified in table 6.Use RTI to return

CMPE12cGabriel Hugh Elkaim 10 MIPS Exceptions Set flag to detect incorrect entry Saves some registers Ascertain exception type exception_code in Cause register Jump to specific exception handler Handle specific exception To resume program, jump to clean up routine Restore registers Reset flag ( that detects incorrect entry ) Restore previous mode Re-enable interrupts Jump back to program (using Exception Program Counter (EPC))

CMPE12cGabriel Hugh Elkaim 11 MIPS Exceptions syscall handler Change EPC to point to next instruction resume after syscall Look at syscall number (MIPS: $2) Jump to specific syscall handler putc handler (one of many syscall handlers) Add char (from $4) to putqueue Turn on display interrupts Try to print a char Jump back to main exception handler getc handler Turn on keyboard interrupts Try to get char when interrupt comes Jump back to main exception handler with data in $2

CMPE12cGabriel Hugh Elkaim 12 MIPS Exceptions External (I/O) interrupt handler Which interrupt Interrupt field in Cause register Call specific interrupt handler Jump back to main exception handler

CMPE12cGabriel Hugh Elkaim 13 MIPS Exception Registers Kernel Registers k0 and k1 GPR $26 ($k0) and $27 ($k1) (used to store EPC) Kernel can hop in between any two user instructions Coprocessor “C0” registers Status ($12), Cause ($13), EPC ($14) mfc0 $s0, $14 reads C0 register $14 (EPC) and puts it in $s0 mtc0 $s0, $14 writes $s0 to C0 register $12 (Status)

CMPE12cGabriel Hugh Elkaim 14 MIPS Exception Registers Cause Register – way hardware makes information available to software about pending interrupts. 6 hardware interrupt bits 2 software interrupt bits 4 bits of exception code Status Register – contains information about the status of features of the computer that can be set by the processor when in kernel mode. Interrupt masks 3 mode/interrupt enable pairs mode is user/kernel on interrupts, stack mode/interrupt pairs

CMPE12cGabriel Hugh Elkaim 15 HC11 Exceptions HC11 does things slightly different than on the MIPS. Uses an interrupt vector table to find address of interrupt and goes straight to specific interrupt handler software. Not as complex as MIPS.

CMPE12cGabriel Hugh Elkaim 16 HC11 Jump Table ; 1unavailable to userSCI ISR_JUMP2EQU$7BC5; SPI ISR_JUMP3EQU$7BC8; Pulse Accumulator Input ISR_JUMP4EQU$7BCB; Pulse Accumulator Overflow ; 5unavailable to userTimer Overflow ; 6unavailable to userOutput Compare 5 ISR_JUMP7EQU$7BD4; Output Compare 4 ISR_JUMP8EQU$7BD7; Output Compare 3 ISR_JUMP9EQU$7BDA; Output Compare 2 ISR_JUMP10EQU$7BDE; Output Compare 1 ISR_JUMP11EQU$7BE3; Input Capture 3 ISR_JUMP12EQU$7BE6; Input Capture 2 ISR_JUMP13EQU$7BE9; Input Capture 1 ; 14unavailable to userReal Time Interrupt ISR_JUMP15EQU$7BEC; IRQ ; 16unavailable to userXIRQ ; 17unavailable to userSWI ; 18unavailable to userIllegal Opcode ISR_JUMP19EQU$7BF8; Cop fail ISR_JUMP20EQU$7BFB; Cop clock fail ; 21unavailable to userReset (found at 0x8040)

CMPE12cGabriel Hugh Elkaim 17 Multiple Exceptions Problem: How about multiple simultaneous exceptions? Solution: Have priorities in HW / SW Handle highest-priority exception first Equal priority exceptions handled arbitrarily Give higher priority more serious (e.g., power failing) can’t wait long (e.g., rotating disk)

CMPE12cGabriel Hugh Elkaim 18 Multiple Exceptions How about exceptions during exception handling? Make it wait until done with first exception May be a bad idea for higher priority exception Make exception handler re-entrant Make able to handle multiple active calls Allow higher-priority exceptions to bypass lower- priority exception currently being serviced

CMPE12cGabriel Hugh Elkaim 19 Multiple Exceptions Implementing a Re-entrant exception handler Initial exception disables all interrupts Exception handler (EH) determines exception’s priority EH saves any state that could be clobbered by higher priority interrupts (e.g. EPC) EH re-enables higher-priority interrupts Higher-priority interrupts may or may nor occur This EH eventually finishes

CMPE12cGabriel Hugh Elkaim 20 Multiprogramming An active program is called a process or task A processes’ state is: program counter registers memory locations being used Some OS memory EPC other registers The ability to run one or more programs “simultaneously” on one CPU.

CMPE12cGabriel Hugh Elkaim 21 Multiprogramming OS has one exception handler called the “kernel” On an exception, CPU jumps into the kernel Kernel will eventually resume the user process If the user process needs I/O (disk read) Kernel schedules it 20ms is ~ 2 million instructions Start (or switch to) another task (multitasking) If user process does not need I/O Kick it out (context switch) after some amount of time Every X clock interrupts and switch again

CMPE12cGabriel Hugh Elkaim 22 Multiprogramming OS has several job queues - An entry is the complete state of a process Some queue examples: A queue of ready jobs with priority A queues for I/O device(s) Jobs are moved to ready queue when I/O complete A queue of sleeping or halted jobs OS picks jobs from the ready queue as appropriate

CMPE12cGabriel Hugh Elkaim 23 Generalized Exceptions 1.User program running 2.Exception is generated Internal/External Trap/Interrupt 3.Determine source of exception Requires a bus cycle for some peripheral bus architectures. 4.Save return PC and any status registers modified by hardware MIPS: EPC, Control, Status HC11: program counter, index registers, acc.

CMPE12cGabriel Hugh Elkaim 24 Generalized Exceptions 5.Jump to exception handler MIPS: Single EH uses interrupt and exceptions type bits to find correct procedure HC11: Jump table starting at 0xFFD : Jump to location specified by interrupt device – vectored interrupts 6.Save state used by exception handler 7.Go to specific case Check exception type Query device Check syscall register

CMPE12cGabriel Hugh Elkaim 25 Generalized Exceptions 8.Process Exception Enable higher-priority interrupts if possible For interrupt, clear device’s interrupt flag Check device for multiple conditions 9.Restore state used by exception handler 10.Return from exception Restore mode Restore hardware-saved state Jump back to user program or exception handler

CMPE12cGabriel Hugh Elkaim 26 Exceptions Summary Exceptions (interrupts and traps) are a combination of hardware and software. The hardware detects the exception and then calls software to handle it. Much more efficient than polling but requires specialized hardware.