Page 1 of 1

Some basic Questions about Virtual 8086 Mode.....

Posted: Mon Mar 03, 2003 5:39 am
by Perica
..

Re:Some basic Questions about Virtual 8086 Mode.....

Posted: Mon Mar 03, 2003 8:11 am
by Tim
Perica Senjak wrote:--When using the "iret" instruction to Switch to vm86 Mode (After changing the eflags.vm bit) Do i load a RealMode/vm86 mode CS Value (Pushing a RealMode/vm86 mode CS Value onto the Stack before executing "iret") or do i wait until i have entered vm86 mode, and then jump to a RealMode/vm86 mode Segment?
Put a CS value compatible with real mode into the stack image before IRET. A ring 0 to V86 stack frame looks like a normal ring 0 to ring 3 frame except that there are DS, ES, FS and GS register images there too (check the Intel manual for details).
--Just before exectuting the "iret" Instruction to Enter vm86 mode, Do i pust a 16-Bit (word) Instruction Pointer ((e)ip) Value, or do i push a 32-Bit value??
32-bit. As I said, the stack frame is as normal except for the extra segment register images.
--While in vm86 mode, is it possible to use 32-Bit Registers (eax, ebx, ecx, edx etc. ?) ??
Yes. Use the address and operand size override prefixes as normal.

Interrupts in vm86 Mode?

Posted: Tue Mar 04, 2003 6:45 am
by Perica
..

Re:Some basic Questions about Virtual 8086 Mode.....

Posted: Tue Mar 04, 2003 8:28 am
by Tim
I think this page should answer these questions: http://osdev.berlios.de/v86.html

Re:Some basic Questions about Virtual 8086 Mode.....

Posted: Tue Mar 04, 2003 11:21 pm
by Perica
..

Re:Some basic Questions about Virtual 8086 Mode.....

Posted: Wed Mar 05, 2003 3:01 am
by DarylD
I don't think you read it very well Perica.

Within seconds I found this little snippet:
If it uses the BIOS, your code will also need the interrupt vector table and BIOS data area from address 0 to 500. If your boot loader or kernel wrote over the IVT and BDA you are also stuck; if so, you will need to modify them so as to preseve that memory. Again, you could make the bottom 500 bytes copy-on-write so that each task got its own IVT and BDA; however, for now it should be enough to map the first page to address zero and make it read-write.
Read it again!

Re:Some basic Questions about Virtual 8086 Mode.....

Posted: Wed Mar 05, 2003 4:00 am
by Perica
..

Re:Some basic Questions about Virtual 8086 Mode.....

Posted: Wed Mar 05, 2003 2:18 pm
by Tim
Perica Senjak wrote:So, does this mean When i am Multi-Tasking vm86 Mode and ProtectedMode that i have to Load the IDT each time?
No.
How would i load the IVT, would i use the lidt instruction? If so, then does the Offset address Remain a Double-Word in Size, or is it a Word in Size?
You wouldn't. The IVT isn't an IDT.
And, lastly... How do i handle IRQ's and Exceptions? Do i have to put all of this Code below the 1mb Mark, or is there another way??
The IDT remains in force even when a V86 task is running. A sure way of handling interrupts is to have them all go through the IDT in ring 0, then modify CS and IP for the V86 task as appropriate.
Yes, the tutorial answers most questions about vm86 Mode, but i couldn't find answers anywhere to the ones above. So if somebody could please help me out ;D .....
Read the Intel manuals. All the answers are in there if you read closely enough.