From: Sengan DOT Short AT durham DOT ac DOT uk
Message-Id: <27927.9607201420@ws-ai5.dur.ac.uk>
Subject: Re: XMS entry point
To: grendel AT ananke DOT amu DOT edu DOT pl (Mark Habersack)
Date: Sat, 20 Jul 1996 15:20:16 +0100 (BST)
Cc: djgpp AT delorie DOT com
In-Reply-To: <Pine.NEB.3.93.960720145510.4266A-100000@ananke.amu.edu.pl> from "Mark Habersack" at Jul 20, 96 03:05:42 pm
Mime-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit

> I am writing a set of routines to detect and provide info on various
> memory-management services. Among all the others there's one to cope with XMS.
> One of the stages in getting XMS info is to collect the real-mode entry-point
> address for the XMS services. And here's where problems begin. I succesfuly
> retrieve this entry point using 0x4310 int 2F call but when I try to call the
> procedure it hangs the machine. Of course I'm not calling the proc directly
> but by means of __dpmi_simulate_proc_retf (I don't remember the name right
> know - they all too long ;-)))) - but it doesn't work. I was unable to check
> what's going on, even with GDB - it hangs also. As far as I could check, the
> es:bx pointer returned by 0x4310 2F call is OK. Where lies the problem? Is it
> allowed to call the XMS services from 32-bit proggy? I have checked that it is
> not a problem of DPMI server - all of them crash without a blink. 
> The only sensible message I got from the system comes from EMM386 - it says
> about exception in the software (it doesn't say which one) and that the system
> has been halted. So it seems that the crash happens AFTER processing the call
> by DPMI server. 

Well, I expect you are conflicting with the DPMI server: the DPMI server uses
XMS if it is available (possibly through EMM if necessary). So if you change
stuff in a way the dpmi server does not expect, you must expect trouble.

Also, it might help to know with what parameters you are calling the
procedure with.

Sengan