Architecture of Windows 9x

From Wikipedia, the free encyclopedia
Jump to: navigation, search
This article is about Windows 9x kernel. For Windows NT kernel, see Architecture of Windows NT.
The Windows 95 Architecture.

The architecture of Windows 9x series OS kernel is monolithic. The basic code is considered similar in function to MS-DOS - as a 16/32 bit hybrid, it requires MS-DOS support to operate.

Critical files[edit]

The minimal Windows 95 so far was booted using the following set of files.


32 bit shell and command line interpreter

Windows 95 Core

Registry and other configuration files

Virtual Machine Manager and Configuration manager

  • VMM386.VXD - Virtual machine manager and default drivers. Essentially Windows 9x 32 bit kernel.

Installable file System Manager

  • IFSHLP.SYS - enables Windows to make direct file system calls bypassing MS-DOS methods
  • IFSMGR.VXD - 32 bit driver for installable file system
  • IOS.VXD I/O Supervisor (IOS) that controls and manages all protected-mode file system and block device drivers.
  • MPREXE.EXE MPRSERV.DLL and MPR.DLL , Multiple Provider Router, required for network authentification and user profiles
  • MSPWL32.DLL Password list management library

Device Drivers


The system may also use CONFIG.SYS (which contains settings and commands executed before loading the command interpreter) and AUTOEXEC.BAT (which is a batch file automatically executed after loading COMMAND.COM), but these two files aren't critical to the boot process, as Windows 9x IO.SYS contains a default setting for both, in case they're absent in the system. In Windows ME, CONFIG.SYS and AUTOEXEC.BAT are not processed. LOGO.SYS may be used as splash screen.

Boot sequence[edit]

Windows 9x startup process consistst of 6 phases

  • Phase 1 - The ROM BIOS Bootstrap Process

ROM BIOS started execution from the FFFF0h physical memory address. During this phase, BIOS first executes Power-on self-test (POST), checks existence of boot disk on A drive, if it is not found in the A drive, the ROM BIOS checks for a hard disk. If the computer has a Plug and Play BIOS, in addition: BIOS checks RAM for I/O port addresses, interrupt lines, and DMA channels for Plug and Play devices, disables found devices, creates maps of used and unused resources and re-enavles devices

  • Phase 2 - The Master Boot Record and Boot Sector

Master boot record is loaded at address 7c000h, and then it loads boot sector of Windows Disk partition. The boot sector contains the disk boot program and BIOS Parameter Block (BPB) table which to finds the location of the root directory and io.sys file, and then loads Io.sys file into memory.

  • Phase 3 - IO.SYS file initialization

IO.SYS initializes minimal FAT driver and reads MSDOS.SYS. Then it displays "Starting Windows " depending on BootDelay=<n> line Msdos.sys file. Then it loads Logo.sys file and displays a startup image on the screen. If the Drvspace.ini or Dblspace.ini file exists, it also loads drivers for compressed disks. Windows then tries to open registry files system.dat, if fails, it tries with system.da0. If configured in msdos.sys or in registry, also double buffering is enabled.

  • Phase 4 - Config.sys, and real mode configuration

Windows 95 and Windows 98 now analize config.sys and load MSDOS real mode drivers. Windows ME ignores this. If the Config.sys file does not exist, the Io.sys file loads drivers: IFSHLP.SYS, HIMEM.SYS and Setver.exe. Windows reserves all upper memory blocks (UMB) for Windows 95 operating system use or for expanded memory EMS. Windows 95 and Windows 98 execute command.com to process autoexec.bat. It loads terminate and stay resident (TSR) programs into memory. Windows ME ignores this step.

  • Phase 5 - Initialize drivers

Io.sys now runs WIN.COM. Win.com loads the Vmm32.vxd file into memory or it is accessed from the hard disk. This file contains most important drivers, but they can be replaced. The real-mode virtual device driver loader checks for duplicate virtual device drivers (VxDs) that exists both in the Windows\System\Vmm32 folder and the Vmm32.vxd file. In a case of duplicates, the driver in the Windows\System\Vmm32 directory will be loaded. Windows 95 and 98 now query real mode drivers calling INT 2F, and looks for drivers in registry entry HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\VxD marked to be loaded as external file. Then vmm32 analyses [386 Enh] section of the Windows\System.ini file, and loads drivers mentioned there. Some most important drivers are loaded even if they are not mentioned in Windows Registry, system.ini or in Windows\System\Vmm32 directory.

Once the real-mode virtual device drivers are loaded, driver initialization, on Windows 95 and Windows 98 occurs. Vmm32 then switches CPU from real mode to protected mode. The next step is initialization of protected mode drivers. It is executed in three phases for each device: critical part of initialization (while interrupts are disabled), device initialization (when file I/O is allowed) and InitComplete phase. After initialization of display driver, Windows switch to graphical mode.

  • Phase 6 - Win32 initialization

After all the drivers are loaded, the Kernel32.dll, gdi32.dll, Gdi.exe, user32.dll, User.exe, shell32.dll and Explorer.exe are loaded. The next step in the startup process is to load the network environment. The user is prompted to log on to the network that is installed. When a user logs on, his desktop settings are loaded from the registry, or the desktop configuration uses a default desktop. Windows then starts programs defined in the StartUp folder, Win.ini, and programs defined in registry keys Run, RunOnce, RunServices and RunServicesOnce inside branches HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion and HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\. After each program in the RunOnce registry key is started, the program is removed from the key. Hourglass pointer is turned off.

For more informations see [1]

Kernel[edit]

The Windows 9x kernel is a 32-bit kernel with virtual memory. Drivers are provided by .VXD files, or since Windows 98 the newer WDM drivers can be used.[2] However the old MS-DOS kernel stays resident in memory and Windows will use the old MS-DOS 16-bit drivers if they are installed.

See also[edit]

References[edit]

External links[edit]