Name Last modified Size Description
Parent Directory - tweaks.html 2021-11-17 02:14 11K EMUfailure.html 2021-11-17 02:14 13K NOVELL-HOWTO.txt 2021-11-17 02:14 14K
You can start DOSEMU using
$ dosemu |
If for some reason it does not start, or DOSEMU crashes somewhere, look at ~/.dosemu/boot.log for details.
Remember, that you can't use <Ctrl>-C within DOS to exit from DOS. For this you need to execute exitemu or, when using the 'DOS in a BOX' <Ctrl><Alt><PgDn>.
Your DOS drives are set up as follows:
A: floppy drive (if it exists) C: points to the Linux directory ~/.dosemu/drive_c. It contains the files config.sys, autoexec.bat and a directory for temporary files. It is available for general DOS use. D: points to your Linux home directory E: points to your CD-ROM drive, if it is mounted at /media/cdrom Z: points to the read-only DOSEMU and FreeDOS commands directory It actually points to ~/mydos/dosemu/drive_z; it appears read-only inside DOSEMU. |
You can use the LREDIR DOSEMU command to adjust these settings, or edit /etc/dosemu/dosemu.conf, ~/.dosemu/.dosemurc, c:\config.sys, or c:\autoexec.bat, or change the symbolic links in ~/.dosemu/drives.
Enter HELP for more information on DOS and DOSEMU commands. Note that FreeDOS COMMAND.COM DIR command shows long file names if you type DIR/LFN.
Other useful keys are:
<Ctrl><Alt><F> toggle full-screen mode in X <Ctrl><Alt><K> grab the keyboard in X <Ctrl><Alt><Home> grab the mouse in X <Ctrl><Alt><Del> reboot <Ctrl><^> use special keys on terminals (dosemu -t) |
There exist various ways of starting DOSEMU, depending on the environment and certain command line options. By default, in X, it will start using a special 'DOS in a Box' which provides a usual PC setup, using a 80x25 text mode. It also supports graphics. The box can be rescaled by dragging the window borders using the mouse.
However, in certain situation you may want to use a different mode.
Terminal mode is automatically entered if you do not have X available, for instance when logging in remotely from a Windows system or at the Linux console. You can force it using:
$ dosemu -t |
You can use the $_internal_char_set option in ~/.dosemu/.dosemurc or dosemu.conf to change the code page that DOSEMU thinks that DOS is using.
Many terminals do not support various function key combinations. On the Linux console you can work around that by using the raw keyboard mode (-k flag, or $_rawkeyboard). xterm's support many key combinations. In other cases you'll have to work around it using the special Ctrl-^ shortcut (Ctrl-6 on US keyboards). Press Ctrl-^ h for help.
For DOS applications that only read from standard input and write to standard output, without any full-screen usage, you can use dumb mode. To use this you must invoke DOSEMU like
$ dosemu -dumb |
$ dosemu -dumb dir > listing |
You can start dosemu with the "-S" option to use the SDL library. In X it will just look like a regular DOS in a Box but with a different shaped text mode mouse cursor. You can also use this mode on frame buffer consoles.
Console graphics mode is the hardest to setup and may potentially lock up your system, but if it works it gives you direct VGA hardware access which may be quicker and more accurate than the emulation used in X.
You need root rights to use it. To enable it, it is recommended to use "sudo":
install sudo if you haven't already done so
use visudo as root to add entries such as
joeuser hostname=(root) PASSWD: /usr/local/bin/dosemu.bin |
if you change PASSWD to NOPASSWD then joeuser does not need to type the user's password (not root's password) when invoking DOSEMU (a little less secure, if somebody hacks into joeuser's account).
now invoke DOSEMU using dosemu -s
You can use something like
dosemu "/home/clarence/games/commander keen/keen1.exe" |
"cd" to the correct directory,
execute the program automagically,
and quit DOSEMU when finished.
It is possible to use a different DOS than the supplied FreeDOS in DOSEMU. A straightforward way is to just copy the relevant system files (io.sys, msdos.sys, etc.) to ~/.dosemu/drive_c, and then the next time you run dosemu it will automatically use them. You may need to edit config.sys and autoexec.bat though, if the DOS complains.
Another way is to boot directly from a Linux mounted FAT partition, with Windows 9x or any DOS installed. You can change the C: drive to point to that by using dosemu -i.
In that case the DOSEMU support commands are available on drive D: instead of drive Z:. You might want to use different config.sys and autoexec.bat files with your DOS. For example, you can try to copy D:\config.emu and D:\autoemu.bat to C:\, adjust them, and use the $_emusys option in ~/.dosemu/.dosemurc or dosemu.conf.
Manual adjustment of the C: drive is also possible, by changing the ~/.dosemu/drives/c symbolic link or by specifying it explicitly using the $_hdimage run-time option.
The rest of this document goes into more detail about all the different settings and possibilities. This documentation is derived from a number of smaller documents. This makes it easier for individuals to maintain the documentation relevant to their area of expertise. Previous attempts at documenting DOSEMU failed because the documentation on a large project like this quickly becomes too much for one person to handle.
This section of the document by Hans, <lermen@fgan.de>. Last updated on May 4, 2007, by Bart Oldeman.
Most of DOSEMU configuration is done during runtime and per default it can use the system wide configuration file dosemu.conf (which is often situated in /etc or /etc/dosemu) optionally followed by the users ~/.dosemurc and additional configurations statements on the commandline (-I option). If /etc/dosemu.users exists then dosemu.conf is searched for in /etc and otherwise in /etc/dosemu (or an alternative sysconfdir compiletime-setting).
The default dosemu.conf and ~/.dosemurc have all settings commented out for documentation purposes; the commented out values are the ones that DOSEMU uses by default. Note that a non-suid type of installation does not need the dosemu.users and dosemu.conf files, and the main per-user configuration file is $HOME/.dosemurc. However, for security reasons, a suid-root installation will not run without dosemu.users, and in that case certain dosemu.conf settings are ignored by ~/.dosemurc.
In fact dosemu.conf and ~/.dosemurc (which have identical syntax) are included by the systemwide configuration script global.conf which, by default, is built into the DOSEMU binary. As a normal user you won't ever think on editing this, only dosemu.conf and your personal ~/.dosemurc. The syntax of global.conf is described in detail in README-tech.txt, so this is skipped here. However, the option -I string too uses the same syntax as global.conf, hence, if you are doing some special stuff (after you got familar with DOSEMU) you may need to have a look there.
The first file expected (and interpreted) before any other configuration (such as global.conf, dosemu.conf and ~/.dosemurc) is /etc/dosemu.users or /etc/dosemu/dosemu.users. As mentioned above, this file is entirely optional for non-suid-root (default) installations. Within this file the general permissions are set:
which users are allowed to use DOSEMU.
which users are allowed to use DOSEMU suid root.
which users are allowed to have a private lib dir.
what kind of access class the user belongs to.
what special configuration stuff the users needs
and further more:
whether the lib dir (DOSEMU_LIB_DIR) resides elsewhere.
setting the loglevel.
Except for lines starting with `xxx=' (explanation below), each line in dosemu.user corresponds to exactly one valid user count, the special user `all' means any user not mentioned earlier. Format:
[ <login> | all ] [ confvar [ confvar [ ... ] ] ] |
The below example is from etc/dosemu.users.secure, which you may copy to /etc/dosemu.users.
root c_all # root is allowed to do all weird things nobody nosuidroot guest # variable 'guest' is checked in global.conf # to allow only DEXE execution guest nosuidroot guest # login guest treated as `nobody' myfriend c_all unrestricted private_setup myboss nosuidroot restricted private_setup all nosuidroot restricted # all other users have normal user restrictions |
The use of `nosuidroot' will force a suid root dosemu binary to exit, the user may however use a non-suid root copy of the binary. For more information on this look at README-tech, chapter 11.1 `Privileges and Running as User'
Giving the keyword `private_setup' to a user means he/she can have a private DOSEMU lib under $HOME/.dosemu/lib. If this directory is existing, DOSEMU will expect all normally under DOSEMU_LIB_DIR within that directory. As this would be a security risk, it only will be allowed, if the used DOSEMU binary is non-suid-root. If you really trust a user you may additionally give the keyword `unrestricted', which will allow this user to execute a suid-root binary even on a private lib directory (though, be aware).
In addition, dosemu.users can be used to define some global settings, which must be known before any other file is accessed, such as:
default_lib_dir= /opt/dosemu # replaces DOSEMU_LIB_DIR log_level= 2 # highest log level |
With `default_lib_dir=' you may move DOSEMU_LIB_DIR elsewhere, this mostly is interesting for distributors, who want it elsewhere but won't patch the DOSEMU source just for this purpose. But note, the dosemu supplied scripts and helpers may need some adaption too in order to fit your new directory.
The `log_level=' can be 0 (never log) or 1 (log only errors) or 2 (log all) and controls the ammount written to the systems log facility (notice). This keyword replaces the former /etc/dosemu.loglevel file, which now is obsolete.
Nevertheless, for a first try of DOSEMU you may prefer etc/dosemu.users.easy, which just contains
root c_all all c_all |
After the file dosemu.users, the file dosemu.conf (via global.conf, which may be built-in) is interpreted, and only during global.conf parsing the access to all configuration options is allowed. dosemu.conf normally lives in the same directory as dosemu.users, for instance /etc/dosemu or /etc (that is, sysconfdir in compiletime-settings). Your personal ~/.dosemurc is included directly after dosemu.conf, but has less access rights (in fact the lowest level), all variables you define within ~/.dosemurc transparently are prefixed with `dosemu_' such that the normal namespace cannot be polluted (and a hacker cannot overwrite security relevant enviroment variables). Within global.conf only those ~/.dosemurc created variables, that are needed are taken over and may overwrite those defined in dosemu.conf.
The dosemu.conf (global.conf) may check for the configuration variables, that are set in dosemu.users and optionaly include further configuration files. But once dosemu.conf (global.conf) has finished interpretation, the access to secure relevant configurations is (class-wise) restricted while the following interpretation of (old) .dosrc and -I statements.
For more details on security settings/issues look at README-tech.txt, for now (using DOSEMU the first time) you should need only the below description of dosemu.conf (~/.dosemurc)
All settings are variables, and have the form of
$_xxx = (n) |
$_zzz = "s" |
where `n' is a numerical or boolean value and `s' is a string. Note that the brackets are important, else the parser will not decide for a number expression. For numbers you may have complete expressions ( such as (2*1024) ) and strings may be concatenated such as
$_zzz = "This is a string containing '", '"', "' (quotes)" |
Hence a comma separated list of strings is concatenated. All these settings are also environment variables. You can override them by prefixing with dosemu_, e.g.
dosemu__X_title="DOS was in the BOX" dosemu |
The parameter settings are tailored to fit the recommended usage of disk and floppy access. There are other methods too, but for these you have to look at README-tech.txt (and you may need to modify global.conf). We strongly recommend that you use the proposed techique. Here the normal setup:
# List of hdimages or boot directories under # ~/.dosemu, the system config directory (/etc/dosemu by default), or # syshdimagedir (/var/lib/dosemu by default) assigned in this order # such as "hdimage_c directory_d hdimage_e" # Absolute pathnames are also allowed. $_hdimage = "drives/*" $_floppy_a ="threeinch" # or "fiveinch" or empty, if not existing $_floppy_b = "" # dito for B: $_cdrom = "/dev/cdrom" # list of CDROM devices |
A hdimage is a file containing a virtual image of a DOS-FAT filesystem. Once you have booted it, you (or autoexec.bat) can use `lredir' to access any directory in your Linux tree as DOS drive (a -t msdos mounted too). Look at chapter 5 (Using Lredir) for more details. If you want to create your own hdimage use "mkfatimage16" (see the manual page). To make it bootable you can make it, say, drive F:, and use "SYS F:" at the DOS prompt. The DOSEMU-HOWTO explains how to manipulate it using mtools.
You can also specify a Linux directory containing all what you want to have under your DOS C:. Copy your IO.SYS, MSDOS.SYS or equivalent to that directory (e.g. DOSEMU_LIB_DIR/bootdir), set
$_hdimage = "bootdir" |
config.sys autoexec.bat command.com -> /dos/command.com io.sys -> /dos/io.sys msdos.sys -> /dos/msdos.sys dos -> /dos/dos bc -> /dos/bc windows -> /dos/windows |
As a further enhancement of your drives setup you may even use the following strategy: given you have the following directory structure in one the directories where the $_hdimage setting applies (this is done by default in ~/.dosemu and in /etc/dosemu)
drives/c drives/d |
$_hdimage = "drives/*" |
drives/x drives/a |
In some rare cases you may have problems accessing Lredir'ed drives (especially when your DOS application refuses to run on a 'network drive'), For this to overcome you may need to use so-called `partition access', use a floppy, or a special-purpose hdimage. The odd with partition access is, that you never should have those partition mounted in the Linux file system at the same time as you use it in DOSEMU (which is quite uncomfortable and dangerous on a multitasking OS such as Linux ). Though DOSEMU checks for mounted partitions, there may be races that are not caught. In addition, when your DOSEMU crashes, it may leave some FAT sectors unflushed to the disk, hence destroying the partition. Anyway, if you think you need it, you must have r/w access to the partition in /dev, and you have to `assign' real DOS partitions as follows:
$_hdimage = "hdimage.first /dev/hda1 /dev/sdc4:ro" |
The above will have `hdimage.first' as booted drive C:, /dev/hda1 as D: (read/write) and /dev/sdc4 as E: (readonly). You may have any kind of order within `$_hdimage', hence
$_hdimage = "/dev/hda1 hdimage.first /dev/sdc4:ro" |
would have /dev/hda1 as booted drive C:. Note that the access to the /dev/* devices must be exclusive (no other process should use it) except for `:ro'.
DOSEMU will help you find problems, when you enable its debug messages. These will go into the file, that you defined via the `-o file' or `-O' commandline option (the latter prints to stderr). If you do not specify any -O or -o switch, then the log output will be written to ~/.dosemu/boot.log. You can preset the kind of debug output via
$_debug = "-a" |
Whether a numeric processor should be shown to the DOS space
$_mathco = (on) |
Which type of CPU should be emulated (NOTE: this is not the one you are running on, but your setting may not exeed the capabilities of the running CPU). Valid values are: 80[345]86
$_cpu = (80386) |
To let DOSEMU use the Pentium cycle counter (if availabe) to do better timing use the below
$_rdtsc = (off) # or on |
For the above `rdtsc' feature DOSEMU needs to know the exact CPU clock, it normally calibrates it itself, but is you encounter a wrong mesurement you may overide it such as
$_cpuspeed = (166.666) # 0 = let DOSEMU calibrate |
If you have a PCI board you may allow DOSEMU to access the PCI configuration space by defining the below
$_pci = (auto) # or auto, or off |
NOTE: `$_pci' can not be overwritten by ~/.dosemurc. The "on" setting can be very dangerous because it gives DOSEMU complete write access; you need to edit dosemu.users to enable it. In console graphics mode, some video card BIOSes need some PCI configuration space access, which is enabled by the default (auto) setting. This setting is far more restricted and less dangerous.
Starting with dosemu-1.0 there is a flexible way to handle the mapping strategy used by DOSEMU, which is needed by video emulation, EMS, DPMI and XMS support and other things to map a given page of memory to the required virtual DOS address space.
Normally DOSEMU will detect the proper mapping driver for the kernel you are using, however, in some cases you may want to define it explicitely to overcome eventual problems. For this you can specify
$_mapping= "mapfile" |
If you are using a kernel above 2.3.40, you may use
$_mapping= "mapshm" |
$_mapping= "mapashm" |
Note, that in case of `mapfile' and `mapshm' the size of the file or the segment depend on how much memory you configured for XMS, EMS and DPMI (see below). You should take care yourself that you have enough diskspace for 'mapfile'. For 'mapshm' the tmpfs mount option 'size=nbytes' controls the amount of space; by default it is half of the (real machine) memory.
Defining the memory layout, which DOS should see:
$_xms = (8192) # in Kbyte $_ems = (2048) # in Kbyte $_ems_frame = (0xe400) $_dpmi = (0x5000) # in Kbyte $_dosmem = (640) # in Kbyte, < 640 |
If you want mixed operation on the filesystem, from which you boot DOSEMU (native and via DOSEMU), it may be necessary to have two separate sets of config.sys and system.ini. DOSEMU can fake a different file extension, so DOS will get other files when running under DOSEMU. Faking autoexec.bat cannot happen in a reliable fashion, so if you would like to use an autoexec.bat replacement then just use the SHELL command in config.XXX, like this:
SHELL=COMMAND.COM /P /K AUTOEMU.BAT
$_emusys = "" # empty or 3 char., config.sys -> config.XXX $_emuini = "" # empty or 3 char., system.ini -> system.XXX |
As you would realize at the first glance: DOS will not have the the CPU for its own. But how much it gets from Linux, depends on the setting of `hogthreshold'. The HogThreshold value determines how nice Dosemu will be about giving other Linux processes a chance to run.
$_hogthreshold = (1) # 0 == all CPU power to DOSEMU # 1 == max power for Linux # >1 the higher, the faster DOSEMU will be |
To select the character set and code page for use with DOSEMU you have
$_external_char_set = "XXX" |
"cp437", "cp737", "cp773", "cp775", "cp850", "cp852", "cp857", "cp860", "cp861", "cp862", "cp863", "cp864", "cp865", "cp866", "cp869", "cp874", "cp1125", "cp1251" "iso8859-1", "iso8859-2", "iso8859-3", "iso8859-4", "iso8859-5", "iso8859-6", "iso8859-7", "iso8859-8", "iso8859_9", "iso8859-14", "iso8859-15", "koi8-r" "koi8-u", "koi8-ru", "utf8" |
The external character set is used to:
compute the unicode values of characters coming in from the terminal
compute the character set index of unicode characters output to a terminal display screen.
If you set a DOS external character set, then it is to the user to load a proper DOS font (cp437.f16, cp850.f16 or cp852.f16 on the console).
$_internal_char_set = "XXX" |
"cp437", "cp737", "cp773", "cp775", "cp850", "cp852", "cp857", "cp860", "cp861", "cp862", "cp863", "cp864", "cp865", "cp866", "cp869", "cp874" "cp895", "cp1125", "cp1251", "bg-mik" |
The internal character set is used to:
compute the unicode value of characters of video memory, when using DOSEMU in a terminal or using X with a unicode font.
compute the character set index of unicode characters returned by bios keyboard translation services.
compute the unicode values of characters in file names.
This section applies whenever you run DOSEMU remotely, in an xterm or on the Linux console without graphics. Color terminal support is now built into DOSEMU. Skip this section for now to use terminal defaults, until you get DOSEMU to work.
$_term_color = (on) # terminal with color support $_term_updfreq = (4) # time between refreshs (units: 20 == 1 second) $_escchar = (30) # 30 == Ctrl-^, special-sequence prefix |
F1 is 'Ctrl-^1', Alt-F7 is 'Ctrl-^s Ctrl-^7'. For online help, press 'Ctrl-^h' or 'Ctrl-^?'. |
When running DOSEMU from console (also remote from console) or X you may need to define a proper keyboard layout. It is possible to let DOSEMU do this work automatically for you (see auto below), however, this may fail and you'll end up defining it explicitely. This is done either by choosing one on the internal keytables or by loading an external keytable from DOSEMU_LIB_DIR/keymap/* (which you may modify according to your needs). Both sets have identical names (though you may add any new one to DOSEMU_LIB_DIR/keymap/*):
be finnish hu-latin2 sg-latin1 de finnish-latin1 it sw de-latin1 fr keyb-no uk dk fr-latin1 no-latin1 us dk-latin1 hr-cp852 po dvorak hr-latin2 sf es hu sf-latin1 es-latin1 hu-cwi sg jp106 cz-qwerty cz-qwertz |
$_layout = "name" |
$_layout = "load de-latin1" |
Note, however, that you have to set
$_X_keycode = (on) |
The most comfortable method, however, is to first let DOSEMU set the keyboard layout itself. This involves 2 parts and can be done by setting
$_X_keycode = (auto) |
$_layout = "auto" |
When being on console you might wish to use raw keyboard, especially together with some games, that don't use the BIOS/DOS to get their keystrokes.
$_rawkeyboard = (1) |
If DOSEMU is running in its own X-window (not xterm), you may need to tailor it to your needs. Here a summary of the settings and a brief description what they mean. A more detailed description of values one can be found at chapter 2.2.14 (X Support settings) of README-tech.txt
$_X_updfreq = (5) # time between refreshs (units: 20 == 1 second) $_X_title = "DOS in a BOX" # Title in the top bar of the window $_X_icon_name = "xdos" # Text for icon, when minimized $_X_keycode = (off) # on == translate keybord via dosemu keytables $_X_blinkrate = (8) # blink rate for the cursor $_X_font = "" # basename from /usr/X11R6/lib/X11/fonts/misc/* # (without extension) e.g. "vga" $_X_mitshm = (on) # Use shared memory extensions $_X_sharecmap = (off) # share the colormap with other applications $_X_fixed_aspect = (on) # Set fixed aspect for resize the graphics window $_X_aspect_43 = (on) # Always use an aspect ratio of 4:3 for graphics $_X_lin_filt = (off) # Use linear filtering for >15 bpp interpol. $_X_bilin_filt = (off) # Use bi-linear filtering for >15 bpp interpol. $_X_mode13fact = (2) # initial factor for video mode 0x13 (320x200) $_X_winsize = "" # "x,y" of initial windows size $_X_gamma = (1.0) # gamma correction $_X_vgaemu_memsize = (1024) # size (in Kbytes) of the frame buffer # for emulated vga $_X_lfb = (on) # use linear frame buffer in VESA modes $_X_pm_interface = (on) # use protected mode interface for VESA modes $_X_mgrab_key = "" # KeySym name to activate mouse grab, empty == off $_X_vesamode = "" # "xres,yres ... xres,yres" # List of vesamodes to add. The list has to contain # SPACE separated "xres,yres" pairs |
The builtin ASPI driver (a SCSI interface protocol defined by Adaptec) can be used to run DOS based SCSI drivers that use this standard (most SCSI devices ship with such a DOS driver). This enables you to run hardware on Linux, that normally isn't supported otherwise, such as CD writers, Scanners e.t.c. The driver was successfully tested with Dat-streamers, EXABYTE tapedrives, JAZ drives (from iomega) and CD writers. To make it work under DOSEMU you need
to configure $_aspi to define which of the /dev/sgX devices you want to show up in DOSEMU.
to load the DOSEMU aspi.sys stub driver within config.sys (e.g. DEVICE=ASPI.SYS) before any ASPI using driver.
The $_aspi variable takes strings listing all generic SCSI devices, that you want give to DOSEMU. NOTE: You should make sure, that they are not used by Linux elsewhere, else you would come into much trouble. To help you not doing the wrong thing, DOSEMU can check the devicetype of the SCSI device such as
$_aspi = "sg2:WORM" |
$_aspi = "sg2 sg3 sg4" |
$_aspi = "sg1:Direct-Access" |
$_aspi = "sg1:0" |
$ cat /proc/scsi/scsi |
$ scsicheck sg0 scsi0 ch0 ID0 Lun0 ansi2 Direct-Access(0) IBM DCAS-34330 S61A $_aspi = "sg0:Direct-Access:0" (or "0/0/0/0:Direct-Access:0") sg1 scsi0 ch0 ID5 Lun0 ansi2 Direct-Access(0) IOMEGA ZIP 100 D.08 $_aspi = "sg1:Direct-Access:5" (or "0/0/5/0:Direct-Access:5") sg2 scsi0 ch0 ID6 Lun0 ansi2 CD-ROM(5) TOSHIBA CD-ROM XM-5701TA 0167 $_aspi = "sg2:CD-ROM:6" (or "0/0/6/0:CD-ROM:6") <== multiple IDs sg3 scsi1 ch0 ID4 Lun0 ansi2 Sequential-Access(1) HP C1533A 9503 $_aspi = "sg3:Sequential-Access:4" (or "1/0/4/0:Sequential-Access:4") sg4 scsi1 ch0 ID6 Lun0 ansi1 WORM(4) IMS CDD522/10 1.07 $_aspi = "sg4:WORM:6" (or "1/0/6/0:WORM:6") <== multiple IDs |
In the above example there are two scsi hostadapters (scsi0 and scsi1) and DOSEMU will not show more than one hostadapter to DOS (mapping them all into one), hence you would get problems accessing sg2 and sg4. For this you may remap a different targetID such as
$_aspi = "sg2:CD-ROM:5 sg4:WORM" |
$_aspi = "0/0/6/0:CD-ROM:5 1/0/6/0:WORM" |
echo "scsi remove-single-device 0 0 5 0" >/proc/scsi/scsi |
echo "scsi add-single-device 0 0 5 0" >/proc/scsi/scsi |
Coming so far, one big problem remains: the (hard coded) buffersize for the sg devices in the Linux kernel (default 32k) may be to small for DOS applications and, if your distributor yet didn't it, you may need to recompile your kernel with a bigger buffer. The buffer size is defined in linux/include/scsi/sg.h and to be on the secure side you may define
#define SG_BIG_BUFF (128*1024-512) /* 128 Kb buffer size */ |
We have simplified the configuration for mice and serial ports and check for depencies between them. If all strings in the below example are empty, then no mouse and/or COM port is available. Note. that you need no mouse.com driver installed in your DOS environment, DOSEMU has the mousedriver builtin. The mouse settings below only apply to DOSEMU in the Linux console; in X and terminals the mouse is detected automatically. The below example is such a setup
$_com1 = "" # e.g. "/dev/mouse" or "/dev/ttyS0" $_com2 = "/dev/modem" # e.g. "/dev/modem" or "/dev/ttyS1" $_mouse = "microsoft" # one of: microsoft, mousesystems, logitech, # mmseries, mouseman, hitachi, busmouse, ps2 $_mouse_dev = "/dev/mouse" # one of: com1, com2 or /dev/mouse $_mouse_flags = "" # list of none or one or more of: # "emulate3buttons cleardtr" $_mouse_baud = (0) # baudrate, 0 == don't set |
The above example lets you have your modem on COM2, COM1 is spare (as you may have your mouse under native DOS there and don't want to change the configuration of your modem software between boots of native DOS and Linux)
However, you may use your favorite DOS mouse driver and directly let it drive COM1 by changing the below variables (rest of variables unchanged)
$_com1 = "/dev/mouse" $_mouse_dev = "com1" |
And finaly, when you have a PS/2 or USB mouse on your machine you use the built-in mouse driver (not your mouse.com) to get it work: ( again leaving the rest of variables unchanged)
$_mouse = "ps2" $_mouse_dev = "/dev/mouse" |
When using a PS/2 or USB mouse or when having more than 2 serial ports you may of course assign _any_ free serialdevice to COM1, COM2. The order doesn't matter:
$_com1 = "/dev/ttyS2" $_com2 = "/dev/ttyS0" |
Printer is emulated by piping printer data to your normal Linux printer. The belows tells DOSEMU which printers to use. The `timeout' tells DOSEMU how long to wait after the last output to LPTx before considering the print job as `done' and to close it.
# Print commands to use for LPT1, LPT2 and LPT3. # Default: "lpr -l, lpr -l -P lpt2, lpr -l P lpt3" # Which means: use the default print queue for LPT1, "lpt2" queue for LPT2, # "lpt3" queue for LPT3. "-l" means raw printing mode (no preprocessing). $_lpt1 = "lpr -l" $_lpt2 = "lpr -l -P lpt2" $_lpt3 = "lpr -l -P lpt3" $_printer_timeout = (20)# idle time in seconds before spooling out |
The following settings will tell DOSEMU to emulate an SB16 sound card using your Linux sound drivers. For more information see sound-usage.txt.
$_sound = (on) # sound support on/off $_sb_base = (0x220) # base IO-address (HEX) $_sb_irq = (5) # IRQ $_sb_dma = (1) # Low 8-bit DMA channel $_sb_hdma = (5) # High 16-bit DMA channel $_sb_dsp = "/dev/dsp" # Path to the sound device $_sb_mixer = "" # path to the mixer control $_mpu_base = (0x330) # base address for the MPU-401 chip (HEX) |
Here are the settings for Joystick emulation.
$_joy_device = "/dev/js0 /dev/js1" # 1st and 2nd joystick device # e.g. "/dev/js0" or "/dev/js0 /dev/js1" # (or "" if you don't want joystick support) # $_joy_dos_min = (1) # range for joystick axis readings, must be > 0 $_joy_dos_max = (150) # avoid setting this to > 250 $_joy_granularity = (1) # the higher, the less sensitive - # useful if you have a wobbly joystick # $_joy_latency = (1) # delay between nonblocking linux joystick reads # increases performance if >0 and processor>=Pentium # recommended: 1-50ms or 0 if unsure |
Turn the following option `on' if you require IPX/SPX emulation, there is no need to load IPX.COM within the DOS session. ( the option does not emulate LSL.COM, IPXODI.COM, etc. ) And NOTE: You must have IPX protocol configured into the kernel.
$_ipxsupport = (on) |
Enable Novell 8137->raw 802.3 translation hack in new packet driver.
$_novell_hack = (on) |
If you make use of TUN/TAP driver, then you can select it via
$_vnet = "tap" |
But if you just need 'single' packet driver support that talks to, for instance, your ethernet card eth0 then you need to set
$_netdev = "eth0" |
Note that dosnet and eth0 require raw packet access, and hence (suid)-root. If $_vnet = "dosnet", then $_netdev will default to "dsn0". If you would like to use persistent TUN/TAP devices then you need to specifify the TAP device in $_netdev. For more on this look at chapter 15 (Networking using DOSEMU).
The following settings (together with the direct console video settings below make it possible for DOSEMU to access your real (non-emulated) computer hardware directly. Because Linux does not permit this for ordinary users, DOSEMU needs to be run as root, via sudo or suid-root to be able to use these settings. They can NOT be overwritten by the user configuration file ~/.dosemurc. You must also run dosemu with the "-s" switch. This activates sudo when appropriate; without it, even root will not get direct hardware access.
Here you tell DOSEMU what to do when DOS wants let play the speaker:
$_speaker = "" # or "native" or "emulated" |
And with the below may gain control over real ports on you machine. But:
WARNING: GIVING ACCESS TO PORTS IS BOTH A SECURITY CONCERN AND SOME PORTS ARE DANGEROUS TO USE. PLEASE SKIP THIS SECTION, AND DON'T FIDDLE WITH THIS SECTION UNLESS YOU KNOW WHAT YOU'RE DOING.
$_ports = "" # list of portnumbers such as "0x1ce 0x1cf 0x238" # or "0x1ce range 0x280,0x29f 310" # or "range 0x1a0,(0x1a0+15)" |
If you have hardware, that is not supported under Linux but you have a DOS driver for, it may be necessary to enable IRQ passing to DOS. Note that IRQ passing does not work on x86-64.
$_irqpassing = "" # list of IRQ number (2-15) to pass to DOS such as # "3 8 10" |
!!WARNING!!: IF YOU ENABLE GRAPHICS ON AN INCOMPATIBLE ADAPTOR, YOU COULD GET A BLANK SCREEN OR MESSY SCREEN EVEN AFTER EXITING DOSEMU. Read doc/README-tech.txt (Recovering the console after a crash).
Start with only text video using the following setup
$_video = "vga" # one of: plainvga, vga, ega, mda, mga, cga $_console = (0) # use 'console' video $_graphics = (0) # use the cards BIOS to set graphics $_vbios_seg = (0xc000) # set the address of your VBIOS (e.g. 0xe000) $_vbios_size = (0x10000)# set the size of your BIOS (e.g. 0x8000) $_vmemsize = (0) # amount of video RAM to save/restore $_chipset = "" $_dualmon = (0) # if you have one vga _plus_ one hgc (2 monitors) |
After you get it `somehow' working and you have one of the DOSEMU supported graphic cards you may switch to graphics mode changing the below
$_graphics = (1) # use the cards BIOS to set graphics |
If you have a 100% compatible standard VGA card that may work, however, you get better results, if your card has one of the DOSEMU supported video chips and you tell DOSEMU to use it such as
$_chipset = "s3" # one of: plainvga, trident, et4000, diamond, s3, # avance, cirrus, matrox, wdvga, paradise, ati, sis, # svgalib, vesa |
Note, `s3' is only an example, you must set the correct video chip else it most like will crash your screen.
The 'svgalib' setting uses svgalib 1.9.21 or greater for determining the correct video chip.
The 'vmemsize' setting's default of 0 causes DOSEMU to try to autodetect the amount of video memory on the graphics card. This amount is saved and restored when you switch away from and back to the virtual console DOSEMU runs in using the Ctrl-Alt-Fn key combination. Since saving video memory can be a very slow operation you may want to restrict 'vmemsize' to a value that was more common when DOS was still mainstream. For instance 1024 covers it if you want to be able to save and restore modes up to 1024x768x256.
NOTE: `video setting' can not be overwritten by ~/.dosemurc.
By Paul Crawford. This is a short guide to the time modes supported in DOSEMU; you can get a more detailed description of how and why they operate at http://www.sat.dundee.ac.uk/~psc/dosemu_time_advanced.html. There are three modes currently supported using the $_timemode variable:
$_timemode = "bios" $_timemode = "pit" $_timemode = "linux" |
In BIOS mode, the DOSEMU session begins with the current (local) date & time, and once running it behaves fully like an emulated PC. You can set the date & time using the normal DOS methods as you would expect. However, time keeping accuracy in the long term under DOS was never very good, and under DOSEMU it is typically poorer.
In LINUX mode, the emulated PC always reports the current host time, and so you no longer have the option to set the DOS time (the date can be set, which is odd, as this is kept in DOS and not in the emulator). In this mode you get the long term accuracy of the host, so if you are running NTP or similar, you always get accurate time.
A reasonable question for some applications is "how do I get accurate UTC time?", of course, the more general question is about running the emulated DOS session in a different timezone and/or with differing "daylight saving" options to the host computer. This is quite simple in fact, just start DOSEMU with the environment variable TZ set to the required zone, and don't forget to have the corresponding command in the DOS autoexec.bat file (otherwise Microsoft products all assume -8 hours PST!). The DOSEMU emulation of file system access is also based on the local timezone it is running in, so you will get consistent file time stamps compared to the emulated time. So in the UTC case, you would start DOSEMU in a shell with TZ=GMT0, and have a line in autoexec.bat with "set TZ=GMT0" before any of your programs are run.
This part of the document by Hans Lermen, <lermen@fgan.de> on Apr 6, 1997.
These are the hints we give you, when running dosemu on a machine that is (even temporary) connected to the internet or other machines, or that otherwise allows 'foreign' people login to your machine.
Don't set the "s" bit, as DOSEMU can run in lowfeature mode without the "s" bit set. If you want fullfeatures for some of your users, it is recommended to use "sudo". Alternatively you can just use the keyword `nosuidroot' in /etc/dosemu.users to forbid some (or all) users execution of a suid root running dosemu (they may use a non-suid root copy of the binary though). DOSEMU now drops its root privileges before booting; however there may still be security problems in the initialization code, and by making DOSEMU suid-root you can give users direct access to resources they don't normally have access too, such as selected I/O ports, hardware IRQs and hardware RAM. For any direct hardware access you must always use the "-s" switch.
If DOSEMU is invoked via "sudo" then it will automatically switch to the user who invoked "sudo". An example /etc/sudoers entry is this:
joeuser hostname=(root) NOPASSWD: /usr/local/bin/dosemu.bin |
Use proper file permissions to restrict access to a suid root DOSEMU binary in addition to /etc/dosemu.users `nosuidroot'. ( double security is better ).
NEVER let foreign users execute dosemu under root login !!! (Starting with dosemu-0.66.1.4 this isn't necessary any more, all functionality should also be available when running as user)
The SB code is currently in a state of flux. Some changes to the code have been made which mean that I can separate the DSP handling from the rest of the SB code, making the main case statements simpler. In the meantime, Rutger Nijlunsing has provided a method for redirecting access to the MPU-401 chip into the main OS.
The Sound driver opens "/var/run/dosemu-midi" and writes the Raw MIDI data to this. A daemon is provided which can be can be used to seletc the instruments required for use on some soundcards. It is also possible to get various instruments by redirecting '/var/run/dosemu-midi' to the relevant part of the sound driver eg:
% ln -s /dev/midi /var/run/dosemu-midi |
This will send all output straight to the default midi device and use whatever instruments happen to be loaded.
make midid |
This compiles and installs the midi daemon. The daemon currently has support for the 'ultra' driver and partial support for the 'OSS' driver (as supplied with the kernel) and for no midi system. Support for the 'ultra' driver will be compiled in automatically if available on your system.
Copy the executable './bin/midid' so that it is on your path, or somewhere you can run it easily.
Before you run DOSEMU for the first time, do the following:
mkdir -p ~/.dosemu/run # if it doesen't exist rm -f ~/.dosemu/run/dosemu-midi mknod ~/.dosemu/run/dosemu-midi p |
Then you can use the midi daemon like this:
./midid < ~/.dosemu/run/dosemu-midi &; dosemu |
(Assuming that you put the midid executeable in the directory you run DOSEMU from.)
You can disable the SB emulation by changing the 'sound' variable in /etc/dosemu.conf to 'off'. There is currently no way to specify at runtime which SB model DOSEMU should emulate; the best you can do is set the T value of the BLASTER environment variable (see sound-usage.txt), but not all programs will take note of this.
This section of the document by Hans, <lermen@fgan.de>. Last updated on October, 23 2002.
What is it? Well, its simply a small DOS program that tells the MFS (Mach File System) code what 'network' drives to redirect. With this you can 'mount' any Linux directory as a virtual drive into DOS. In addition to this, Linux as well as multiple dosemu sessions may simultaneously access the same drives, what you can't when using partition access.
Mount your dos hard disk partition as a Linux subdirectory. For example, you could create a directory in Linux such as /dos (mkdir -m 755 /dos) and add a line like
/dev/hda1 /dos msdos umask=022 |
to your /etc/fstab. (In this example, the hard disk is mounted read- only. You may want to mount it read/write by replacing "022" with "000" and using the -m 777 option with mkdir). Now mount /dos. Now you can add a line like
lredir d: linux\fs/dos |
to the AUTOEXEC.BAT file in your hdimage (but see the comments below). On a multi-user system you may want to use
lredir d: linux\fs\${home} |
where "home" is the name of an environmental variable that contains the location of the dos directory (/dos in this example)
You may even redirect to a NFS mounted volume on a remote machine with a /etc/fstab entry like this
otherhost: /dos nfs nolock |
In addition, you may want to have your native DOS partion as C: under dosemu. To reach this aim you also can use Lredir to turn off the 'virtual' hdimage and switch on the real drive C: such as this:
Assuming you have a c:\dosemu directory on both drives (the virtual and the real one) and have mounted your DOS partition as /dosc, you then should have the following files on the virtual drive:
autoexec.bat:
lredir z: linux\fs\dosc copy c:\dosemu\auto2.bat z:\dosemu\auto2.bat lredir del z: c:\dosemu\auto2.bat |
dosemu\auto2.bat:
lredir c: linux\fs\dosc rem further autoexec stuff |
To make the reason clear why the batch file (not necessaryly autoexec.bat) must be identical:
Command.com, which interpretes the batchfile keeps a position pointer (byte offset) to find the next line within this file. It opens/closes the batchfile for every new batchline it reads from it. If the batchfile in which the 'lredir c: ...' happens is on c:, then command.com suddenly reads the next line from the batchfile of that newly 'redired' drive. ... you see what is meant?
To have a redirected drive available at time of config.sys you may either use emufs.sys such as
device=c:\emufs.sys /dosc |
or make use of the install instruction of config.sys (but not both) such as
install=c:\lredir.exe c: linux\fs\dosc |
The later has the advantage, that you are on your native C: from the beginning, but, as with autoexec.bat, both config.sys must be identical.
For information on using 'lredired' drives as a 'user' (ie having the right permissions), please look at the section on Running dosemu as a normal user.
This section of the document by Hans, <lermen@fgan.de>. Last updated on Jan 21, 2003.
In the default setup, DOSEMU does not have root privileges. This means it will not have direct access to ports, external DOSish hardware and won't use the console other than in normal terminal mode, but is fully capable to do anything else. See the previous section on how to enable privileged operation if you really need to.
If a user needs access to privileged resources other than console graphics, then you may need to explicitly allow the user to do so by editing the file /etc/dosemu.users (or /etc/dosemu/dosemu.users). The format is:
loginname [ c_strict ] [ classes ...] [ other ] |
For example, to allow joeuser full access you can use
joeuser c_all |
The msdos partitions, that you want to be accessable through Section 5 should be mounted with proper permissions. I recommend doing this via 'group's, not via user ownership. Given you have a group 'dosemu' for this and want to give the user 'lermen' access, then the following should be
in /etc/passwd:
lermen:x:500:100:Hans Lermen:/home/lermen:/bin/bash ^^^-- note: this is NOT the group id of 'dosemu' |
in /etc/group:
users:x:100: dosemu:x:200:dosemu,lermen ^^^ |
in /etc/fstab:
/dev/hda1 /dosc msdos defaults,gid=200,umask=002 0 0 ^^^ |
Note: the changes to /etc/passwd and /etc/group only take place the next time you login, so don't forget to re-login.
The fstab entry will mount /dosc such that is has the proper permissions
( drwxrwxr-x 22 root dosemu 16384 Jan 1 1970 /dosc ) |
You can do the same with an explicit mount command:
mount -t msdos -o gid=200,umask=002 /dev/hda1 /dosc |
Of course normal lredir'ed unix directories should have the same permissions.
Make sure you have read/write permissions of the devices you configured (in /etc/dosemu.conf) for serial and mouse.
Starting with dosemu-0.66.1.4 there should be no reason against running dosemu as a normal user. The privilege stuff has been extensively reworked, and there was no program that I tested under root, that didn't also run as user. Normally dosemu will permanently run as user and only temporarily use root privilege when needed (during initialization) and then drop its root privileges permanently. In case of non-suid root (as of dosemu-0.97.10), it will run in lowfeature mode without any privileges.
This documents the cdrom extension rucker@astro.uni-bonn.de has written for Dosemu.
An easy way to access files on a CDROM is to mount it in Linux and use Lredir to refer to it. However, any low-level access, often used by games is impossible that way, unless you use the C option. For that you need to load some drivers in DOS. CDROM image files (ISOs) can be used in a similar fashion.
The driver consists of a server on the Linux side (src/dosext/drivers/cdrom.c, accessed via int 0xe6 handle 0x40) and a device driver (src/commands/cdrom.S) on the DOS side.
Please send any suggestions and bug reports to <rucker@astro.uni-bonn.de>
To install it:
Create a (symbolic) link /dev/cdrom to the device file of your drive or use the cdrom statement in dosemu.conf to define it.
Make sure that you have read/write access to the device file of your drive, otherwise you won't be able to use the cdrom under Dosemu directly because of security reasons.
Load cdrom.sys within your config.sys file with e.g.:
devicehigh=d:\dosemu\cdrom.sys |
Mount the CD-ROM in Linux (some distributions do this automatically), and use
lredir e: linux\fs/media/cdrom c |
to access the CD-ROM as drive E:. The "C" option specifies that the low-level access provided via cdrom.sys is used. Or ... start Microsoft cdrom extension as follows:
mscdex /d:mscd0001 /l:driveletter |
shsucdex /d:mscd0001 /l:driveletter |
To change the cd while Dosemu is running, use the DOS program 'eject.com'. If is not possible to change the disk, when the drive has been opened by another process (e.g. mounted), then you need to unmount it first!
Lredir has the advantage of supporting long file names, and not using any DOS memory, whereas MS/SHSUCDX are more low-level and perhaps more compatible. You would need to use a DOS TSR driver such as DOSLFN to use long file names with SHSUCDX.
Remarks by zimmerma@rz.fht-esslingen.de:
This driver has been successfully tested with Linux' SCSI CDROMS by the author, with the Mitsumi driver mcd.c and with the Aztech/Orchid/Okano/Wearnes- CDROM driver aztcd.c by me. With the latter CDROM-drives changing the CD-ROM is not recognized correctly by the drive under all circumstances and is therefore disabled. So eject.com will not work. For other CD-ROM drives you may enable this feature by setting the variable 'eject_allowed = 1' in file dosemu/drivers/cdrom.c (you'll find it near the top of the file). With the mcd.c and aztcd.c Linux drivers this may cause your system to hang for some 30 seconds (or even indefinitely), so don't change the default value 'eject_allowed = 0'.
Support for up to 4 drives:
If you have more then one cdrom, you can use the cdrom statement in dosemu.conf like this:
$_cdrom = "/dev/cdrom /dev/cdrom2 image.iso" |
device=cdrom.sys device=cdrom.sys 2 device=cdrom.sys 3 |
The one and only parameter to the device driver is a digit between 1 and 4, (if its missing then 1 is assumed) for the DOS devices MSCD0001, MSCD0002 ... MSCD0004 respectively. You then also need to use lredir or tell MSCDEX about these drivers such as
lredir e: linux\fs/media/cdrom c lredir f: linux\fs/media/cdrom2 c 2 lredir g: linux\fs/media/cdrom3 c 3 |
mscdex /d:mscd0001 /d:mscd0002 /l:driveletter |
History:
Release with dosemu.0.60.0 Karsten Rucker (rucker@astro.uni-bonn.de) April 1995
Additional remarks for mcd.c and aztcd.c Werner Zimmermann (zimmerma@rz.fht-esslingen.de) May 30, 1995
Release with dosemu-0.99.5 Manuel Villegas Marin (manolo@espanet.com) Support for up to 4 drives December 4, 1998
This chapter provides some hints and tips for using DOSEMU in X.
If you start dosemu in X it brings up its own window, in which you can also execute graphical programs such as games. To force text-only execution of DOSEMU in an xterm or other terminal (konsole, gnome-terminal, and so on), you need to run dosemu -t.
Use dosemu -w to start DOSEMU in fullscreen mode. When running DOSEMU, you can flip between fullscreen and windowed mode by pressing <Ctrl><Alt><F>. The graphics window is resizeable.
Some DOS applications want precise mouse control that is only possible if the mouse cursor is trapped in the DOSEMU window. To enable this you need to grab the mouse by pressing <Ctrl><Alt><Home>. Similarly, you can grab the keyboard by pressing <Ctrl><Alt><K>, or <Ctrl><Alt><Shift><K> if your window manager already grabs <Ctrl><Alt><K>. After you grab the keyboard all key combinations (including <Alt><Tab> and so on) are passed to DOSEMU. In fullscreen mode the mouse and keyboard are both automatically grabbed.
Use <Ctrl><Alt><Pause> to pause and unpause the DOSEMU session, which is useful if you want it to sit silently in the background when it is eating too much CPU time. Press <Ctrl><Alt><PgDn> or click the close button of the window to exit DOSEMU.
DOSEMU uses bitmapped internal fonts by default, so it can accurately simulate a real VGA card text mode. It is also possible to use X fonts. The advantages of these is that they may be easier on the eyes, and are faster, in particular if you use DOSEMU remotely. Any native DOS font setting utilities do not work, however. To set an X font use the provided xmode.com utility, using
xmode -font vga |
$_X_font = "vga" |
If the mouse is not grabbed, then you can copy and paste text if the DOSEMU window is in text mode. This uses the standard X mechanism: select by dragging the left mouse button, and paste by pressing the middle mouse button.
What you might take care of:
If backspace and delete do not work, you can try 'xmodmap -e "keycode 22 = 0xff08"' to get use of your backspace key, and
'xmodmap -e "keycode 107 = 0xffff"' to get use of your delete key.
Make sure DOSEMU has X support compiled in. The configure script complains loudly if it does not find X development libraries.
There are some X-related configuration options for dosemu.conf. See the file itself for details.
Keyboard support of course depends on your X keyboard mappings (xmodmap). If certain keys don't work (like Pause, Backspace,...), it *might* be because you haven't defined them in your xmodmap, or defined to something other than DOSEMU expects.
using the provided icon (dosemu.xpm):
you need the xpm (pixmaps) package. If you're not sure, look for a file like /usr/X11R6/lib/libXpm.so.*
you also need a window manager which supports pixmaps. Fvwm is fine, but I can't tell you about others. Twm probaby won't do.
copy dosemu.xpm to where you usually keep your pixmap (not bitmap!) files (perhaps /usr/share/pixmaps)
tell your window manager to use it. For fvwm, add the following line to your fvwmrc file:
Icon "xdosemu" dosemu.xpm |
This assumes you have defined a PixmapPath. Otherwise, specify the entire pathname.
note that if you set a different icon name than "xdosemu" in your dosemu.conf, you will also have to change the fvwmrc entry.
restart the window manager. There's usually an option in the root menu to do so.
Now you should see the icon whenever you iconify xdosemu.
Note that the xdosemu program itself does not include the icon - that's why you have to tell the window manager. I chose to do it this way to avoid xdosemu requiring the Xpm library.
If anything else does not work as expected, don't panic :-) Remember the thing is still under construction. However, if you think it's a real bug, please tell me.
In X, a VGA card is emulated. The same happens if you use the SDL library using dosemu -S. This emulation (vgaemu) enables X to run graphics modes.
Some features:
Video memory. 1 Mb is allocated. It is mapped with mmap() in the VGA memory region of DOSEMU (0xa00000-0xbfffff) to support bank switching. This is very i386-Linux specific, don't be surprised if it doesn't work under NetBSD or another Linux flavour (Alpha/Sparc/MIPS/etc).
The DAC (Digital to Analog Converter). The DAC is completely emulated, except for the pelmask. This is not difficult to implement, but it is terribly slow because a change in the pelmask requires a complete redraw of the screen. Fortunately, the pelmask changes aren't used often so nobody will notice ;-)
The attribute controller is emulated.
The emulator emulates a basic Trident TVGA8900C graphics card. All standard VGA modes are emulated, most VGA hardware features (mode-X, 320x240 and so on), some Trident extensions, and on top of that many high-resolution VESA 2.0 modes, that were not present in the original Trident card. Some (very few) programs, such as Fast Tracker, play intimately with the VGA hardware and may not work. As vgaemu improves these problems should disappear.
Nearly full VESA 2.0 support.
A VESA compatible video BIOS is mapped at 0xc00000. It is small because it only contains some glue code and the BIOS fonts (8x8, 8x14, 8x16).
support for hi- and true-color modes (using Trident SVGA mode numbers and bank switching)
Support for mode-X type graphics modes (non-chain4 modes as used by e.g. DOOM)
gamma correction for graphics modes
video memory size is configurable via dosemu.conf
initial graphics window size is configurable
The current hi- (16bpp) and true (24/32bpp) color support does not allow resizing of the graphics window and gamma correction is ignored.
As the typical graphics mode with 320x200x8 will be used often with large scalings and modern graphics boards are pretty fast, Steffen Winterfeldt added something to eat up your CPU time: you can turn on the bilinear interpolation. It greatly improves the display quality (but is rather slow as I haven't had time yet to implement an optimized version - it's plain C for now). If the bilinear filter is too slow, you might instead try the linear filter which interpolates only horizontally.
Note that (bi)linear filtering is not available on all VGA/X display combinations. The standard drawing routines are used instead in such cases.
If a VGA mode is not supported on your current X display, the graphics screen will just remain black. Note that this does not mean that DOSEMU has crashed.
The only unsupported VBE function is VGA state save/restore. But this functionality is rarely used and its lack should not cause too much problems.
VBE allows you to use the horizontal and vertical scrolling function even in text modes. This feature is not implemented.
If you think it causes problems, the linear frame buffer (LFB) can be turned of via dosemu.conf as well as the protected mode interface. Note, however, that LFB modes are faster than banked modes, even in DOSEMU.
The default VBE mode list defines a lot of medium resolution modes suitable for games (like Duke3D). You can still create your own modes via dosemu.conf. Note that you cannot define the same mode twice; the second (and all subsequent) definitions will be ignored.
Modes that are defined but cannot be supported due to lack of video memory or because they cannot be displayed on your X display, are marked as unsupported in the VBE mode list (but are still in it).
The current interface between VGAEmu and X will try to update all invalid video pages at a time. This may, particularly in hi-res VBE/SVGA modes, considerably disturb DOSEMU's signal handling. That cannot be helped for the moment, but will be addressed soon (by running an extra update thread).
If you really think that this is the cause of your problem, you might try to play with veut.max_max_len in env/video/render.c. This variable limits the amount of video memory that is updated during one timer interrupt. This way you can dramatically reduce the load of screen updates, but at the same rate reduce your display quality.
Gamma correction works in both 4 and 8 bit modes. It must be specified as a float value, e.g. $_X_gamma=(1.0). Higher values give brighter graphics, lower make them darker. Reasonable values are within a range of 0.5 ... 2.0.
You can specify the video memory size that the VGA emulator should use in dosemu.conf. The value will be rounded up to the nearest 256 kbyte boundary. You should stick to typical values like 1024, 2048 or 4096 as not to confuse DOS applications. Note that whatever value you give, 4 bit modes are only supported up to a size of 800x600.
You can influence the initial size of the graphics window in various ways. Normally it will have the same size (in pixel) as the VGA graphics mode, except for mode 0x13 (320x200, 256 colors), which will be scaled by the value of mode13fact (defaults to 2). Alternatively, you can directly specify a window size in dosemu.conf via $_X_winsize. You can still resize the window later.
The config option $_X_fixed_aspect allows you to fix the aspect ratio of the graphics window while resizing it. Alternatively, $_X_aspect_43 ties the aspect ratio to a value of 4:3. The idea behind this is that, whatever the actual resolution of a graphics mode is in DOS, it is displayed on a 4:3 monitor. This way you won't run into problems with modes such as 640x200 (or even 320x200) which would look somewhat distorted otherwise.
For planar modes (for instance, most 16 colour modes, but also certain 256-colour modes: mode-X), vgaemu has to switch to partial cpu emulation. This can be slow, but expect it to improve over time.
DOSEMU can run any 16bit Windows up to 3.1, and has limited support for Windows 3.11. You should be able to install and run these versions of Windows without any extra work. There are still a few caveats however, and if you have some problems, read on.
In Windows, the mouse cursor is not always in sync with the native X mouse cursor. This problem can be easily avoided by enabling mouse grab. There also exist an alternative mouse driver specially written to work in ungrabbed mode: https://github.com/stsp/win31-mouse-driver/tree/master/out. This driver is not limited to use with dosemu2: it can be used with any other emulator and under bare-metal machine.
If you want to run Windows in SVGA mode, you can either use the Trident drivers, or the patched SVGA drivers of Windows 3.11.
The Trident drivers for Windows are in the files tvgaw31a.zip and/or tvgaw31b.zip. Search www.winsite.com to get them. Unpack the archive. In Windows setup, install the Trident "800x600 256 color for 512K boards" driver.
Windows 3.11 comes with SVGA drivers. You can also download them: search www.winsite.com for svga.exe and install the drivers. Then go to http://www.japheth.de/dwnload1.html and get the SVGAPatch tool. This tool causes the above drivers to work with most of the video cards in a real DOS environment, and makes them DOSEMU-compatible too.
By the time of writing this, DOSEMU does not have support for Windows ring-0 device drivers (.vxd, .386). Fortunately, most of Windows 3.1 drivers are ring-3 ones (.drv), so you can easily install the Sound Blaster drivers, for instance. This is not the case with Windows 3.11. Its network drivers are ring-0 ones, so the native Winsock does not work. In order to get networking operational, you need to get the Trumpet Winsock package. Refer to chapter "Using Windows and Winsock" for more info on this.
There is probably little use of a DOS shell under Windows under DOSEMU... But for those who need it, here are some basic hints. The DOS shell is supported by DOSEMU only if Windows is running in Standard mode. The Enhanced mode DOS shell is currently unsupported. Note however, that unlike in a real DOS environment, under DOSEMU the DOS shell of the Windows in Standard mode allows you to run protected mode applications (in the real DOS environment only the DOS shell of the Enhanced mode allows this).
This section written by Eric Biederman <eric@dosemu.org>
For most dos applications you should be able to use the internal mouse with very little setup, and very little trouble.
Under X, or in terminal mode, you don't need to do anything, unless you want to use the middle button then you need to add to autoexec.bat:
emumouse 3 |
in dosemu.conf:
$_mouse = "mousesystems" $_mouse_dev = "/dev/gpmdata" |
emumouse 3 |
GPM setting DOSEMU setting ------------------------------- msc (default) mousesystems ms3 microsoft raw select type of your real mouse |
In X there are 2 ways applications can get into trouble.
The most common way is if they don't trust the mouse driver to keep track of where the mouse is on the screen, and insist on doing it themselves. win31 & geoworks are too applications in this category. They read mouse movement from the mouse driver in turns of mickeys i.e. they read the raw movement data.
To support this mouse driver then tracks where you were and where you move to, in terms of x,y screen coordinates. Then works the standard formulas backwards that calculate screen coordinates from mickeys to generate mickeys from screen coordinates. And it feeds these mickeys to the application. As long as the application and dosemu agree on the same formulas for converting mickeys to screen coordinates all is good.
The only real problem with this is sometimes X mouse and the application mouse get out of sync. Especially if you take your mouse cursor out of the dosemu window, and bring it back in again.
To compensate for getting out of sync what we do is whenever we reenter the Xdos window is send a massive stream of mickeys heading for the upper left corner of the screen. This should be enough to kick us any an good mouse drivers screen limits. Then once we know where we are we simulate movement for 0,0.
In practice this isn't quite perfect but it does work reasonably well.
The tricky part then is to get the application and dosemu to agree on the algorithm. The algorithm we aim at is one mickey one pixel. Dosemu does this by default under X but you can force it with.
emumouse x 8 y 8 a |
for win31 you need
MouseThreshold1=0 MouseThreshold2=0 MouseSpeed=0 |
The fool proof solution is to take total control of the mouse in X. This is controlled by the $_X_mgrab_key in /etc/dosemu.conf $_X_mgrab_key contains an X keysym of a key that when pressed with both Ctrl & Alt held down will turn on the mouse grab, which restricts the X mouse to the dosemu window, and gives dosemu complete control over it. Ctrl-Alt-$_X_mgrab_key will then release the mouse grab returning things to normal.
I like: $_X_mgrab_key="Scroll_Lock" (Ctrl-Alt-Scroll_Lock) but $_X_mgrab_key="a" is a good conservative choice. (Ctrl-Alt-A) You can use xev to see what keysyms a key generates.
Currently the way the X mouse code and the mouse grab are structured the internal mouse driver cannot display the mouse when the mouse grab is active. In particular without the grab active to display the mouse cursor we just let X draw the mouse for us, (as normal). When the mouse grab is active we restrict the mouse to our current window, and continually reset it to the center of the current screeen (allowing us to get relative amounts of movement). A side effect of this is that the the position of the X cursor and the dos cursor _not_ the same. So we need a different strategy to display the dos cursor.
The other way an application can get into trouble in X, and also on the console for that matter is if it is partially broken. In particular the mouse driver is allowed to return coordinates that have little to no connection with the actual screen resolution. So an application mouse ask the mouse driver it's maximums and then scale the coordinates it gets into screen positions. The broken applications don't ask what the maximum & minimum resolutions are and just assume that they know what is going on.
To keep this problem from being too severe in mouse.c we have attempted to match the default resolutions used by other mouse drivers. However since this is up to the choice of an individual mouse driver there is doubtless code out there developed with different resolutions in mind.
If you get stuck with such a broken application we have developed a work around, that is partially effective. The idea being that if the application draws it's own mouse pointer it really doesn't matter where the dos mouse driver thinks the mouse is things should work. So with emumouse it is possible to set a minimum resolution to return to an application. By setting this minimum resolution to as big or bigger than the application expect to see it should work. The side effect of setting a minimum resolution bigger than the application expects to see in X is that there will be some edges to the of the screen where the application draws the cursor at the edge of the window, and yet you need to continue scrolling a ways before the cursor comes out there. In general this will affect the right and bottom edges of the screen.
To read the current minimum use:
emumouse i |
To set the minimum resolution use:
emumouse Mx 640 My 200 |
This part of the document was written by Hans <lermen@fgan.de>.
This chapter deals with starting DOS commands directly from Linux. You can use this information to set up icons or menu items in X. Using the keystroke, input and output redirection facilities you can use DOS commands in shell scripts, cron jobs, web services, and so on.
The default autoexec.bat file has a statement unix -e at the end. This command executes the DOS program or command that was specified on the dosemu command line.
For example:
dosemu "/home/clarence/games/commander keen/keen1.exe" |
Lredir "/" if the specified program is not available from an already-redirected drive,
"cd" to the correct directory,
execute the program automagically,
and quit DOSEMU when finished, all without any typing in DOS.
You can also specify a DOS command, such as "dir". A combination with the -dumb command-line option is useful if you want to retrieve the output of the DOS command, such as
dosemu -dumb dir > listing |
Make use of the -input command-line option, such as
dosemu -input 'dir > C:\\garbage\rexitemu\r' |
\r Carriage return == <ENTER> \n LF \t tab \b backspace \f formfeed \a bell \v vertical tab \^x <Ctrl>x, where X is one of the usual C,M,L,[ ... (e.g.: \^[ == <Ctrl>[ == ESC ) \Ax <Alt>x, hence \Ad means <Alt>d \Fn; Function key Fn. Note that the trailing ';' is needed. (e.g.: \F10; == F10 ) \Pn; Set the virtual typematic rate, thats the speed for autotyping in. It is given in unix timer ticks to wait between two strokes. A value of 7 for example leads to a rate of 100/7=14 cps. \pn; Before typing the next stroke wait n unix ticks. This is useful, when the DOS-application flushes the keyboard buffer on startup. Your strokes would be discarded, if you don't wait. |
Make a file "FILE" containing all keystrokes you need to boot DOSEMU and to start your dos-application, ... and don't forget to have CR (literal ^M) for 'ENTER'. FILE may look like this (as on my machine):
2^Mdir > C:\garbage^Mexitemu^M |
and execute DOSEMU like this:
dosemu -dumb < FILE |
In bash you can also use
echo -e 'dir \gt; c:\\garbage\rexitemu\r' | dosemu -dumb |
echo -e 'dir\rexitemu\r' | dosemu -dumb > FILE.out |
FILE.out then contains the output from the DOS application, but (unlike the unix -e technique, merged with all startup messages.
You may elaborate this technique by writing a script, which gets the dos-command to execute from the commandline and generate 'FILE' for you.
When you try to use one of the above to start DOSEMU out of a crontab, then you have to asure, that the process has a proper environment set up ( especially the TERM and/or TERMCAP variable ).
Normally cron would setup TERM=dumb, this is fine because DOSEMU recognizes it and internally sets it's own TERMCAP entry and TERM to `dosemu-none'. You may also configure your video to
dosemu ... -dumb |
These are some utitlies to assist you in using Dosemu.
change the Unix directory for Dosemu (use chdir(2))
change the debug setting from within Dosemu
dosdbg -- show current state
dosdbg <string>
dosdbg help -- show usage information
eject CD-ROM from drive
fine tune internal mousedriver of Dosemu
emumouse h -- display help screen
terminate Dosemu
get the Unix directory for Dosemu (use getcwd(2))
detects Dosemu version and returns greater 0 if running under Dosemu
???
redirect Linux directory to Dosemu
lredir -- show current redirections
lredir D: LINUX\FS\tmp -- redirects /tmp to drive D:
lredir help -- display help screen
set cpu usage (HogThreshold) from inside Dosemu
interface to system(2)...
execute Unix commands from Dosemu
unix -- display help screen
unix ls -al -- list current Linux directory
caution! try "unix" and read the help screen
Read /proc/self/cmdline and put strings such as "var=xxx" found on the commandline into the DOS enviroment. Example having this as the dosemu commandine:
dosemu.bin "autoexec=echo This is a test..." |
C:\cmdline < D:\proc\self\cmdline %autoexec% |
disable vga option
enable vga option
set special X parameter when running as xdos
These are useful drivers for Dosemu
allow direct access to CD-ROM drives from Dosemu
enable EMM in Dosemu
redirect Unix directory to Dosemu
ASPI conform SCSI driver
FOSSIL serial driver (TSR)
This keymap is for using dosemu over telnet, and having *all* your keys work. This keymap is not complete. But hopefully with everyones help it will be someday :)
There are a couple of things that are intentionally broken with this keymap, most noteably F11 and F12. This is because they are not working though slang correctly at the current instant. I have them mapped to "greyplus" and "greyminus". Also the scroll lock is mapped to shift-f3. This is because the scroll lock dosn't work right at all. Please feel free to send keymap patches in that fix anything but these.
If you want to patch dosemu to fix either of those problems, i'd be glad to accept those :)
to figure out how to edit this, read the keystroke-howto.
as of 3/30/95, control/shift/alternate home/insert/delete/end/pageup/pagedown should work.
Major issues will be:
Do we move "alt-<fkey>" to "control-<fkey>" to switch virtual consoles?
who is going to fix the linux keyboard device to be able to handle multiple keymaps at the same time?
--------------------------------------------------------
to use it:
as root type
loadkeys dosemu.new.keymap |
(then run dosemu via telnet, or something in slang mode)
when your done, find your old keymap, and load it back, cause control-home won't work in emacs anymore (or any other special key in any applicaion that uses xlate)
if you find a key missing, please add it and send me the patch. (test it first! :)
if you find a key missing, and don't feel like coding it, don't tell me! I already know that there are a lot of keys missing.
corey sweeney <corey@interaccess.com >
Sytron Computers
The easiest (and not recommended) way to set up the networking in DOSEMU is to use the direct NIC access. It means that DOSEMU will exclusively use one of your network interfaces, say eth1. No other processes will be able to use that interface. If they try to, the data exchange will became unreliable. So you have to make sure that this network interface is not used by anything including the kernel itself, before starting DOSEMU. The settings for this method are as follows:
$_pktdriver = (on) $_ethdev = "eth1" $_vnet = "eth" |
As you can see, this simple method has many shortcomings. If you don't have the network card dedicated specially for dosemu, consider using more advanced method called "Virtual Networking".
Virtual networking is a mechanism that allows to overcome all the limitations of the direct NIC access method, but it requires more work to set up everything properly. A special virtual network devices can be created using TUN/TAP interface. This will enable multiple dosemu sessions and the linux kernel to be on a separate virtual network. Each dosemu will have its own network device and ethernet address.
First make sure that your Linux kernel comes with support for TUN/TAP; for details check Documentation/networking/tuntap.txt in the Linux kernel source. The user who runs DOSEMU should have read/write access to /dev/net/tun. Then either:
Set
$_pktdriver=(on) $_vnet = "tap" $_tapdev = "" |
Start DOSEMU as usual and configure the network device while DOSEMU is running (using ifconfig manually as root, a script, or usernetctl if your distribution supplies that), e.g.
ifconfig dosemu_tap0 up 192.168.74.1 |
Configure the DOS TCP/IP network clients to have another IP address in the subnet you just configured. This address should be unique, i.e. no other dosemu, or the kernel, should have this address. For the example addresses given above, 192.168.74.2-192.168.74.254 would be good. Your network should now be up and running and you can, for example, use a DOS SSH client to ssh to your own machine, but it will be down as soon as you exit DOSEMU.
Or set
$_pktdriver=(on) $_vnet = "tap" $_tapdev = "tap0" |
Obtain tunctl from the user mode linux project. Then set up a persistent TAP device using tunctl (use the -u owner option if you do that as root). Configure the network using ifconfig as above, but now before starting DOSEMU. Now start DOSEMU as often as you like and you can use the network in the same way as you did above.
Note, however, that multiple DOSEMU sessions that run at the same time need to use multiple tapxx devices. $_tapdev can be changed without editing dosemu.conf or ~/.dosemu/.dosemurc (if you leave it commented out there) by using dosemu -I "netdev tap1".
With the above you did set up a purely virtual internal network between the DOSEMU and the real Linux box. This is why in the above example 192.168.74.1 should *not* be a real IP address of the Linux box, and the 192.168.74 network should not exist as a real network. To enable DOS programs to talk to the outside world you have to set up Ethernet bridging or IP routing.
Bridging, using brctl (look for the bridge-utils package if you don't have it), is somewhat easier to accomplish than the IP routing. You set up a bridge, for example named "br0" and connect eth0 and tap0 to it. Suppose the Linux box has IP 192.168.1.10 on eth0, where 192.168.1.x can be a real LAN, and the uid of the user who is going to use DOSEMU is 500, then you can do (as root):
brctl addbr br0 ifconfig eth0 0.0.0.0 promisc up brctl addif br0 eth0 ifconfig br0 192.168.1.10 netmask 255.255.255.0 up tunctl -u 500 ifconfig tap0 0.0.0.0 promisc up brctl addif br0 tap0 |
If you like to use IP routing, note that unlike with bridging, each DOSEMU box will reside in a separate IP subnet, which consists only of 2 nodes: DOSEMU itself and the corresponding TAP device on Linux side. You have to choose an IP address for that subnet. If your LAN has the address 192.168.1.0 and the netmask is 255.255.255.0, the dosemu subnet can have the address 192.168.74.0 and tap0 can have the address 192.168.74.1:
ifconfig tap0 192.168.74.1 netmask 255.255.255.0 up |
route add -net 192.168.74.0 netmask 255.255.255.0 dev tap0 |
Destination Gateway Genmask Flags Metric Ref Use Iface 192.168.74.0 * 255.255.255.0 U 0 0 0 tap0 |
route add -net 192.168.74.0 netmask 255.255.255.0 gw 192.168.1.10 |
echo 1 > /proc/sys/net/ipv4/ip_forward |
iptables -t filter -I FORWARD 1 -i tap0 -j ACCEPT |
Yet one more thing have to be done if you want dosemu to be able to access Internet. Unlike in your LAN, you are not supposed to change the routing tables on an every Internet host, so how to make them to direct the IP packets back to dosemu's virtual network? To accomplish this, you only have to enable the IP Masquerading on the network interface that looks into Internet. If your machine serves as a gateway in a LAN, then the masquerading is most likely already enabled, and no further work is required. Otherwise you must run the following command (assuming the eth0 interface serves the Internet connection):
iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE |
If you just need to have a working internet access from within your DOSEMU environment, then you might want to consider using VDE networking. slirpvde is a user mode networking utility providing a NAT-like service, DHCP server, as well as a virtualized network in the 10.0.2.0/24 range, with a default gateway and a DNS server. Note that dosemu uses VDE backend as a fallback when other methods are unavailable. It also tries to start all the vde utilities, so no configuration efforts are usually needed.
Use the following command to get VDE sources:
svn checkout svn://svn.code.sf.net/p/vde/svn/trunk vde-svn |
VDE-specific config options:
$_pktdriver=(on) $_vnet = "vde" $_vdeswitch = "/tmp/switch1 $_slirpargs = "--dhcp" |
Your wattcp.cfg file will look as simple as this:
my_ip=dhcp |
This is the Windows Net Howto by Frisoni Gloriano <gfrisoni@hi-net.it> on 15 may 1997
This document tries to describe how to run the Windows trumpet winsock over the dosemu built-in packet driver, and then run all TCP/IP winsock-based application (netscape, eudora, mirc, free agent .....) in windows environment.
This is a very long step-by-step list of operation, but you can make little scripts to do all very quickly ;-)
In this example, I use the dosnet based packet driver. It is very powerful because you can run a "Virtual net" between your dos-windows session and the linux, and run tcp/application application without a real (hardware) net.
The WINPKT.COM virtual packet driver, version 11.2 I have found this little tsr in the Crynwr packet driver distribution file PKTD11.ZIP
The Trumpet Winsock 2.0 revision B winsock driver for windows.
Enable "dosnet" based dosemu packet driver:
cd ./src/dosext/net/net select_packet (Ask single or multi -> m) |
Make the dosnet linux module:
cd ./src/dosext/net/v-net make |
Make the new dosemu, with right packet driver support built-in:
make make install |
Now you must load the dosnet module:
insmod ./src/dosext/net/v-net/dosnet.o |
Some linux-side network setup (activate device, routing). This stuff depends from your environment, so I write an example setup.
Here you configure a network interface dsn0 (the dosnet interface) with the ip address 144.16.112.1 and add a route to this interface.
This is a good example to make a "virtul network" from your dos/windows environment and the linux environment.
ifconfig dsn0 144.16.112.1 broadcast 144.16.112.255 netmask 255.255.255.0 route add -net 144.16.112.0 dsn0 |
I suppose you know how to run windows in dosemu. You can read the Section 9 document if you need more information. Windows is not very stable, but works.
start dosemu.
copy the winpkt.com driver and the trumpet winsock driver in some dos directory.
start the winpkt TSR. (dosemu assign the 0x60 interrupt vector to the built-in packet driver)
winpkt 0x60 |
edit the trumpet winsock setup file trumpwsk.ini. Here is an example of how to setup this file: (I think you can use less parameters, if you have the time to play with this file. You can also setup this stuff from the winsock setup dialog-box).
[Trumpet Winsock] netmask=255.255.255.0 <-- class C netmask. gateway=144.16.112.1 <-- address in the default gateway. dns=www.xxx.yyy.zzz <-- You must use right value for the dns. domain=hi-net.it ip=144.16.112.10 <-- Windows address in the dosnet. vector=60 <-- packet driver interrupt vector. mtu=1500 rwin=4096 mss=1460 rtomax=60 ip-buffers=32 slip-enabled=0 <--- disable slip slip-port=2 slip-baudrate=57600 slip-handshake=1 slip-compressed=0 dial-option=1 online-check=0 inactivity-timeout=5 slip-timeout=0 slip-redial=0 dial-parity=0 font=Courier,9 registration-name="" registration-password="" use-socks=0 socks-host=0.0.0.0 socks-port=1080 socks-id= socks-local1=0.0.0.0 0.0.0.0 socks-local2=0.0.0.0 0.0.0.0 socks-local3=0.0.0.0 0.0.0.0 socks-local4=0.0.0.0 0.0.0.0 ppp-enabled=0 <-------- disable ppp ppp-usepap=0 ppp-username="" ppp-password="" win-posn=42 220 867 686 -1 -1 -4 -4 1 trace-options=16392 [default vars] |
Now you can run windows, startup trumpet winsock and ..... enjoy with your windoze tcp/ip :-)
Gloriano Frisoni. <gfrisoni@hi-net.it>