1 / 22

Exception Handling (2)

Exception Handling (2). 68000 Exception Handling. The 68000’s exception classification Register that support OS and exceptions Protecting OS memory The various exceptions The exception vectors. The 68000’s family exceptions. Supervisory State Registers. Registers across The processor

teva
Download Presentation

Exception Handling (2)

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. Exception Handling (2) Lecture 3 - Instruction Set - Al

  2. 68000 Exception Handling • The 68000’s exception classification • Register that support OS and exceptions • Protecting OS memory • The various exceptions • The exception vectors Lecture 3 - Instruction Set - Al

  3. The 68000’s family exceptions Lecture 3 - Instruction Set - Al

  4. Supervisory State Registers Registers across The processor Family Lecture 3 - Instruction Set - Al

  5. Registers • 68000 • SSP – Supervisor Stack Pointer • System Byte of Status Word • 68010 adds • Vector Base Register • Source Function Code • Destination Function Code • etc Lecture 3 - Instruction Set - Al

  6. Supervisor Memory Space Lecture 3 - Instruction Set - Al

  7. Exceptions and Interrupts • Reset • Externally Generated • Force both the RESET* and HALT* pins low for at least 10 clock cycles • Force the 68000 into a known start-up state • No RTE Lecture 3 - Instruction Set - Al

  8. Exceptions and Interrupts • Bus Error • Externally Generated • Initiated by hardware driving BERR* pin low • A catchall exception • Can be used to indicated non-populated memory has been addressed Lecture 3 - Instruction Set - Al

  9. Exceptions and Interrupts • Interrupt • Hardware generated on pins IPL0*, IPL1*, IPL2* • Pins activated indicated level of interrupt • Bits 8, 9, 10 of the status word indicates level of interrupt needed for service • Interrupting device generates level code through a 8-line-to-3-bit encoder Lecture 3 - Instruction Set - Al

  10. Interrupt Hardware Lecture 3 - Instruction Set - Al

  11. Interrupt HW Level encoder Lecture 3 - Instruction Set - Al

  12. Exceptions and Interrupts • Address Error • Exception occurs when 68000 attempts to access a 16-bit word or 32-bit longword at an odd address • Consider • LEA $7000,A0 Load A0 with $00 7000 • MOVE.B (A0)+,D0 Load D0 with byte at (A0)n incr • MOVE.W (A0)+,D0 Load D0 with word • Final instruction has A0 containing $7001 Lecture 3 - Instruction Set - Al

  13. Exceptions and Interrupts • Illegal Instruction • What happens when you try to execute and op-code that is not defined? • 8-bit uprocessor days • 68000? • Illegal Instruction Exception Lecture 3 - Instruction Set - Al

  14. Exceptions and Interrupts • Divide by Zero • Trying to divide by 0 generates this exception • CHK Instruction • Check Register against bounds • CHK D1,D0 generates an exception if • [D0(0:15)] < 0 • [D0(0:15)] > [D1(0:15)] • Point – useful for compiler writers Lecture 3 - Instruction Set - Al

  15. Exceptions and Interrupts • Privilege Violation • Processor in user state (S-bit is clear) • Attempt to execute a privileged instruction • Trace • Controlled by the trace bit of the status word • Contents of all registers output after each instruction Lecture 3 - Instruction Set - Al

  16. Exceptions and Interrupts • Line 1010 Emulator • Allow creation of special instructions • When this op code is encountered an exception occurs • Remaining bits of instruction word can be used to further specify “user” created instruction • Line 1111 Emulator • A second version Lecture 3 - Instruction Set - Al

  17. Exceptions and Interrupts • Un-initialized Interrupt Vector • When a 68000 device causes and interrupt • During IACK device supplies ID • If not yet initialized $0F is sent so device can be initialized • 68000 Devices respond with $0F when reset Lecture 3 - Instruction Set - Al

  18. Exceptions and Interrupts • Spurious Interrupt • IACK generated but no response? • Prevents hanging when no device responds to IACK after an IPL0-IPL2 pin pulled low • TRAP (Software Interrupt) • TRAP #x where x is from 0 to 15 ($0 to $F) • Allows creation of unique instructions Lecture 3 - Instruction Set - Al

  19. Exceptions and Interrupts • TRAPV Instruction • Trap on overflow • “IF V=1 THEN exception ELSE continue” • Double Bus Fault • Example: A bus error occurs and while responding to this a second bus error occurs? • 68000 halts!!! Lecture 3 - Instruction Set - Al

  20. Exception Vectors • 256 longwords (512 words) • Extend form address $00 0000 to $00 03FF Lecture 3 - Instruction Set - Al

  21. Exception Vector Table • Table located in low memory • Schemes allow relocation to other addresses Lecture 3 - Instruction Set - Al

  22. How would you implement the table in memory? • How would you allow the movement of the table to other addresses of memory? Lecture 3 - Instruction Set - Al

More Related