Usage
The directives in this file configure DOS for use with devices and applications in the system. The CONFIG.SYS directives also set up the memory managers in the system. After processing the CONFIG.SYS file, DOS proceeds to load and execute the command shell specified in the SHELL line of CONFIG.SYS, or COMMAND.COM if there is no such line. The command shell in turn is responsible for processing theSYS /DR:ext
command can be used to change the default file extensions. For example, with SYS /L /DR:703
the written Volume Boot Record would look for a renamed and modified IBMBIO.703 system file (instead of the default .BAT
" as well (both features are also supported by SYS /A
parameter in order to copy the corresponding CONFIG.SYS and AUTOEXEC.BAT files along with the system files.
FreeDOS implements a similar feature with its FDCONFIG.SYS configuration file. RxDOS 7.24 and higher use RXCONFIG.SYS instead. PTS-DOS uses CONFIG.PTS.
Both CONFIG.SYS and AUTOEXEC.BAT can be found included in the root folder of Windows 95, and Windows 98 boot drives, as they are based on DOS. Typically, these files are left empty, with no content.
Windows ME does not even parse the CONFIG.SYS file during the Windows boot process, loading environment variables from the Windows Registry instead:
:
: HKLM\System\CurrentControlSet\Control\SessionManager\Environment
Under FlexOS, CONFIG.SYS is a binary file defining the resource managers and device drivers loaded.
Directives
:;*?!
; : Defines labels in CONFIG.SYS as jump targets for , , , and directives. ; : Similar to , but can be used also for in-line comments (following other CONFIG.SYS directives). See . (Under MS-DOS/PC DOS the inline-comment is not ignored if put in double-quotes.) ; : Used to lead in in-line comments in addition to the ; directive. ; : Displays a Yes/No query and (since DR DOS 5.0) optional message to ask the user for confirmation to execute the following CONFIG.SYS directives. (FreeDOS does not support optional messages, but optional conditions in conjunction with boot menus defined with and .) (DOS 6.0 and higher supports a similar feature by adding a after the corresponding CONFIG.SYS directive, f.e. or instead of . This variant is also supported by DR DOS.) ; : Unconditionally execute the following CONFIG.SYS directive.AC
; : Specifies if programs can be aborted on errors. ; : Configures which drives should store file access date stamps in the reserved area of directory entries in FAT file systems. ; : Conditional execution on AT-compatible machines only. ; : Boot manager. ; : Configures verbosity of error messages. ; : Changes internal default serial device driver ( to ) for device. ; : Disables the availability of character devices outside phantom \DEV directory. ; : Loads base device driver into memory. ; : Emits a short beep, even if audible notifications are disabled via . ; : Specifies operating system to be booted. ; : Sets or clears extended checking. ; : Specifies the number of disk buffers to allocate. ; : Same as , but explicitly loads buffers into HMA or UMB (like under DR DOS 6.0 and higher). ; : Maximum number of 512-byte cache blocks dynamically allocated from system pool. ; : Maximum time in ms before unused cache blocks are returned to system pool. ; : Maximum time in ms before a dirty cache block gets flushed to disk. ; : Similar to under DOS, loads programs in CONFIG.SYS. Similar to under OS/2, but runs in foreground and halts CONFIG.SYS processing until return. ; : Specifies whether the keyboard status is turned on or off. ; : Specifies the name of the CD-ROM hardware driver. ; : Specifies the number of buffers for CD-ROM access. ; : Continues CONFIG.SYS processing in new file and (since DR-DOS 7.02) at optional label. ; : Specifies the type of clock used by the system. ; : Clears screen. ; : Specifies the OEM codepage(s). ; : Specifies the address of the CMOS RAM. ; : Specifies colors for boot menus. ; : Defines count and logical order and configures I/O address and timeout for COM1: device. ; : Defines count and logical order and configures I/O address and timeout for COM2: device. ; : Defines count and logical order and configures I/O address and timeout for COM3: device. ; : Defines count and logical order and configures I/O address and timeout for COM4: device. ; : Specifies buffer for DMA. ; : Redefines the lead-in character(s) for CONFIG.SYS inline-comments, or causes the following line to be ignored. ; : Enables and configures international support. ; : Sets display cursor to specified position for configuration menus. ; : For codepage switching support. ; : Specifies RAM refresh speed. ; : Conditional execution on 8088 CPUs only. ; : Conditional execution on 8088 and higher CPUs only. ; : Conditional execution on 8086 CPUs only. ; : Conditional execution on 8086/8088 and higher CPUs only. ; : Conditional execution on 286 CPUs only. ; : Conditional execution on 286 and higher CPUs only. ; : Conditional execution on 386 and higher CPUs only, f.e. or ; : Conditional execution on 386 and higher CPUs only. ; : Conditional execution on 486 CPUs only. ; : Conditional execution on 486 and higher CPUs only.DF
; : Configures the relocation of the drive descriptor tables. ; : Specifies the memory segment address up to which multi-sector disk data deblocking is allowed. ; : Enables internal debugger support. ; : Boot manager. ; : Loads a device driver into memory. ; : Loads a device driver into upper memory. (Same as in DRDOS 5.0.) ; : Configures country and codepage information for KBD, SCR, LPT1, LPT2, LPT3 devices. ; : Configures cache memory sizes. ; : Specifies floppy disk compatibility mode. ; : Specifies display font. ; : Specifies whether to load DOS into the high memory area and/or use upper memory. (Similar to under DRDOS 5.0.) ; : Specifies whether to load DOS tables (, , , , ) into upper memory. ; : Specifies alternative path to search for DOS files. ; ; : Specifies the search path for data files. ; : Specifies physical parameters of disk drives. ; : Define parameters for unrecognized drives. ; : See . ; : Enables and specifies drive forPDUMP.nnn
error logs.
; : Displays a message on screen.
; : Displays a message including ANSI Escape sequences.
; : Specifies if additional checks should be carried out when starting programs.
; : Specifies an error / return code to be assumed in the following.
; : Specifies the state of the A20 gate when starting a program.
; : Finishes CONFIG.SYS processing before the end of the file has been reached (except for and directive processing under some conditions).
; : Specified the size of the hash table for fast file open operations. Works considerably differently from the external MS-DOS/PC DOS FASTOPEN driver.
; : Specifies the number of cached FCBs that can be opened at once. (Under DR-DOS, and dynamically share the same internal buffer.)
; : Same as , but explicitly loads FCBs into upper memory.
; : Boot manager.
; : Specifies the number of files that can be opened at once.
; : Same as , but explicitly loads file handles into upper memory.
; : Include execution of specified CONFIG.SYS subsections. See .
GI
; : Waits for key (or timeout) and sets error level to its ASCII code (or 1024 on timeout). ; : Continues CONFIG.SYS processing at specified label. ; : Continues nested CONFIG.SYS processing at specified label, with returning to old location. ; : See or or . ; : See . ; : See . ; : See or . ; : See or . ; : See . ; : Installs a TSR program into memory, like , but installs after the DOS data segment relocation. Compare also:KM
; : Specifies the keyboard layout. ; : Specifies the address of the relocated keyboard buffer. ; : Specifies the maximum of drives that can be accessed. ; : Same as LASTDRIVE, but explicitly loads the Current Directory Structure (CDS) into upper memory. ; : Specifies a list of search paths for DLLs. ; : Specifies how old programs should be handled. ; : Specifies number of file locks. ; : Configures boot logo support under MS-DOS. Allows to display startup message in conjunction with PTS-DOS boot manager. ; : Defines count and logical order and configures I/O address and timeout for LPT1: device. ; : Defines count and logical order and configures I/O address and timeout for LPT2: device. ; : Defines count and logical order and configures I/O address and timeout for LPT3: device. ; : Enables, defines count and logical order and configures I/O address and timeout for LPT4: device. ; : Specifies time before a waiting process gets a higher priority. ; : Configures memory allocation strategy ; : Specifies the default DOS memory allocation strategy. ; : Defines menu options. ; : Specifies menu colors. (Can be emulated using under DR-DOS.) ; : Specifies the default menu block. (Can be emulated using and under DR-DOS.) ; : Specifies a menu block. (Can be emulated using and under DR-DOS.) ; : Specifies whether multitrack disk operations are used or not. ; : Continues CONFIG.SYS processing in new file (similar to DR-DOSNQ
; : Specifies the default No () character in Yes/No/Resume questions.) ; : Specifies whether the keyboard status is turned on or off. ; : Conditional execution depending on last return code/error status only, f.e. or . ; : Similar to and under DR-DOS, displays a text and waits for a key press. ; : Specifies if user must acknowledge errors in CONFIG.SYS. ; : Configures buffer size for LPT1, LPT2, LPT3. ; : Conditional execution on PC-compatible machines only. ; : Configures priority scheduler. ; : Configures priority of programs using disk I/O. ; : Changes internal default printer device driver ( to , or even ) for PRN device. ; : Specifies if DOS programs can be run or not. ; : Loads user interface. ; : Conditional execution on PS/1-compatible machines only. ; : Conditional execution onRT
; : Specifies if system should reboot automatically on errors. ; : Allows comments in CONFIG.SYS. ; : Specifies a drive letter not to be used up for local block device drivers. ; : Specifies the default Resume () character in Yes/No/Resume queries.) ; : Returns nested CONFIG.SYS processing at previous location of or directive. An optional return code can be given, otherwise 0 is assumed. ; : Defines the real mode memory size. ; : Similar to , loads programs in CONFIG.SYS. Similar to under DOS and under OS/2, but loads programs in background concurrently. ; : Specifies, if the first character of deleted files should be stored in the reserved area of directory entries in the FAT file system. ; : Similar to under PTS-DOS, specifies the video mode to be used under FreeDOS. Under PTS-DOS, does not specify the video mode but screen access methods. ; : Specifies whether the keyboard status is turned on or off.) ; : Sets environment variables. ; : Loads the command interpreter shell. ; : Same as , but supports an additional parameter to define the size of the pre-allocation for COMMAND.COM to relocate its resident portion into the HMA (with/MH
). Can be useful to avoid HMA fragmentation in conjunction with third-party shells which cannot load into the HMA. SHELLHIGH under PTS-DOS tries to load the shell into UMBs instead.)
; : Specifies the state of the keyboard modifiers like Shift Lock, Num Lock, Scroll Lock or Insert mode.
; : Specifies if files should be closed on .
; : Specifies if POST should be skipped on reboots.
; : Compatibility dummy - DR DOS 3.31 - 6.0 were mostly reentrant and had a different stacks layout.
; : Specifies the number of stacks for hardware interrupts.
; : Default stack size allocated for new threads.
; : Same as , but explicitly loads buffers into upper memory.
; : Boot manager.
; : Internal use.
; : Specifies how XMS A20 gate control should work.
; : Specifies a submenu block. (Can be emulated using , and under DR-DOS.)
; : Specifies a drive where to log error information instead of displaying a textmode popup screen.
; : Specifies swap file path.
; : Conditionally continues nested CONFIG.SYS processing at one of the specified labels depending on keys pressed, with returning to old location.
; : Defines the default UZ
; : Configures DOS management to use a specific segment as UMB memory. ; : Configures the UMB server used. ; : Specifies the address ranges used as UMB RAM. ; : Enables or disables disk write verification. ; : Specifies the DOS version (and optionally the true DOS version) to be reported to programs. ; : Configures VGA display status. ; : Similar to under FreeDOS, specifies current video mode. ; : Specifies if virtual DMA can be used. ; : Specifies if the processor's Virtual Mode Extensions (VME) should be deactivated or not. ; : Configures VxD driver for Windows. ; : Configures system support for Windows. ; : Configures the relocation of the Extended BIOS data area (XBDA) ; : Conditional execution on XT-compatible machines only. ; : Configures the built-in Year 2000 support. ; : Specifies the default Yes () character in Yes/No/Resume queries. ; : Configures deletion tracking.Issues
The system can still boot if this file is missing or corrupted. However, this file, along withEXIT
command is disabled only when the shell was started with /P
.) This also provides limited means to replace the shell at runtime without having to reboot the system.
Since the MS-DOS 7.0 and higher COMMAND.COM executable is incompatible with DR-DOS, but typically resides in the root of drive C: in dual-boot scenarios with DR-DOS, DR-DOS 7.02 and higher no longer allow to bypass SHELL directives in (+)// "skip"/"trace"/"step" modes. (Some later issues added (+) to reinvoke the former "skip" behaviour in order to allow recovery from problems with invalid SHELL arguments as well.) Also, if no SHELL directive could be found when skipping CONFIG.SYS processing via (+) (and also with (+)/, when the default file extension has been changed with SYS /DR:ext
), the user is prompted to enter a valid shell file name ''before'' trying to load COMMAND.COM from the root. Pressing without specifying a file will assume the former default.
Depending on the version, the size of the CONFIG.SYS file is limited to a few kilobytes under MS-DOS/PC DOS (up to 64 KB in most recent versions), whereas the file's size is unlimited under DR-DOS. This is because the former operating systems (since DOS 3.0) will compile the file into some tokenized in-memory representation before they sort and regroup the directives to be processed in a specific order (with device drivers always being loaded before TSRs), whereas DR-DOS interprets the file and executes most directives line-by-line, thereby giving full control over the load order of drivers and TSRs via DEVICE and INSTALL (for example to solve load order conflicts or to load a program debugger before a device driver to be debugged) and allowing to adapt the user interaction and change the flow through the file based on conditions like processor types installed, any type of keys pressed, load or input errors occurring, or return codes given by loaded software. This becomes particularly useful since INSTALL can also be used to run non-resident software under DR-DOS, so that temporary external programs can be integrated into the CONFIG.SYS control flow.
In MS-DOS/PC DOS 2.0 through 4.01, the length of the SHELL line was limited to 31 characters, whereas up to 128 characters are possible in later versions. DR-DOS even accepts up to 255 characters. CONFIG.SYS directives do not accept Dual booting DOS and Windows 9x
When installing Windows 95 over a preexisting DOS/Windows install, CONFIG.SYS and AUTOEXEC.BAT are renamed to CONFIG.DOS and AUTOEXEC.DOS. This is intended to ease dual booting between Windows 9x and DOS. When booting into DOS, they are temporarily renamed CONFIG.SYS and AUTOEXEC.BAT. Backups of the Windows 95 versions are made as CONFIG.W40 and AUTOEXEC.W40 files. When Caldera DR-DOS 7.02/7.03 is installed on a system already containing Windows 95, Windows' CONFIG.SYS and AUTOEXEC.BAT retain those names. DR-DOS' startup files are installed as DCONFIG.SYS (a name already used in earlier versions of DR DOS) and AUTODOS7.BAT.OS/2 / Windows NT
OS/2 uses the CONFIG.SYS file extensively for setting up its configuration, drivers and environment before the graphical part of the system loads. In the OS/2 subsystem of Windows NT, what appeared as CONFIG.SYS to OS/2 programs was actually stored in the registry. There are many undocumented or poorly documented CONFIG.SYS directives used by OS/2. CONFIG.SYS continues to be used by the OS/2 derivatives eComStation andSee also
*Notes
References
External links
* * * (Description of DR-DOS 7 CONFIG.SYS directives (incomplete)) * * * {{DEFAULTSORT:Config.Sys DOS configuration files OS/2 files Configuration files