Windows 95 20 July 1992 build

(Redirected from Windows 95 build 22)
3.10.07200022
Build of Windows 95
Screenshot
OS family16-bit Windows
Version number3.10
Build number07200022
Architecturex86 PC/AT (16 bit)
Compiled on1992-07-20
About dialog
3.10.07200022-Winver.png

The 20 July 1992 build or build 07200022 is the earliest confirmed and available build of Windows 95, which predates the Chicago Feature Specification document by more than 2 months.[1] It was originally leaked on 18 September 1992 as a mislabeled Windows for Workgroups 3.1 build, and was later rediscovered and reuploaded on 23 June 2024.[2]

This build is relatively similar to contemporary builds of Windows for Workgroups 3.1, although it includes a number of user experience changes such as the new 3D control style, new applications and updated versions of existing applications. Unlike later builds of Windows 95, it requires a version of MS-DOS to be already installed and does not include any Win32 support, notably predating the earliest publicly released Win32s beta.

Build number[edit | edit source]

This build uses an unusual build number format where the first four digits are the date when the build was compiled. Therefore, build number 07200022 means that the build was compiled on 20 July. The latter four digits could be the time that this build was compiled, which would correspond to 00:22. This would match the file modified times seen in the available copy, although it was common for Microsoft to tamper with file modified times and should not be considered authoritative. It is possible that the second part could still be the traditional, consecutive build number.

This format appears to have continued to be used after the version number was increased to 4.0; Windows for Workgroups 3.11 build 026 includes several components backported from Chicago and/or Cougar builds, including SVGA256.DRV with a version number of 4.00.08310026 (later builds of Windows for Workgroups 3.11 include updated versions of this component sourced from later Chicago builds).

Relationship to various projects[edit | edit source]

It is disputed whether this build was indeed compiled as a part of the Chicago project, or a smaller project that ended up being overtaken by Chicago. The build was compiled more than two months before the Chicago Feature Specification was finished,[1] although the project was already well underway as shown by an internal e-mail discussing user interface change planning that went out in June 1992,[3] more than a month prior to the compilation of this build. Certain features mentioned in the feature specification, such as a generic 256 color SVGA driver, are already implemented in this build.

The build was compiled and packaged in a similar fashion to a regular Windows for Workgroups 3.1 build, which led to it being mislabeled as one when it originally leaked. Likely as a result of this, the build functions well on top of standard, standalone MS-DOS for the most part. However, the WinOldAp module that enables running MS-DOS applications under Windows depends on functionality that was implemented by Cougar, the 32-bit DOS kernel project, and is therefore broken under this copy of the build. It is possible that Win32 support is absent because it depends on features added in Cougar which are also absent.

A Win32 DLL from an early version of Win32s from January 1992 is included with the build. However, it sits unused as the build includes no Win32 implementation at all. The library is actually referenced in dead code within KERNEL32.DLL from build 58s, although it does not exist in that build. This still suggests that Win32c, the subset of Win32 implemented in Chicago was indeed derived from Win32s.

New features and changes[edit | edit source]

User interface[edit | edit source]

The user interface in this build has been redesigned to make its three-dimensional items more visible to the naked eye. Various other user interface elements have reverted their bold font style and have gone to their regular font states as well.

File Manager[edit | edit source]

There are two versions of the File Manager in this build – an unmodified Windows 3.1 WINFILE.EXE and a new FILEMAN.EXE. The main new feature added to this variant of File Manager is that it has right-click menus for files, folders and drives (something that would later become part of the Windows 95 user interface guidelines), allowing the user to do various context-specific file actions, such as moving, copying, deleting, renaming, and viewing file properties, as well as associating a file extension with an application.

The new version of File Manager also writes a different boot sector to a floppy disk when formatting it. It also has additional strings "Moving...", "Copying..." and "Deleting..." that don't appear to be used anywhere in the code yet.

Item / Project Manager[edit | edit source]

While calling itself "Windows Item Manager" in its executable header, it appears to be a very cut down Program Manager alternative. The user can add items to group windows and open .GRP files created by Program Manager. However, .GRP files produced by Project Manager cannot be loaded by Program Manager.

Raster[edit | edit source]

A redesigned version of the Paintbrush application, being built upon the Microsoft Foundation Class Library, is included in this build. Raster overhauls the user experience compared to Paintbrush, having smaller tool buttons, and a wider arrange of colours in the colour palette. Controlling all of the settings in Raster is done via the menu bar, unlike later builds where some are instead bundled with the tool buttons itself. It is a 16-bit application and still uses the Windows 3-style common controls, though the UI is an early version of that seen in Paint in builds 89 and later of Windows 95.

Task List[edit | edit source]

An early version of the Windows 95 Task List is included, replacing the Windows 3.x version. This version adds application icons for each app and a menu bar, however some options, such as ending tasks and the run box are not functional.

Control Panel[edit | edit source]

  • The "Metrics" control panel option is present (METRICS.CPL), although not installed by default. It is similar to the one from build 58s.
  • The "Desktop" control panel option has been removed, being replaced by a wallpaper selector (WALL.CPL) and a screensaver control panel option similar to one from Windows 3.0 with Multimedia Extensions 1.0 (SSDLG.CPL), both not installed by default.

