vm86 mode(problem with #gp)

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
Post Reply
User avatar
ahmedhalawa
Member
Member
Posts: 28
Joined: Wed Jul 02, 2008 9:28 am

vm86 mode(problem with #gp)

Post by ahmedhalawa »

Hello every body i'm trying to write vm8086 program
it run very good i use int 0x10 i know it should go to
#Gp handler and thats happen the problem when it back
from #GP handler **0x10 handler doesn't run but #GP handler still
repeat himself :(
that is my code

#gp handler

Code: Select all

void GP::handle(regs r)
{   
    uchar *ip;
    regs *vr=&r;
    ushort *ivt=(ushort*)0x0;
    ip = (uchar*)r.eip;
    if(ip[0] = 0xCD)
    {
        vr->cs = ivt[ip[1]*2+1];
        vr->eip= ivt[ip[1] * 2];
        vr->eflags=0x23202;
        return;
    }
    while(1);
}
adding vm8086 code

Code: Select all

        tasks[id].uesp = (uint)kh.alloc(stacksz)+stacksz-1;
        tasks[id].kesp = (uint)kh.alloc(stacksz)-1;
        uint *stack = (uint*)tasks[id].uesp;
        *--stack = (ushort)(add >> 16);
        *--stack = (ushort)(add >> 16);
        *--stack = (ushort)(add >> 16);
        *--stack = (ushort)(add >> 16);
        *--stack = 0x10;
        *--stack=  0xFFFe;
        *--stack = 0x20202|0x200;
        *--stack = (ushort)add>>16;
        *--stack = (ushort)add&0xFFFF;
        *--stack = 0;
        *--stack = 0;
        *--stack = 0;
        *--stack = 0;
        *--stack = 0;
        *--stack = 0;
        *--stack = 0;
        *--stack =(iss)?0x10:0x10;
        *--stack =(iss)?0x10:0x10;
        *--stack =(iss)?0x10:0x10;
        *--stack =(iss)?0x10:0x10;
thanks
User avatar
Combuster
Member
Member
Posts: 9301
Joined: Wed Oct 18, 2006 3:45 am
Libera.chat IRC: [com]buster
Location: On the balcony, where I can actually keep 1½m distance
Contact:

Re: vm86 mode(problem with #gp)

Post by Combuster »

When the #GP runs again, what instruction is it pointing to?
"Certainly avoid yourself. He is a newbie and might not realize it. You'll hate his code deeply a few years down the road." - Sortie
[ My OS ] [ VDisk/SFS ]
User avatar
ahmedhalawa
Member
Member
Posts: 28
Joined: Wed Jul 02, 2008 9:28 am

Re: vm86 mode(problem with #gp)

Post by ahmedhalawa »

Hello
#Gp point the same address
instruction is : 0xCD
value is : 0x10
which my program has it
/*****************/
i think you want to be sur if my program chang ip and cs
in regs be sur that's happen because my program
print values from regs.eip and regs.cs
the values of this regs are differnet, it's not my
program ip and cs
/*****************/
sorry for my english
User avatar
ahmedhalawa
Member
Member
Posts: 28
Joined: Wed Jul 02, 2008 9:28 am

Re: vm86 mode(problem with #gp)

Post by ahmedhalawa »

Hello
does any one know the answer or no if no
pleas from any one give me all things about(rulls) it with small exampel

thanks
Hyperdrive
Member
Member
Posts: 93
Joined: Mon Nov 24, 2008 9:13 am

Re: vm86 mode(problem with #gp)

Post by Hyperdrive »

ahmedhalawa wrote:Hello
#Gp point the same address
instruction is : 0xCD
value is : 0x10
which my program has it
0xCD 0x10 is simply the mentioned "INT 0x10" instruction. You said that raises a GP (huh?), which you handle, then you return from the handler to the old faulting address again. Then, not very surprising, "INT 0x10" raises the GP again, which you handle, then you return from the handler to the old faulting address. Then, not very surprising, "INT 0x10" raises the GP again... I think you got it by now?!

--TS
User avatar
ahmedhalawa
Member
Member
Posts: 28
Joined: Wed Jul 02, 2008 9:28 am

Re: vm86 mode(problem with #gp)

Post by ahmedhalawa »

Hai do you looked to the code i know gp will repeat him self when int 0x10 happen my question is:why that happen pleas look to my code first
User avatar
Combuster
Member
Member
Posts: 9301
Joined: Wed Oct 18, 2006 3:45 am
Libera.chat IRC: [com]buster
Location: On the balcony, where I can actually keep 1½m distance
Contact:

Re: vm86 mode(problem with #gp)

Post by Combuster »

The answer has been given, I suggest you read it :roll:
"Certainly avoid yourself. He is a newbie and might not realize it. You'll hate his code deeply a few years down the road." - Sortie
[ My OS ] [ VDisk/SFS ]
User avatar
ahmedhalawa
Member
Member
Posts: 28
Joined: Wed Jul 02, 2008 9:28 am

Re: vm86 mode(problem with #gp)

Post by ahmedhalawa »

Sorry for re open this topic
I had write vm86 code then i tried it and it's work finaly
after 2 days without change any of code
it bochs and my pc give me #gnf in int 0x10
at this address 0xC000:0xFFFF
Bochs msg is

Code: Select all

Prefetch: Eip [00010000] > cs limit [ 0000FFFF]
Does any one know the reason :!: :?:
Attachments
#gpf.cpp
My #gpf code
(1.56 KiB) Downloaded 87 times
User avatar
Combuster
Member
Member
Posts: 9301
Joined: Wed Oct 18, 2006 3:45 am
Libera.chat IRC: [com]buster
Location: On the balcony, where I can actually keep 1½m distance
Contact:

Re: vm86 mode(problem with #gp)

Post by Combuster »

Does any one know the reason
Prefetch: Eip [00010000] > cs limit [ 0000FFFF]
Asking answered question, no?


Question for you: what is the instruction pointer doing there? How does it get there? Is the bios actually mapped?
"Certainly avoid yourself. He is a newbie and might not realize it. You'll hate his code deeply a few years down the road." - Sortie
[ My OS ] [ VDisk/SFS ]
User avatar
ahmedhalawa
Member
Member
Posts: 28
Joined: Wed Jul 02, 2008 9:28 am

Re: vm86 mode(problem with #gp)

Post by ahmedhalawa »

I think you read this sentence
I had write vm86 code then i tried it and it's work finaly
after 2 days without change any of code
it bochs and my pc give me #gnf in int 0x10
Mr. Combuster or my best man :D
first pages from 0x00000000 to 0x00200000 mapped in to the same
address there some thing else it's happen after 40 instruction
exact after ret instruction May it happen because i put bad stack address then bois out bad values i donn't think so
i attachment gpf.cpp code you can look to it then give me reason
Post Reply