From: Piet van Oostrum Date: Mon, 6 Mar 1995 12:16:28 +0100 To: emx-list , djgpp AT sun DOT soe DOT clarkson DOT edu, rainer AT mathematik DOT uni-bielefeld DOT de (Rainer Schnitker), mattes AT azu DOT informatik DOT uni-stuttgart DOT de (Eberhard Mattes), dj (DJ Delorie), fhart AT atlanta DOT twr DOT com (C. Frederick Hart), ue508 AT freenet DOT victoria DOT bc DOT ca (Trevor L. Smith), ghernan AT bribri DOT ci DOT ucr DOT ac DOT cr (Luis G. Hernandez U.) Subject: Summary (Re: DJGPP or EMX?) References: <199502211609 DOT RAA22669 AT stego DOT cs DOT ruu DOT nl> Some weeks ago I asked about the DJGPP and EMX ports of gcc for MS-DOS and the relative differences. Here is a summary of the answers I received. Please note that I couldn't check the validity of all answers. First a brief introduction to these systems. ------------------------------------------------------------------------------ DJGPP is a 32-bit C/C++/Objective C development system for Intel 80386 (and higher) PCs running DOS. It includes ports of many GNU development utilities. It was ported by DJ Delorie and friends. It generates 32-bit programs that need a DOS-extender (go32) to run. It can be found at the simtel mirrors: Oakland Univ: oak.oakland.edu /SimTel/msdos/djgpp St. Louis, MO: wuarchive.wustl.edu /systems/msdos/simtel/djgpp Corvalis, OR: archive.orst.edu /pub/mirrors/simtel/msdos/djgpp Australia: archie.au /micros/pc/oak/djgpp England: src.doc.ic.ac.uk /pub/packages/simtel/djgpp Finland: ftp.funet.fi /pub/msdos/SimTel/djgpp France: ftp.ibp.fr /pub/pc/SimTel/msdos/djgpp Germany: ftp.uni-paderborn.de /SimTel/msdos/djgpp Hong Kong: ftp.cs.cuhk.hk /pub/simtel/msdos/djgpp Israel: ftp.technion.ac.il /pub/unsupported/dos/simtel/djgpp Poland: ftp.cyf-kr.edu.pl /pub/mirror/msdos/djgpp Sweden: ftp.sunet.se /pub/pc/mirror/SimTel/msdos/djgpp Switzerland: ftp.switch.ch /mirror/msdos/djgpp Taiwan: nctuccca.edu.tw /PC/simtel/djgpp Thailand: ftp.nectec.or.th /pub/mirrors/SimTel/msdos/djgpp ------------------------------------------------------------------------------ EMX is a port of the same for OS/2 but it also runs on MS-DOS. It also generates 32-bit programs, and these need a DLL for OS/2 and an extender for DOS. It can also be used to compile OS/2 PM (Presentation Manager) programs. It was ported by Eberhard Mattes and can be found at: ftp.informatik.tu-muenchen.de(131.159.0.198) in /pub/comp/os/os2/devtools/emx+gcc ftp.uni-stuttgart.de(129.69.1.12) in /pub/systems/os2/ src.doc.ic.ac.uk(146.169.2.1) in /pub/packages/os2/2_x/unix/gnu/ For USA sites: ftp-os2.cdrom.com: /pub/os2/32bit/unix/emx09a/ ftp-os2.nmsu.edu: /pub/os2/32bit/unix/emx09a/ (Read README.DOC and INSTALL.DOC first. Needs emxfix02.zip also.) emx-0.9a is the latest version. EMX compiled programs can only run under MS-Windows (or any other DPMI system) by using RSX (see next item) ------------------------------------------------------------------------------ RSX is another DOS-extender written by Rainer Schnitker . It can also run djgpp compiled programs and it replaces go32 then. It is said to be faster than go32 under DPMI. It also does floating point emulation if you don't have a FPU. RSX supports a couple more system calls than emx and djgpp. RSXWIN is an emulator to run EMX text programs in an MS-Windows window rather than a DOS box. RSXWIN only works with normal printf() -- not direct or Bios video output. RSXWDK is a kit for building 32 bit MS-Windows Apps with EMX+GCC and DJGPP. It includes the windows extender RSXW32. For djgpp you will need the sources also (this is NOT mentioned in the help file). You also need DJGPP 1.11m12 or later. RSX can be obtained from ftp.uni-bielefeld.de:/pub/systems/msdos/misc. dpmigcc5 is the basic RSX system. What is missing is a windows.h file. The doc says that you should obtain this from a commercial compiler. I found a windows.h in the WINE projects but I don't know it this can be used. Please let someone try this. See http://www.ifi.uio.no/~dash/wine/wine-dist/include/windows.h Or ftp the whole package from: sunsite.unc.edu:/pub/Linux/ALPHA/wine/Wine-950302.tar.gz aris.com:/pub/linux/ALPHA/Wine/development/Wine-950302.tar.gz tsx-11.mit.edu:/pub/linux/ALPHA/Wine/development/Wine-950302.tar.gz ftp.funet.fi:/pub/OS/Linux/ALPHA/Wine/Wine-950302.tar.gz ftp.wonderland.org:/Wine/Wine-950302.tar.gz ------------------------------------------------------------------------------ OK now come my questions and a summary of the answers for each one. If you want to receive all the replies that I got, please email me and I will send it to you. PvO> 1. If I read the EMX doc correctly I cannot spawn (exec) a PvO> "normal" MSDOS program from an EMX program. Is that correct? If PvO> so, is the same true for djgpp? djgpp can spawn any program that can run under dos. It spawns other djgpp programs directly to allow for long command lines, but will use the system to spawn any other program. You can spawn a normal MS-DOS program from an EMX program if you use the -p option (emxbind -a prog -p). PvO> 2. If you spawn a djgpp program from another one, 130KB of low memory is PvO> used, thereby limiting the number of instances to 5. Is the same true PvO> for emx? Currently (with version 1.1x) everytime a djgpp program is called, the go32 extender will take up 130k of memory. So, ideally, you can spawn 5 djgpp programs (the number may be less than 5 if one of the programs allocated some DOS memory.) djgpp V2 will reduce this overhead to a very low amount - about 17K - allowing many nestings. V2 is in alpha development. If you run an EMX program from an EMX program, no additional low memory is used. However, the number of processes is currently limited to 6; this can be changed by modifying the MAX_PROCESES constant in \emx\src\dos\process.inc and rebuilding emx.exe. PvO> 3. EMX cannot run under DPMI, except when you use the RSX extender. DJGPP PvO> programs can, but they can also run under RSX. Any [dis]advantages? PvO> RSXWIN can run EMX programs in a normal MSWindows window. Can this also PvO> be done with djgpp programs? Most djgpp program can run under Window (through the DPMI interface.) The other program(s) might not run correctly because of: 1. They use code that assumes DOS memory is mapped to 0xe0000000 area. 2. They use code that attempts to manipulate the stack directly (such that the profile feature in ladybug 1.00) 3. They try to emulate the 387 by a go32-style exception handler. PvO> 4. RSXWDK can be used to develop MSWindows programs with EMX. IS there a PvO> similar thing for DJGPP? Yes. RSXWDK2 allows one to use djgpp to create windows programs. I just used the test files, and they worked. (don't just get the binary, get the source also. you need both). unzip the rsxwdk2s.zip (source code). Otherwise the lib patch script did not work (No it does not tell you if it fails). Just get the source and redo the lib patch. PvO> 5. How about mixing the two? Is there any problem with using djgpp programs PvO> in an EMX environment or v.v.? No problem. E.g. you can run the DJGPP version of GNU make regardless of what compiler you are using (DJGPP, EMX, tcc ...) PvO> 6. Are some programs easier to port with one or the other? Interestingly both say that there system is better for Unix support djgpp was designed specifically to port unix programs; mostly the GNU ones. It may be easier to port with djgpp if you have a unix program to port. X and X/Motif programs should port easily with djgpp and DESQview/X. The POSIX.1 and Unix support of emx used to be better; for instance, DJGPP didn't have termio/termios and signals. This might have changed in the meantime. DJGPP has DOS things like and ScreenPutCh(). EMX is somewhat cleaner in making the DOS, OS/2, UNIX, ANSI distinctions apparent. Example: both DJGPP and EMX support command-line globbing, but - DJGPP does the globbing before main() so that argv[] is expanded as if passed from the shell, unless noglob is specified in the GO32 environment variable. - EMX requires that you explicitly request "_wildcard (&argc, &argv);" at the beginning of main(). emx/rsx has signals, fork, pipe etc which are missing from the current DJGPP (but will be added in the next version). I think if you use djgpp with rsx you will get signals, fork. PvO> 7. More? E.g.: djgpp's graphics support (VCPI) is much better than emx/gcc's. -- Piet van Oostrum http://www.cs.ruu.nl/~piet