Drag and Drop Printing[edit | edit source]

Drag and Drop Printing is a program that creates an icon for the printers installed on your system and allows you to print just by dragging a file on top of them. Double clicking on the icon opens a configuration UI for the printer. If you drag a file that can't be printed, it refers to itself as "Print Dropper".

WinOldAp[edit | edit source]

This copy of the build ships with a version of WINOA386.MOD that depends on functionality that was implemented as a part of Cougar, the 32-bit DOS kernel project. Running MS-DOS applications under 386 Enhanced Mode is therefore broken and launching one will cause errors.

The executable includes resources for a toolbar in windowed mode, which was later observed in build 58s. TrueType font support in windowed mode and "stream-oriented cut and paste", both mentioned in the Chicago Feature Specification as Cougar improvements, were also being worked on at this time. The executable description for WINOA386.MOD replaced "WIN386" with "DOS386", a change that also carried over to later builds of Windows 95.

Cougar dependency[edit | edit source]

Compared to Windows for Workgroups 3.1 build 014e, WINOA386.MOD in this build features extra code in its initialization function (cseg02:8099) that is not present in build 014e (cseg02:0049).

Notably, the version included with this build makes calls to the WSHELL virtual device driver, which was split away from the SHELL VxD during the development of Cougar in anticipation of a standalone, 32-bit MS-DOS version.[4] It also makes use of a new function to get a VxD API by its name rather than ID and checks for version number 3.20 rather than 3.10. In addition, the included VGA DOS-mode video driver for WINOA386, VGA.3GR, checks for VDDVGA version number 3.11 rather than 3.10.

Windows for Workgroups 3.1 build 014e WINOA386.MOD disassembly

; 014e
cseg02:0166                 mov     ax, 1683h
cseg02:0169                 int     2Fh             ; - Multiplex - MS WINDOWS -  3+ - GET CURRENT VIRTUAL MACHINE ID
cseg02:0169                                         ; Return: BX = current virtual machine (VM) ID
cseg02:016B                 cmp     bl, 1
cseg02:016E                 jz      short running_in_first_vm
cseg02:0170
cseg02:0170 error:
cseg02:0170                 mov     ax, 6
cseg02:0173
cseg02:0173 error_2:
; ...
cseg02:0187 running_in_first_vm:                    ; CODE XREF: sub_6A89+125↑j
cseg02:0187                 mov     bx, 17h         ; vxd id: SHELL
cseg02:018A                 mov     ax, 1684h
cseg02:018D                 int     2Fh             ; - Multiplex - MS WINDOWS - GET DEVICE API ENTRY POINT
cseg02:018D                                         ; BX = virtual device (VxD) ID, ES:DI = 0000h:0000h
cseg02:018D                                         ; Return: ES:DI -> VxD API entry point, or 0:0 if the VxD does not support an API
cseg02:018F                 mov     word ptr g_shell_api, di
cseg02:0193                 mov     word ptr g_shell_api+2, es
cseg02:0197                 cmp     g_shell_api, 0
cseg02:019D                 jz      short error
cseg02:019F                 mov     edx, 0
cseg02:01A5                 call    g_shell_api
cseg02:01A9                 jb      short error
cseg02:01AB                 cmp     eax, 30Ah       ; version number 3.10
cseg02:01B1                 mov     ax, 0Bh
cseg02:01B4                 jnz     short error_2

Build 07200022 WINOA386.MOD disassembly

cseg02:09A6                 mov     ax, 1683h
cseg02:09A9                 int     2Fh             ; - Multiplex - MS WINDOWS -  3+ - GET CURRENT VIRTUAL MACHINE ID
cseg02:09A9                                         ; Return: BX = current virtual machine (VM) ID
cseg02:09AB                 cmp     bl, 1
cseg02:09AE                 jz      short running_in_first_vm
cseg02:09B0
cseg02:09B0 error:                                  ; CODE XREF: sub_8099+103↑j
cseg02:09B0                                         ; sub_8099+15B↓j ...
cseg02:09B0                 mov     ax, 6
cseg02:09B3
cseg02:09B3 error_2:
; ...
cseg02:09C7 running_in_first_vm:                    ; CODE XREF: sub_8099+125↑j
cseg02:09C7                 xor     bx, bx
cseg02:09C9                 mov     ax, seg dseg03
cseg02:09CC                 mov     es, ax
cseg02:09CE                 assume es:dseg03
cseg02:09CE                 mov     di, offset aWshell ; "WSHELL   "
cseg02:09D1                 mov     ax, 1684h
cseg02:09D4                 int     2Fh             ; - Multiplex - MS WINDOWS - GET DEVICE API ENTRY POINT
cseg02:09D4                                         ; BX = virtual device (VxD) ID, ES:DI = 0000h:0000h
cseg02:09D4                                         ; Return: ES:DI -> VxD API entry point, or 0:0 if the VxD does not support an API
cseg02:09D6                 mov     word ptr g_wshell_api, di
cseg02:09DA                 mov     word ptr g_wshell_api+2, es
cseg02:09DE                 cmp     g_wshell_api, 0
cseg02:09E4                 jz      short error
cseg02:09E6                 mov     bx, 17h         ; vxd id: SHELL
cseg02:09E9                 mov     ax, 1684h
cseg02:09EC                 int     2Fh             ; - Multiplex - MS WINDOWS - GET DEVICE API ENTRY POINT
cseg02:09EC                                         ; BX = virtual device (VxD) ID, ES:DI = 0000h:0000h
cseg02:09EC                                         ; Return: ES:DI -> VxD API entry point, or 0:0 if the VxD does not support an API
cseg02:09EE                 mov     word ptr g_shell_api, di
cseg02:09F2                 mov     word ptr g_shell_api+2, es
cseg02:09F6                 cmp     g_shell_api, 0
cseg02:09FC                 jz      short error
cseg02:09FE                 mov     edx, 0
cseg02:0A04                 call    g_wshell_api
cseg02:0A08                 jb      short error
cseg02:0A0A                 cmp     eax, 314h       ; version number 3.20 (!!!!)
cseg02:0A10                 mov     ax, 0Bh
cseg02:0A13                 jnz     short error_2

Windows Memory Viewer[edit | edit source]

An application called Windows Memory Viewer (WINMEM.EXE) is present on the install media, however the driver it requires to run, MEMINFO.386, is not. By patching the application to not look for the driver in question, it is possible for it to run successfully.

256 color generic SVGA driver[edit | edit source]

This build includes SVGA256.DRV, a generic 256 color super VGA driver mentioned in the Feature Specification.

MS32EM87[edit | edit source]

This build includes an entirely unused MS32EM87.DLL, which is a PE using the old NT build 196 header format (although the first section header is zeroed out). As the name suggests, it is an Intel 80387 floating point emulator; exporting symbols _Ms32KrnlCbDataSize and _Ms32KrnlHandler, and importing two functions by ordinal from MS32Krnl. CodeView symbols are included; the executable was linked from two modules: \mrt32\emulator\objs\emdos32.obj and \mrt32\emulator\386\emulator.asm.

Unreferenced dead code in KERNEL32.DLL from build 58s will attempt to load MS32EM87.DLL, which does not exist in that build.

This component appears to be from a very early build of Win32s (PE build timestamp is Thu Jan 09 1992 05:32:23 GMT+0000); the build of Win32s included with the SDK of Windows NT 3.1 build 340 renamed it to W32SEM87.DLL and the DLL being imported from to W32SKRNL.DLL; and later builds of Win32s removed the file entirely.

New system APIs[edit | edit source]

KERNEL[edit | edit source]

System functionality has been implemented to read and write structs to INI files, using the READPRIVATEPROFILESTRUCT and WRITEPRIVATEPROFILESTRUCT KRNL386.EXE functions (these functions do not exist in the standard mode KRNL286.EXE, which is in fact unmodified from Windows for Workgroups 3.1 build 014e, perhaps indicating dropping Standard Mode Windows was already planned as of this build).

GDI[edit | edit source]

GDI.EXE has new exports mentioned in the Feature Specification: PolyBezier, PolyBezierTo and CreateDibSection.

USER[edit | edit source]

USER.EXE has a new DrawFrameControl export mentioned in the Feature Specification.

SHELL[edit | edit source]

SHELL.DLL has a new LOCATEHOOKPROC export.

Bugs and quirks[edit | edit source]

As this build is quite early in development, there are a few bugs and quirks in this build.

Networking[edit | edit source]

Networking functionality is quite buggy in this build, and as a result the system may crash on startup. It is recommended to either remove the network part of the [386Enh] section in SYSTEM.INI, or boot in standard mode to avoid loading buggy virtual device drivers.

Screensavers[edit | edit source]

  • Attempting to configure or test the "Blank Screen" screensaver will cause an error in the applet, however if clicking Ignore afterwards, it does the intended action.
  • Closing the applet crashes Control Panel.

MS-DOS application support[edit | edit source]

Trying to open an MS-DOS Prompt or any other DOS application in 386 enhanced mode will fail with a "Windows not set up correctly. Run the Windows Setup program again or run Windows in standard mode." error message. This is caused by the WinOldAp module for this mode (WINOA386.MOD) expecting to run under Cougar and calling into virtual device drivers not present in this build.

Graphics[edit | edit source]

  • In colour modes higher than 256 colours, Windows will report to be low on memory, and as a result will display most icons in the Program Manager as black boxes.
  • In 16 colour mode, the title bar font during Windows Setup will be Fixedsys instead of MS Sans Serif.

Applications[edit | edit source]

  • The Paging Heap Viewer will throw out a General Protection Fault when trying to run it on this build.
  • Paging statistics in the Windows Memory Viewer will not work, presumably due to MEMINFO.386 being missing.

Gallery[edit | edit source]

Setup[edit | edit source]

References[edit | edit source]