Some basic Questions about Virtual 8086 Mode.....
Some basic Questions about Virtual 8086 Mode.....
..
Last edited by Perica on Sun Dec 03, 2006 8:54 pm, edited 2 times in total.
Re:Some basic Questions about Virtual 8086 Mode.....
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).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?
32-bit. As I said, the stack frame is as normal except for the extra segment register images.--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??
Yes. Use the address and operand size override prefixes as normal.--While in vm86 mode, is it possible to use 32-Bit Registers (eax, ebx, ecx, edx etc. ?) ??
Interrupts in vm86 Mode?
..
Last edited by Perica on Sun Dec 03, 2006 8:53 pm, edited 1 time in total.
Re:Some basic Questions about Virtual 8086 Mode.....
I think this page should answer these questions: http://osdev.berlios.de/v86.html
Re:Some basic Questions about Virtual 8086 Mode.....
..
Last edited by Perica on Sun Dec 03, 2006 8:53 pm, edited 1 time in total.
Re:Some basic Questions about Virtual 8086 Mode.....
I don't think you read it very well Perica.
Within seconds I found this little snippet:
Within seconds I found this little snippet:
Read it again!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.
Re:Some basic Questions about Virtual 8086 Mode.....
..
Last edited by Perica on Sun Dec 03, 2006 8:53 pm, edited 1 time in total.
Re:Some basic Questions about Virtual 8086 Mode.....
No.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?
You wouldn't. The IVT isn't an IDT.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?
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.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??
Read the Intel manuals. All the answers are in there if you read closely enough.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 .....