OS/2 2.11 SMP Bootable CDROM 10 Minute Installation Hack into VirtualBox
There was, still is, something appealing about OS/2 -- it was ahead of its time, Warp indeed -- The Integrating Platform.  I came across some relevant resources and created an OS/2 2.11 Bootable CDROM media for VirtualBox -- as I heard, through the grapevine, that it was undoable. 
OS/2 enabled me to learn Unix by utilizing the GNU/Linux utilities ported by OS/2 hackers. Accordingly, once IBM orphaned the OS/2 -- and the executives even balked at our multiple petitions to have the OS open sourced -- the transition to Linux was relatively painless. As a matter of fact, while creating this hack I had to bring my old ported GNU/Linux utilities, alternating between OS/2 2.0, 2.1x, and even Warp 3, environments so as to alleviate the shortcoming of 640x480 resolution.
Due to the scarcity of information, I usually operate by inductive reasoning. Notwithstanding, I came across the following 'nugget':
OS/2 has supported SMP for quite a while in special editions of OS/2. The first version was 'OS/2 2.11 for Symmetrical Multiprocessing'...
The diffences between the single-processor OS/2 and the SMP version are very small: 2 APIs for controlling the CPUs, an extra index for DosQuerySysInfo() and 4 APIs for dealing with spinlocks. I know that the 'SMP addendum' mentions a lot of other things, but they are server things, not SMP things.
'OS/2 2.11 SMP' supports up to 16 processors,...1
Yet my build of VirtualBox, from source, under a Metztli Reiser4 Debian environment can only go up to 8 processors/cores and  higher resolution than 640x480...
 higher resolution than 640x480...
