120 likes | 417 Views
Flow Diagram:. Push AX,BX,CX,DX,ES,DS,SI,DI,BP. Push flags, CS, IP. POP BP,DI,SI,DS,ES,DX,CX,BX,AX. Pop IP,CS,flags. Typical Reentrant Routine:. Push AX, Push BX, Push CX, Push DX, Push ES, Push DS, Push SI, Push DI, Push BP ---------- ---------- ---------- ----------
E N D
Flow Diagram: Push AX,BX,CX,DX,ES,DS,SI,DI,BP Push flags, CS, IP POP BP,DI,SI,DS,ES,DX,CX,BX,AX Pop IP,CS,flags
Typical Reentrant Routine: Push AX, Push BX, Push CX, Push DX, Push ES, Push DS, Push SI, Push DI, Push BP ---------- ---------- ---------- ---------- Pop BP, Pop DI, Pop SI , Pop DS, Pop ES, Pop DX, Pop CX, Pop BX, Pop AX, IRET -------------------- Int --------------------
BP DI SI DS ES DX CX BX AX IP CS Flags Animation:
Example: void main (){ x = sum(4, 5); printf (“%d”, x); a = 10; b = 20; x = sum(a, b); printf (“%d”, x);}int sum (int i, int j){ return i+j;} SP 4 5 RP SP a b RP
Accessing Stack Example: void interrupt newint ( unsigned int BP, unsigned int DI, unsigned int SI, unsigned int DS, unsigned int ES, unsigned int DX, unsigned int CX, unsigned int BX, unsigned int AX, unsigned int CS, unsigned int IP, unsigned int flags){ a = AX; b = BX; d = ES;}
Example: void main ( ) {setvect(0x65,newint); _AX = 0x1234; Geninterrupt (0x65); a = _AX; Printf (“%x”, a); } void interrupt newint( unsigned int BP, unsigned int DI, unsigned int SI, unsigned int DS, unsigned int ES, unsigned int DX, unsigned int CX, unsigned int BX, unsigned int AX, unsigned int CS, unsigned int IP, unsigned int flags){ AX = 0xF00F; }
Disk Interrupt ( int# 13H Service# 3) On Entry AH = Service # = 03AL = No of Blocks to write BX = Offset Address of Data CH = Track No. , CL = Sector DH = Head # DL = Drive #(Starts from 0x80 for fixed disk & 0 for removable disks) ES = Segment Address of data buffer. On Exit AH = return Code Carry flag = 0 ( No Error AH = 0) Carry flag = 1 ( Error AH = Error Code)
Addressing of Block Specified: Head, Sec, Track #pragma inline #include <dos.h> #include <bios.h> void interrupt (*oldtsr) ( ); void interrupt newtsr (unsigned int BP, …, flags); void main ( ) { oldtsr = getvect (0x13); setvect = (0x13, newtsr); keep (0, 1000); }
void interrupt newtsr(unsigned int BP, unsigned int DI, unsigned int SI, unsigned int DS, unsigned int ES, unsigned int DX, unsigned int CX, unsigned int BX, unsigned int AX, unsigned int CS, unsigned int IP, unsigned int flags){ _ES = ES; _DX = DX;if ( _AH = = 0x03) _CX = CX; _BX = BX; if(( _DH= =1 && _CH= =0 _AX = AX; && _CL= =1)&& _DL>=0x80) *oldtsr; { asm pushf; asm clc; asm pop flags; asm pushf; AX = _AX; BX = _BX; asm pop flags; CX = _CX; DX = _DX; return; ES = _ES; } }
Keyboard Interrupt Hook (int# 15H Service# 4FH) Move Scan Code from 60H port to AL Int 15H Service 4FH Key Pressed Convert to ASCII & place it in keyboard buffer
Example: #include <dos.h> #include <bios.h> #include <stdio.h> void interrupt (*oldint15) ( ); void interrupt newint15(unsigned int BP, …, flags); void main ( ) { oldint15 = getvect (0x15); setvect (0x15, newint15); keep (0, 1000); }
void interrupt newint15(unsigned int BP, unsigned int DI, unsigned int SI, unsigned int DS, unsigned int ES, unsigned int DX, unsigned int CX, unsigned int BX, unsigned int AX, unsigned int CS, unsigned int IP, unsigned int flags){ if (*(((char*)&AX) + 1) = = 0x4F ) { if (*((char*)&AX) = = 0x2C) *(((char*)&AX)) = 0x1E; else if (*((char*)&AX) = = 0x1E) *((char*)&AX) = = 0x2C; } }