68b9523315d8ac273e9aa91a8a1f620c.ppt
- Количество слайдов: 32
UNIT-6
INTRODUCTION ØPOLLING ØINTERRUPTS ØINTERRUPT SERVICE ROUTINR(ISR)
INTERRUPT STRUCTURE OF 8086 • SUPPORTS 256 INTERRUPTS • SOURCES OF INTERRUPTS ØINTERRUPT FROM EXTERNAL SIGNAL APPLIED TO TWO HARDWARE PINS INTR AND NMI (HARDWARE INTERRUPTS ØINTERRUPT GENERATED BY EXECUTING AN INTERRUPT INSTRUCTION S/W OR INTERNAL INTERRUPT ØINTERRUPT BY AN ERROR CONDITION PRODUCED BY EXECUTING AN INSTRUCTION (INTERNAL ERRORS)
INTERRUPT RESPONSE 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 8086 COMPLETES THE EXECUTION OF CURRENT INSTRUCTION CHECKS THE SOURCE OF INTERRUPT. IF IT IS DUE TO INTR GO TO NEXT STEP ELSE GO TO STEP 5 CHECKS THE INTERRUPT FLAG. IF ITS SET GO TO NEXT STEP ELSE EXECUTE NEXT INSTRUCTION _____ IT ACKS INTRRUPT BY SENDING INTA SIGNAL TO THE DEVICE. _____ IT READS INTERRUPT TYPE GIVEN BY THE DEVICE DURING SECOND INTA SIGNAL IT PUSHES THE FLAG REGISTER TO STACK AND DECREMENTS STACK POINTER BY 2 IT CLEARS INTERRUPT FLAG AND TRAP FLAG IT SAVES RETURN ADDRESS BY PUSHING THE CS, DEC SP BY 2, PUSH IP TO STACK, DEC SP BY 2 TRANSFERS CONTROL TO START OF ISR. ADDRESS OF ISR IS TAKEN FROM IVT BASED ON WHICH OF THE 256 INTERRUPTS IS SERVICED AT THE END OF ISR, IRET HAS TO BE EXECUTED POPS IP INC SP BY 2, POPS CS, INC SP BY 2 IT POPS EFLAGS INC SP BY 2 TRANSFERS CONTROL BACK TO THE PROGRAM WHICH WAS INTERRUPTED
FLOWCAHRT FOR INTERRUPT RESPONSE SEQUENCE MAIN PROGRAM INTERRUPT IS DUE TO INTR NO PUSH EFLAGS CLEAR IF & TF PUSH CS &IP GO TO ISR YES NO IF =1 ISR YES INTERRUPT ACK CYCLE READ INTERRUPT TYPE POP IP POP CS POP FLAG REGISTER IRET
INTERRUPT VECTOR TABLE
8086 INTERRUPT TYPES 256 INTERRUPTS OF 8086 ARE DIVIDED IN TO 3 GROUPS 1. TYPE 0 TO TYPE 4 INTERRUPTSTHESE ARE USED FOR FIXED OPERATIONS AND HENCE ARE CALLED DEDICATED INTERRUPTS 2. TYPE 5 TO TYPE 31 INTERRUPTS NOT USED BY 8086, RESERVED FOR HIGHER PROCESSORS LIKE 80286 80386 ETC 3. TYPE 32 TO 255 INTERRUPTS AVAILABLE FOR USER, CALLED USER DEFINED INTERRUPTS THESE CAN BE H/W INTERRUPTS AND ACTIVATED THROUGH INTR LINE OR CAN BE S/W INTERRUPTS
TYPE – 0 DIVIDE ERROR INTERRUPT QUOTIENT IS LARGE CANT BE FIT IN AL/AX OR DIVIDE BY ZERO TYPE – 1 SINGLE STEP INTERRUPT USED FOR EXECUTING THE PROGRAM IN SINGLE STEP MODE BY SETTING TRAP FLAG TO SET TRAP FLAG PUSHF MOV BP, SP OR [BP+0], 0100 H; SET BIT 8 POPF TYPE – 2 NON MASKABLE INTERRUPT THIS INTERRUPT IS USED FOR EXECUTING ISR OF NMI PIN (POSITIVE EGDE SIGNAL). NMI CANT BE MASKED BY S/W TYPE – 3 BREAK POINT INTERRUPT USED FOR PROVIDING BREAK POINTS IN THE PROGRAM TYPE – 4 OVER FLOW INTERRUPT USED TO HANDLE ANY OVERFLOW ERROR AFTER SIGNED ARITHMETIC
PRIORITY OF INTERRUPTS INTERRUPT TYPE PRIORITY INT 0, INT 3 -INT 255, INTO HIGHEST NMI(INT 2) INTR SINGLE STEP LOWEST
DOS INTERRUPTS 1. FUNCTION CALL 01: READ THE KEY BOARD INPUT PARAMETER AH = 01 READ A CHARACTER FROM KEYBOARD. ECHO IT ON CRO SCREENAND RETURN THE ASCII CODE OF THE KEY PRESSEDIN AL OUTPUT PARAMETER: AL = ASCII CODE OF CHARACTER 2. FUNCTION CALL 02 H: DISPLAY ON CRT SCREEN INPUT PARAMETER: AH = 02 DL = ASCII CHARACTER TO BE DISPLAYED ON CRT SCREEN 3. FUNCTION CALL 03: READ CHARACTER FROM COM 1 INPUT PARAMETER: AH = 03 H FUNCTION: READS DATA FROM COM PORT OUTPUT PARAMETER: AL = ASCII CODE OF CHARACTER 4. FUNCTION CALL 04: WRITE CHARACTER TO COM 1 INPUT PARAMETER: AH = 04 H DL = ASCII CODE OF CHARACTER TO BE TRANSMITTED FUNCTION: WRITES DATA TO COM PORT 4. FUNCTION CALL 05: WRITE TO LPT 1 INPUT PARAMETER: Al = 05 H DL = ASCII CODE OF CHARACTER TO BE PRINTTED FUNCTION: PRINT THE CHARACTER AVAILABLE IN DL ON PRINTER ATTACHED TO LPT 1
DOS INTERRUPTS FUNCTION CALL 09: DISPLAY A CHARACTER STRING INPUT PARAMETER: AH = 09, DS: DX= ADDRESS OF CHARACTER STRING FUNCTION: DISPLAYS THE CHARACTERS AVAILABLE IN THE STRING TO CRT TILL A $ FUNCTION CALL 0 AH: BUFFERED KEY BOARD INPUT PARAMETER: AH = 0 AH DS: DX = ADDRESS OF KEYBOARD INPUT BUFFER FUNCTION: THE ASCII CODES OF THE CHARACTERS RECEIVED FROM KEYBOARD ARE STORED IN KEYBOARD BUFFER FROM 3 RD BYTE. 1 ST BYTE OF BUFFER = SIZE OF BUFFER UPTO 255. IT RECEIVES THE CHARACTERS TILL SPECIFIED NO. OF CHARACTERS ARE RECEIVED OR ENTER KEY IS PRESSES WHICH EVER IS EARLIER
BIOS INTERRUPTS INT 10 H: VIDEO SERVICE INPERRUPT IT CONTROLS THE VEDIO DISPLAY (a) FUNCTION CALL 00: SELECT VEDIO MODE INPUT PARAMETER: AL = MODE NUMBER AH = 00 H FUNCTION: IT CHANGES THE DISPLAY MODE AND CLEARS THE SCREEN AL = 00 40 X 25 BLACK AND WHITE AL = 04 320 X 200 COLOR AL = 10 H 640 X 350 X 16 COLOR (b) FUNCTION CALL 03: READ CURSOR POSITION INPUT PARAMETER: AH = 03 BH = PAGE NUMBER FUNCTION: READS CURSOR POSITION ON SCREEN OUTPUT PARAMETERS: CH = STARTING LINE CL = ENDING LINE DH = CURRENT ROW DL = CURRENT COLUMN
BIOS INTERRUPTS ( C) FUNCTION CALL 0 E: WRITE CHARACTER ON CRT SCREEN AND ADVANCE CURSOR INPUT PARAMETER: AH = 0 EH AL = ASCII CODE OF THE CHARACTER BH = PAGE(TEXT MODE) BL = COLOR(GRAPHICS) FUNCTION: DISPLAY CHARACTER AVAILABLE IN AL ON SCREEN INT 11 H: DETERMINE THE TYPE OF EQUIPMENT INSTALLED. REGISTER AX SHOULD CONTAIN FFFFH AND INSTRUCTION INT 11 H TO BE EXECUTED. ON RETURN, REGISTER AX WILL INDICATE THE EQUIPMENTS ATTACHED TO COMPUTER INT 14 H: CONTROL THE SERIAL COMMUNICATION PORT ATTACHED TO THE COMPUETR. AH SHOULD CONTAIN THE FUNCTION CALL (a) FUNCTION CALL 00: INITIALIZE THE COM PORT (b) FUNCTION CALL 01: SEND A CHARACTER (c) FUNCTION CALL 02: RECEIVE A CHARACTER INT 16 H: KEYBOARD INTERRUPT AH SHOULD CONTAIN THE FUNCTION CALL (a) FUNCTION CALL 00: READ KEYBOARD CHARACTER, IT WILL RETURN ASCII CODE OF THE CHARACTER (b) FUNCTION CALL 01: GET KEY BOARD STATUS
8259
Control Word (initialization)
SEQUENCE OF OPERATIONS IF IF FLAG IS SET AND INTR BECOMES ACTIVE HIGH 8086 DOES THE FOLLOWING 1. 2. 3. 4. 8086 pulses INTA(active low) twice indicating to 8259 that interrupt occurred 8259 WILL SEND THE TYPE NO. OF HIGHEST PRIORITY INTERRUPT TO 8086 ON D 0 -D 7 LINES DURING 2 ND INTA PULSE(ACTIVE LOW) 8086 MULTIPLIES THIS TYPE NO. 4 AND GETS THE CORRESPONDING ADDRESS FROM IVT 8086 PUSHED FLAG REGISTER, CLEARS IF, TF, PUSHED RET. ADDR AND THEN EXECUTES THE ISR AT THE ADDRESS RECEIVED
SEQUENCE OF OPERATIONS IN 8259 BEFORE IT ACTIVATES INTR 1. 2. 5. THE IRR REGISTERS THE INTERRUPT REQUESTS PRIORITY RESOLVER INTERACTS WITH IRR, ISR, IMR. IN CASE OF MULTIPLE INTERRUPTS HIGHEST PRIORITY INTERRUPT IS PICKED UP CORRESPONDING BIT IN IMR IS CHECKED BY PR TO SEE IF THIS INTERRUPT CAN BE ALLOWED OR NOT, ASSUME THAT IT IS ALLOWED ISR IS NOW CHECKED TO SEE IF ANY INTERRUPT IS UNDER SERVICE IF A HIGHER PRI. INTR IS UNDER SERVICE PR TAKES NO ACTION. IF NO HIGHER PRI. INTR IS UNDER SERVICE, IT ACTIVATES INT WHICH IS CONNECTED TO INTR OF 8086 SENDS 2 INTA PULSES. USING 1 ST PULSE 8259 WILL RESET THE CORRES 6. 7. PONDING IR BIT OF IRR TO INDICATE THE REQ IS ACCEPTED AND SETS THE CORRESPONDING IS BIT OF ISR TO INDICATE WHICH IR LEVEL IS UNDER SERVICE DURING 2 ND INTA PULSE 8259 WILL SEND THE TYPE NUMBER OF INTERRUPT ISR BIT WILL BE RESET AT THE END OF INT. SERVICE ROUTINE 3. 4.
PRIORITY MODES FULLY NESTED MODE DEFAULT MODE. IR 0 HAS HIG. PRI, IR 1 NEXT …. IR 7 LOWEST PRIORITY SPECIFIC ROTATION MODE AN IR WILL BE ASSIGNED LOWEST PRIORITY, THUS FIXING THE PRI OF OTHER INTERRUPTS IN CYCLIC MANNER EX: IF IR 3 IS ASSIGNED LOWEST PRI. , THEN IR 2 IS NEXT HIGHER…. IR 4 IS HIGHEST PRI AUTOMATIC ROTATION MODE AN IR LEVEL AFTER BEING SERVICED GETS LOWEST PRIORITY, OTHER PRI WILL GET FIXED IN CYCLIC ORDER. EX: IR 5 AFTER BEING SERVICED ASSIGNED LOWEST PRI, NEXT HIGHR WILL BE IR 4, IR 6 WILL BE HIGHEST SPECIAL FULLY NESTED MODE APPLICABLE FOR CASCADE CONFIGURATON. PRI. LEVEL OF SLAVE 8259 IS SAME FOR ALL INTERRUPTS. SO IF AN INTERRUPT IS UNDER SERVICE FROM A SLAVE THEN OTHER INTERRUPTS FROM SLAVE WILL NOT BE RECOGNISED. SFNM REMOVE THIS PROBLEM, ALLOWS HIGHEST PRI. INTERRUPT FROM A SLAVE TO BE RECOGNIS WHILE ANOTHET LOWER PRI INTERRUPT IS UNDER SERVICE
END OF INTERRUPTS AUTOMATIC EOI COMMAND NEED NOT BE GIVEN. ISR IS RESET BY LAST INTA PULSE. THE DRAWBACK IS THAT NOW ANY IR CAN INTERRUPT ISR. THIS METHOD IS GENERALLY USED WHEN A NESTED MULTI-LEVEL INTERRUPT STRUCTURE IS NOT REQUIRED. IT IS A PREFERRED MODE OF OPERATION AND REDUCES ISR LENGTH NON SPECIFIC EOI COMMAND THIS COMMAND WILL RESET THE HIGHEST PRIORITY ISR BIT. THIS IS BECAUSE IN NESTED MODE IT IS THE HIGHEST PRIORITY WHICH WILL BE IN SERVICE SPECIFIC EOI THIS COMMAND WILL RESET THE ISR BIT WHICH IS SPECIFIED AS A PART OF COMMAND. THREE BIT CODE L 0 – L 2 SPECIFIES WHICH BIT HAS TO BE RESET
ICW-INITIALIZATION COMMAND WORD THERE ARE 4 ICWs ICW 1 IS WRITTEN USING PORT 0 ADDRESS OF 8259 ICW 2 IS WRITTEN USING PORT 1 ADDRESS OF 8259 It is used by 8086 to specify the interrupt type number which is sent by 8259 in response to INTA
ICW 1, ICW 2
D 7 D 6 D 5 D 4 D 3 D 2 D 1 D 0 T 7/ T 6/ T 5/ T 4/ T 3/ A 10 A 9 A 15 A 14 A 13 A 12 A 11 A 8 D 0 -D 7 ARE LABLED AS A 8 TO A 15(A 8 – A 15) OF INTERRYPT VECTOR ADDRESS AND USED BY 8085 D 0 – D 2 ARE NOT USED BY 8086 D 3 – D 7 ARE LABLED AS T 3 -T 7(OF INTERRUPT VECTOR TYPE, USED BY 8086 AND ARE 5 MSBs OF INTERRUPT TYPE NUMBER
Masking and Prioritization • OCW (operation command word)
Programming OCWs
OCW 1 IS WRITTEN USING PORT 1 ADDRESS OF 8259 IT IS USED TO SET RESET THE MASK BITS IN INTERRUPT MASK REGISTER D 0 = 1 INDICATES IR 0 IS MAKED OR DISABLED D 0 = 0 INDICATES IR 0 IS UNMASKED OR ENABLED D 1 THROUGH D 7 ARE FOR IR 1 THROUGH IR 7 OCW 2 IS WRITTEN USING PORT 0 ADDRESS OF 8259 IT IS PROGRAMMED ONLY WHEN AEOI MODE IS NOT SELECTED IN ICW 4 R- ROTATION SL-SPECIFIC LEVEL EOI – END OF INTERRUPT
OCW 3


