Mail Archives: djgpp/1996/08/19/08:16:29
Xref: | news2.mv.net comp.os.msdos.djgpp:7622
|
From: | "John M. Aldrich" <fighteer AT cs DOT com>
|
Newsgroups: | comp.os.msdos.djgpp
|
Subject: | Re: DPMI programming
|
Date: | Sun, 18 Aug 1996 21:48:25 -0700
|
Organization: | Three pounds of chaos and a pinch of salt
|
Lines: | 61
|
Message-ID: | <3217F219.280@cs.com>
|
References: | <4v797b$35l AT tornix DOT tornado DOT be>
|
NNTP-Posting-Host: | ppp222.cs.com
|
Mime-Version: | 1.0
|
To: | Schmitz Stéphane <tyrell AT tornado DOT be>
|
DJ-Gateway: | from newsgroup comp.os.msdos.djgpp
|
Schmitz Stéphane wrote:
> I just downloaded the DPMI specs but it doesn't help me a lot.
> It seems very difficult to code programs that use the DPMI interface.
> What I want is beeing able to use all the computer memory available (to
> dynamically allocate chunks of memory without worrying about the memory
> limits). For example, I have 32 megs of memory. What have I to code if I
> want to load, for example, a lot of big .WAV files into memory and then
> working on them ?
You're making things way too complex for yourself. :) The whole theory
behind DPMI is that the host handles all memory allocation: switch to
protected mode, virtual memory, page swapping, etc. You don't need to do
anything at all to make this happen. Just malloc() away, and just check
for NULL to indicate that you ran out of memory.
> So here's my questions : is there a good DPMI documentation that explains
> everything from a to z (and easily understandable even by the beginner that
> I am) ? I have seen programs that use the extended memory and wondered how
> to do that. But reading and understanding a source is maybe a good way, but
> a long and *very* difficult one. Are there special libs to include in the
> executable file ? Are there C headers required (go32.h for example) ? Are
> there GCC command line parameters I have to type when I compile the program
> ? Are there any other programs needed when I run the app (go32-v2.exe,
> cwsdpmi.exe...) ? You see that I have a lot of questions ! (don't forget I'm
> a total beginner is this environment).
The DPMI spec was not meant to be read by novices. While programming
under DPMI is quite simple, the actual interface is extremely complex.
If anyone has written a version for beginners to understand, I've never
heard of it. :)
On the other hand, all you need to run a DJGPP compiled program is a DPMI
host of some sort. When the program runs, the startup code in the stub
looks for existing DPMI services, and only if it doesn't find them does
it run CWSDPMI. What this means is if your program is run in a Windows
DOS shell, or on a system using QDPMI (QEMM's DPMI host), 4DOS, 386MAX,
OS/2 DOS mode, or Linux dosemu, it doesn't need anything else to run.
However, it is always a good idea to include CWSDPMI anyway, just in case
a user runs your program in vanilla DOS. It must either be in the same
directory as the program or somewhere in the PATH.
As for <dpmi.h> and <go32.h>, you only need these if you are going to be
working directly with the DPMI interface. Unless you are working with
interrupts, direct hardware interface, or related things, you can safely
ignore that part of DJGPP. Also, you don't really need go32-v2 for
anything either. It exists for two (well, actually three) purposes: To
enable you to run old v1.* programs without the entire v1 installation
(although you still need the go32 from v1), to run unstubified v2
programs, and to give you a quick report on available system memory.
Hope this helps!
--
John M. Aldrich, aka Fighteer I <fighteer AT cs DOT com>
-----BEGIN GEEK CODE BLOCK-----
Version: 3.1
GCS d- s+:- a-->? c++>$ U@>++$ p>+ L>++ E>+ W+>++ N++ o+ K? w(---) O-
M-- V? PS+ PE Y+ PGP- t+(-) 5- X- R+ tv+() b+++ DI++ D++ G e(*)>++++
h!() !r !y+()
------END GEEK CODE BLOCK------
- Raw text -