Update 12-18-2022 : my personal development computing environment can only go up to eight(8) cores; however, I installed another Oracle VirtualBox 7.0.4 -- although 'headless' -- in one of my remote Metztli Reiser4 servers. I made use of VNC to make connection and although Remmina experience a buggy pointer (or mouse) I was able to bring up the SMP Monitor. I could not delay this event as it is not everyday that an OS/2 for Symmetrical Multiprocessing (SMP) Version 2.11 is seen running on 16 CPU/Cores!
OS/2 for SMP Version 2.11 remote instance accessed via VNC
CONVERT FROM 2.1 BASE VIDEO INTO 3.0 BASE VIDEO IN ORDER TO TAKE ADVANTAGE OF THE MONITOR CONFIGURATION FEATURE OF THE 3.0 SYSTEM ICON
At our OS/2 2.1x CMD, executing the following:
Shell
| \OS2\VCFGINST.EXE | 
the screen will momentarily blank; subsequently, shutting down and then rebooting our OS/2 2.1x then, opening the Screen object will show the current screen resolution enabled by the conversion into 3.0 Base Video:
(Once the video player has started, right selecting (or 'clicking') your device (or 'mouse') will show menu option, 'Open video in new tab', which will enable larger screen size. Alternatively, the video with larger screen size may be shown in the Calli, i.e., 'Home', collection front page)
"
Platform Specific Drivers (PSDs)
In OS/2 for SMP V2.11, all of the platform specific code has been removed from the operating system, and placed into a Platform Specific Driver. These drivers provide an abstraction layer for the underlying hardware by allowing the operating system to call generic functions to perform platform-specific operations without worrying about the actual hardware implementation. This allows OS/2 for SMP V2.11 to support new MP hardware platforms without modifying the operating system.
PSDs are 32-bit flat DLLs specified in CONFIG.SYS by using the PSD= keyword, and must conform to the 8.3 file naming convention (e.g. PSD=TENOCHCA.PSD). They cannot contain either drive or path information because OS/2 cannot process such information at the stage of the startup sequence when the PSD statements are processed. The root directory of the startup partition is first searched for the specified file name, followed by the \OS2 directory of the startup partition. If drive or path information is included in a PSD statement, an error is generated.
PSD parameters may be specified after the PSD's name, and may be a maximum of 1024 characters long. The parameter string is not interpreted or parsed by OS/2, but is passed verbatim as an ASCIIZ string when the PSD's Install function is invoked.
If multiple PSD statements are encountered, OS/2 will load each PSD in the order listed in CONFIG.SYS, and call the PSD's install function. The first PSD which successfully installs will be the one OS/2 uses.
PSD statements are processed before BASEDEV, IFS, and DEVICE statements."
->\OS2\INSTALL\CAVERUN.PSD
->\OS2\INSTALL\OS2APIC.PSD
->\OS2\INSTALL\VIPERMP.PSD
->\OS2\INSTALL\EBI2.PSD
->\OS2\INSTALL\TRICRD.PSD
->\OS2\INSTALL\PROLIANT.PSD
->\OS2\INSTALL\WYSE.PSD
->\OS2\INSTALL\ALR.PSD
(The above are typical of middle of 1990's Compaq software bundle where OS/2 for SMP v2.11 was an option; notwithstanding, I believe that the maximum number of CPU/COREs supported was eight(8))
On OS/2 for SMP Version 2.11 Executing on 16 CPUs/Cores in VirtualBox We can Install HPFS386 File System Hack.
Shell
| \AHPFS386.CMD | 
(Once the video player has started, right selecting (or 'clicking') your device (or 'mouse') will show menu option, 'Open video in new tab', which will enable larger screen size. Alternatively, the video with larger screen size may be shown in the Calli, i.e., 'Home', collection front page)
Other Unix virtual file systems include the File System Switch in System V Release 3, the Generic File System in Ultrix, and the VFS in Linux. In OS/2 and Microsoft Windows, the virtual file system mechanism is called the Installable File System.
Wikipedia: Virtual File System
The Installable File System (IFS) is a filesystem API in MS-DOS/PC DOS 4.x, IBM OS/2 and Microsoft Windows that enables the operating system to recognize and load drivers for file systems.
...
The IFS provided a basic and powerful interface for programming filesystems. It was introduced in 1989 in OS/2 1.20, along with the HPFS filesystem.
Filesystem drivers executed in kernel-space (ring 0) and are divided in four principal pieces: microIFS, miniIFS, IFS, helpers.
Only the IFS and the filesystem code itself is required and it is loaded via an "IFS=" statement in the CONFIG.SYS file:
The microIFS is a piece of code that loads in memory the kernel and the miniIFS and jumps to kernel execution. It is usually in the boot portion of the filesystem.
i.e.,
'Big Blue'... could make a minimum investment in virtualizing the OS/2 boot procedure with the Kernel-based Virtual Machine (KVM) Linux virtualization technology used extensively by Red Hat -- IBM's latest acquisition!
Tlacatecolotl: OS/2 for Symmetrical Multiprocessing(SMP) v2.11 HPFS386 on Headless VirtualBox 7.0.12
Wikipedia: Installable File System
For OS/2 two kinds of IFS drivers were available for HPFS file system:
- The standard one with a cache limited to 2 MB
- HPFS386 provided with certain server versions of OS/2, or as added component for the server versions that did not come with it.
HPFS386's cache is limited by the amount of available memory in OS/2's system memory arena[1] and was implemented in 32-bit assembly language. HPFS386 is a ring 0 driver (allowing direct hardware access and direct interaction with the kernel) with built-in SMB networking properties that are usable by various server daemons, whereas HPFS is a ring 3 driver. Thus, HPFS386 is faster than HPFS and highly optimized for server applications. It is also highly tunable by experienced administrators.
Wikipedia: High Performance File System
Here we have an OS/2 for SMP v2.11 with HPFS386 hack -- on 16 CPU/Cores/Threads in VirtualBox 7.1.6 -- running GammaTech GTDISK utilities and seemingly saying (to IBM), 'Look ma', my CPUs or Cores or Threads do not hang me!'  
 
Typical OS/2 for SMP Version 2.11 CONFIG.SYS -- Installed to Drive H: -- Retrofitted with HPFS386 File System, MultiMedia, and TCP/IP
Here is some rearranged and enhanced code of A non-real-life example to prove a point1...
Unlike the initial preliminary hard-coded int 16 assigned to the variable threads, as elaborated at Ahuiani: OS/2 for Symmetrical Multiprocessing(SMP) v2.11 with HPFS386, MultiMedia, and TCP/IP stack., this version does query/detect the number of threads, as the original author intended. Further, it will output the int CPUs/COREs variable detected in OS/2.
Shell
| #define INCL_DOSPROCESS | |
| #define INCL_DOSMISC | |
| #include <os2.h> | |
| #include <stdio.h> | |
| #include <time.h> | |
|   | |
| #ifndef QSV_NUMPROCESSORS | |
| /*The QSV_NUMPROCESSORS is only defined in the SMP toolkit, | |
|  *and since the SMP toolkit is always at least 6 months behind | |
|  *the normal toolkit you will probably not want use it. | |
|  */ | |
| #define QSV_NUMPROCESSORS 26 | |
| #endif | |
|   | |
| int GetNumberOfCPUs() { | |
|   ULONG CPUs; | |
|   APIRET rc; | |
|   CPUs = 0; | |
|   rc = DosQuerySysInfo(QSV_NUMPROCESSORS, | |
|                        QSV_NUMPROCESSORS, | |
|                        &CPUs, | |
|                        sizeof(CPUs)); | |
|   /*We have to guard against running under a non-SMP OS/2 | |
|    *that does not support index 26, and that index 26 (as | |
|    *far as I remember) has previously been used for | |
|    *something else | |
|    */ | |
|   | |
|   if(rc!=0 || CPUs<1 || CPUs>64) | |
|     CPUs = 1; | |
|   return CPUs; | |
|   | |
| } | |
|   | |
| void SpendTime(int howmuch) { | |
|   //Use some CPU time | |
|   // - and beg that your compiler does not optimize this aways | |
|   int x=0; | |
|   for(int i=0; i<howmuch; i++) { | |
|     x += 2; | |
|   } | |
| } | |
|   | |
| void APIENTRY MyThread(ULONG howmuch) { | |
|   SpendTime((int)howmuch); | |
|   DosExit(EXIT_THREAD,0); | |
| } | |
|   | |
|   | |
| int main(void) { | |
|   TID tid[64]; //array to hold the TIDs of the threads | |
|   int threads=GetNumberOfCPUs(); //how many threads to create | |
|     int howmuch=1000000000; | |
|   // int howmuch=1000000000000000000; | |
|   int t; | |
|   | |
|   clock_t starttime=clock(); | |
|   | |
|   //create threads | |
|   for(t=0; t<threads; t++) { | |
|     DosCreateThread(&tid[t], | |
|                     MyThread, | |
|                     (ULONG)(howmuch/threads), | |
|                     CREATE_READY|STACK_COMMITTED, | |
|                     8192 | |
|                    ); | |
|   } | |
|   | |
|   //wait for the threads to finish | |
|   for(t=0; t<threads; t++) { | |
|     DosWaitThread(&tid[t],DCWW_WAIT); | |
|   } | |
|   | |
|   clock_t endtime=clock(); | |
|   | |
|   printf("CPUs/COREs detected: %d", threads); | |
|   printf("\nRunning time: %f seconds\n", ((double)(endtime-starttime))/CLK_TCK); | |
|   | |
|   return 0; | |
| } | 
Example SMP_OME executable program OS211-SMP_OME.ZIP is available AS-IS, i.e., no explicit nor implicit warranties and whoever downloads it s/he/they do at their own discretion. (Once the video player has started, right selecting (or 'clicking') your device (or 'mouse') will show menu option, 'Open video in new tab', which will enable larger screen size. Alternatively, the video with larger screen size may be shown in the Calli, i.e., 'Home', collection front page)
OS/2 for SMP Version 2.11 with HPFS386 hack, MultiMedia, and TCP/IP Version 2.04 in Action!
After installing the TCP/IP v2.x stack and its fixpak UN64092,
OS/2 for SMP Version 2.11, with HPFS386 file system hack and multimedia, can still implement The Network is the Computer protocols, as shown by pinging a couple of sites and -- provided we install the IBM WebExplorer v1.01 -- browsing a few still compatible sites.
---
NOTE: If you want to acquire this OS/2 2.11 SMP Bootable CD/ISO image hack, it comes in a bottle opener USB stick:
and includes the IBM base OS/2 2.10 CDROM image on which the hack was loosely based.
REFERENCES:
1 EDM/2 SMP - Symmetrical Multiprocessing
CAVEAT: I have seen some videos/statements out there where the OS2APIC.PSD is simply extracted from a higher version OS/2 for SMP and rammed in with an OS2KRNL with none or limited support for SMP, i.e., a two- CPU/Core OSKRNL with a Warp 3 server (vanilla or Advanced), Warp 4, and/or WSeB, -donated OS2APIC.PSD being presented as an four(4) CPU/CORE SMP in a YT video out there (hint  . Well, yes, the pseudo- SMP OS/2 will experience frequent severe locks during execution.
 . Well, yes, the pseudo- SMP OS/2 will experience frequent severe locks during execution.  Yet, the narrator will blame those events on legacy OS/2 SMP 'instability' thus cloaking his/her technical deficiency instead of admitting that s/he is cheating -- making fraudulent claims to defame the legacy OS/2 technology! i.e., YT video fragment:
 Yet, the narrator will blame those events on legacy OS/2 SMP 'instability' thus cloaking his/her technical deficiency instead of admitting that s/he is cheating -- making fraudulent claims to defame the legacy OS/2 technology! i.e., YT video fragment:














Recent comments: