|   |   | 
| Line 1: | Line 1: | 
|  | '''Phoenix OS/4''' is a project intended to recreate the original kernel for the [http://en.wikipedia.org/wiki/OS/2IBM Operating System/2]using such techniques, asreverse-engineering and disassembling. The main goal of the project is to make the system able to work on the PCs, thatit is unable to work on with theoriginal kernel.
 |  | The content of this page [http://www.os2world.com/wiki/index.php/Phoenix_OS/4 was moved to the OS/2 World Wiki] as that's the most popular and active one. | 
|  | 
 |  | 
 | 
|  | ==Installation instructions==
 |  | --[[User:Dbanet|Dbanet]] ([[User talk:Dbanet|talk]]) 18:52, 18 February 2014 (CET) | 
|  | From now, we assume that you [[#Getting_the_binary_distributions | downloaded the latest OS/4 kernel distribution]] zip file, and it is named like this:<br />
 |  | 
|  | <tt>os2krnlSVNxxxx_unoff.zip</tt>, where <tt>xxxx</tt> is the SVN revision of the downloaded release.
 |  | 
|  | To unify the following installation instruction, it is assumed, that the downloaded distribution file's name is <tt>os4krnl_current.zip</tt>. Please, rename the downloaded file to <tt>os4krnl_current.zip</tt> using your favorite filemanager or the CMD.EXE's <tt>ren</tt> command like this: <tt>ren os2krnlSVNxxxx_unoff.zip os4krnl_current.zip</tt>.
 |  | 
|  | Also, you will need the <tt>unzip</tt> utility, [http://hobbes.nmsu.edu/h-search.php?sh=1&button=Search&key=unzip&stype=all&sort=type_name&dir=%2Fpub%2Fos2%2Futil%2Farchiver which you can find on hobbes].<br />
 |  | 
|  |   |  | 
|  | Okay, so everything is set up properly -- let's begin!<br />
 |  | 
|  |   |  | 
|  | The OS/4 distribution package includes a powerful kernel loader, which features '''loading OS/4 and OS/2 kernels''', '''kernel selection menu''', '''custom CONFIG.SYS files''' for each kernel, '''CONFIG.SYS editor''' which may be invoked right before the kernel loads (available on OS/4 kernels only; although the modified version of the config is not put back on the disk, the feature is fairly useful in crash recovering), '''chainloading another kernel bootloaders''' and '''preloading files in the memory''' (better boot time).<br />
 |  | 
|  |   |  | 
|  | So, the first thing to do, is to install the OS/4 kernel bootloader, because the original one is unable to load the OS/4 kernel.
 |  | 
|  | If you use a recent version of ACPI, original kernel, or both (you have eCS), then it is highly recommended to keep the original bootloader:
 |  | 
|  | * unset the hidden attribute of the original kernel bootloader: <tt>attrib -H \OS2LDR</tt>
 |  | 
|  | * rename <tt>OS2LDR</tt> to <tt>OS2LDR.IBM</tt>: <tt>ren \OS2LDR OS2LDR.IBM</tt>
 |  | 
|  | * extract OS2LDR from the OS/4 package to the root of the boot drive: <tt>unzip os4krnl_current.zip OS2LDR -d \</tt>
 |  | 
|  |   |  | 
|  | Then extract the Phoenix OS/4 kernel to the root of the boot drive (the file is named OS4KRNL for the debug version and OS4KRNLR for the release version):
 |  | 
|  | * we will use the release version, so do <tt>unzip os4krnl_current.zip OS4KRNLR -d \</tt>.
 |  | 
|  |   |  | 
|  | OS/4 ships also with an updated <tt>DOSCALL1.DLL</tt> library, which works fine with both kernels (highly recommended):
 |  | 
|  | * download [http://hobbes.nmsu.edu/h-search.php?key=lxlite&pushbutton=Search the lxlite package] from hobbes
 |  | 
|  | * extract the unLock.exe utility to your PATH, for example, to the \OS2 directory: <tt>unzip -j lxlt133.zip lxLite\unLock.exe -d \OS2</tt>
 |  | 
|  | * now unlock your current DOSCALL1.DLL file: <tt>unlock \OS2\DLL\DOSCALL1.DLL</tt>
 |  | 
|  | * rename it for a backup: <tt>ren \OS2\DLL\DOSCALL1.DLL DOSCALL1.IBM</tt>
 |  | 
|  | * and then extract the Phoenix version: <tt>unzip os4krnl_current DOSCALL1.DLL -d \OS2\DLL</tt>
 |  | 
|  |   |  | 
|  | Then you need to configure the OS/4 kernel bootloader to be able to load the original, and the Phoenix kernel. The configuration file's name is OS2LDR.INI. An example configuration file is present in the distribution package, and contains a comment for each line.<br />
 |  | 
|  | Create an empty OS2LDR.INI file in the root of the bootdrive and then put this in it using a text editor (or whatever you want):
 |  | 
|  |  
 |  | 
|  |  [config]
 |  | 
|  |  default=1
 |  | 
|  |  timeout=15
 |  | 
|  |  
 |  | 
|  |  [kernel]
 |  | 
|  |  OS2LDR.IBM = IBM orig. kernel ,RESTART
 |  | 
|  |  OS4KRNLR   = Phoenix kernel   ,PRELOAD
 |  | 
|  | The <tt>default</tt> statement in the <tt>config</tt> section sets the default selection in the kernel selection menu, and the <tt>timeout</tt> statement sets the time in seconds before the default kernel will be loaded.<br />
 |  | 
|  | In the kernel section, the statements must comply with the following syntax:<br />
 |  | 
|  |  <kernel or loader filename> = <kernel selection menu option text>[,option[=value][,option[=value][,option[=value][...]]]]
 |  | 
|  | The possible options are:
 |  | 
|  | {| class="wikitable"
 |  | 
|  | |RESTART||Indicates, that the file to be loaded is an another kernel bootloader, rather than a kernel file.
 |  | 
|  | |-
 |  | 
|  | |LOGSIZE||Defines the size of the log buffer (which [[#Getting_the_log | you can get]]reading special device files)in KiB (0 < value < All memory - 16MiB). 
 |  | 
|  | |-
 |  | 
|  | |PRELOAD||Use the files preload function (a must for OS4APIC to work properly, also speeds up the loading process).
 |  | 
|  | |-
 |  | 
|  | |LOADSYM||Load the symbol file for <tt>OS2BOOT</tt>.
 |  | 
|  | |-
 |  | 
|  | |CFGEXT|| Specifies an extension for the <tt>CONFIG.ext</tt> file to be loaded instead of the CONFIG.SYS file, where <tt>ext</tt> 
 |  | 
|  | is the extension specified by the CFGEXT statement (must be three characters or less).
 |  | 
|  | |-
 |  | 
|  | |ALTF1||Emulates a user pressing Alt-F1 in the loader menu.
 |  | 
|  | |-
 |  | 
|  | |ALTF2||Emulates a user pressing Alt-F2 in the loader menu.
 |  | 
|  | |-
 |  | 
|  | |ALTF3||Emulates a user pressing Alt-F3 in the loader menu.
 |  | 
|  | |-
 |  | 
|  | |ALTF4||Emulates a user pressing Alt-F4 in the loader menu.
 |  | 
|  | |}
 |  | 
|  |   |  | 
|  | Although the original kernel may be loaded by the OS/4 kernel bootloader '''directly''', the most stable configuration is to use original bootloader to load the original kernel.<br />
 |  | 
|  |   |  | 
|  | Notice, that the original bootloader (OS2LDR.IBM) is able to load the only kernel file, named OS2KRNL, and you have to keep the original kernel with that name to have the ability to load it with the original bootloader.<br />
 |  | 
|  |   |  | 
|  | Also notice, that although you have the ability to chainload kernel bootloaders with custom name using the Phoenix bootloader, the '''first''' loaded kernel bootloader is always named OS2LDR.<br />
 |  | 
|  |   |  | 
|  | There are also some configuration statements you can use in the <tt>config</tt> section in the Phoenix bootloader configuration file, but those are usually only useful for debugging and troubleshooting purposes. See the example OS2LDR.INI file in the OS/4 kernel distribution package.<br />
 |  | 
|  |   |  | 
|  | ----
 |  | 
|  |   |  | 
|  | This is a basic installation process, but remember, that there is also a new <tt>CLOCK03B.SYS</tt>, which supersedes original <tt>TIMER0.SYS</tt> and <tt>CLOCK01.SYS</tt> drivers. It is recommend to install this driver:
 |  | 
|  | * <tt>unzip os4krnl_current.zip CLOCK03B.SYS -d \OS2\BOOT</tt>
 |  | 
|  | You don't need to modify <tt>CONFIG.SYS</tt><br />
 |  | 
|  |   |  | 
|  | '''Attention!''' Since SVN revision '''4166''', it is '''mandatory''' to install the new <tt>SCREEN03.SYS</tt>, otherwise kernel won't boot:
 |  | 
|  | * <tt>unzip os4krnl_current.zip SCREEN03.SYS -d \OS2\BOOT</tt>
 |  | 
|  | You don't need to modify <tt>CONFIG.SYS</tt>,too.<br />
 |  | 
|  |   |  | 
|  | ----
 |  | 
|  |   |  | 
|  | Okay, everything is set up. Now reboot your system!<br />
 |  | 
|  | You should notice the kernel selection menu with two options, where you can select to load either the original IBM kernel, or the Phoenix one. Although you may fail to boot up with the Phoenix kernel due to a bug in it, there is no doubt you will be able to fall back to the original kernel and boot your system with it (if you were able to do this before :)).
 |  | 
|  |   |  | 
|  | ==Frequently asked questions==
 |  | 
|  |   |  | 
|  | {{netfaq|q=
 |  | 
|  | I'm getting a <tt>SYS1195: The statement "VIRTUALADDRESSLIMIT" on line *** of the CONFIG.SYS file is not recognized.  Line *** is ignored.
 |  | 
|  | </tt> error message while booting. What's wrong?
 |  | 
|  | |a=
 |  | 
|  | Somewhere in SVN3xxx the VIRTUALADDRESSLIMIT tuning feature was broken. Now the VAL is fixed and set to 2048.
 |  | 
|  |   |  | 
|  | There's nothing bad in the error message; you can REM or remove the entire VAL statement in your CONFIG.SYS file -- it will always remain fixed to 2 GiBs.
 |  | 
|  |   |  | 
|  | Unfortunately, there is no information whether Phoenix will fix this issue and make the VAL changeable again, or not.
 |  | 
|  | }}
 |  | 
|  |   |  | 
|  | {{netfaq|q=
 |  | 
|  | Can I use ACPI.PSD with the OS/4 kernel, and what version?
 |  | 
|  | |a=
 |  | 
|  | Yes, you can. The best option is to use the 3.18version, as that's the latest officially supported version, and it has recommended itself as the most stable ACPI.PSD.
 |  | 
|  | }}
 |  | 
|  |   |  | 
|  | {{netfaq|q=
 |  | 
|  | I'm getting a <tt>TIMER0.SYS... initialization failed</tt> error message while booting. What's wrong?
 |  | 
|  | |a=
 |  | 
|  | The 16-bit <tt>TIMER0.SYS</tt> driver fail is okay because its function is now fully substituted by the <tt>CLOCK03B.SYS</tt> system driver written by Phoenix.
 |  | 
|  | }}
 |  | 
|  |   |  | 
|  | {{netfaq|q=
 |  | 
|  | What is the purpose of the <tt>CLOCK03B.SYS</tt> driver?
 |  | 
|  | |a=
 |  | 
|  | The CLOCK03B.SYS was rewritten in 32-bit and now contains two drivers: CLOCK$ and TIMER0$ (having more than one driver per module is allowed in OS/2). That was made for better performance and code cleanup.
 |  | 
|  | }}
 |  | 
|  |   |  | 
|  | {{netfaq|q=
 |  | 
|  | What is the purpose of the <tt>SCREEN03.SYS</tt> driver?
 |  | 
|  | |a=
 |  | 
|  | The <tt>SCREEN03.SYS</tt> was written to enable Panorama VESA BIOS Extension Video Driver to set the proper Write-Combine flags for the LFB (the linear frame buffer) '''without''' <tt>ACPI.PSD</tt>.
 |  | 
|  |   |  | 
|  | Now the Phoenix team provides the full alternative to the OS2KRNL + ACPI.PSD + PANOGRADD stack of technologies:
 |  | 
|  |   |  | 
|  | '''OS4KRNL + OS4APIC.PSD + ACPI4.SYS + SCREEN03.SYS + PANOGRADD'''
 |  | 
|  | }}
 |  | 
|  |   |  | 
|  | {{netfaq|q=
 |  | 
|  | How can I prevent the debug version of the kernel from jumping into KDB when some program traps?
 |  | 
|  | |a=
 |  | 
|  | Put this in <tt>KDB.INI</tt> file in the root of your boot drive:
 |  | 
|  |  .b 115200t
 |  | 
|  |  g
 |  | 
|  |  g
 |  | 
|  |  g
 |  | 
|  |  g
 |  | 
|  |  g
 |  | 
|  |  ln
 |  | 
|  |  k
 |  | 
|  | }}
 |  | 
|  |   |  | 
|  | {{netfaq|q=
 |  | 
|  | How can I get the kernel log if my test PC does not have a COM port? Can I use a USBCOM device?
 |  | 
|  | |a=
 |  | 
|  | No, you cannot get a kernel log using a USBCOM device. For more information on getting the kernel log, please refer to the [[#Getting_the_log | Troubleshooting/Getting the log]] section.
 |  | 
|  | }}
 |  | 
|  |   |  | 
|  | ==Troubleshooting==
 |  | 
|  | ===Known problems and not-a-problems===
 |  | 
|  |   |  | 
|  |   |  | 
|  | ===I think there is a bug in the kernel...===
 |  | 
|  |   |  | 
|  |   |  | 
|  | ===Getting the log===
 |  | 
|  |   |  | 
|  |   |  | 
|  | ===Submitting the bugreport===
 |  | 
|  |   |  | 
|  |   |  | 
|  | ===Participating in testing===
 |  | 
|  |   |  | 
|  |   |  | 
|  | ==Getting the binary distributions==
 |  | 
|  | Currently, the [http://ru2.halfos.ru/core/downloads/ download section on the RU/2's Core/2] is outdated (will be fixed ASAP).
 |  | 
|  |   |  | 
|  | The latest kernel distribution should reside on [http://www.gus.biysk.ru/os4/ the gus.biysk.ru server in the /os4 directory].<br />
 |  | 
|  | You should find there a '''ZIP''' file in the root, starting with '''os2krnlSVN'''.
 |  | 
|  |   |  | 
|  | Also [http://www.os2world.com/forum/index.php/topic,324.msg2674.html#msg2674 the first post on the OS2World thread about OS/4] should contain the direct link to the release.
 |  | 
|  |   |  | 
|  | ==Resources on the WWW==
 |  | 
|  | [http://www.gus.biysk.ru/os4/] is an official HTTP server, where you can get the latest OS/4 kernel releases and some useful utilities.<br />
 |  | 
|  | [http://ru2.halfos.ru/core/] is a section on the Russian Underground/2, fully devoted to the Phoenix project (Russian only).<br />
 |  | 
|  | [irc://efnet/os2russian] is an IRC channel where you can get support.<br />
 |  | 
|  | [http://www.os2world.com/forum/index.php/topic,324.0.html] is a thread on the OS2World forum about OS/4.<br />
 |  | 
|  |   |  | 
|  | ==Contacting developers==
 |  | 
|  | The most easy way to contact Phoenix is to join the [irc://efnet/os2russian #os2russian] IRC channel on the original EFNet network.
 |  | 
|  |   |  | 
|  | There is no collaborative e-mail mailbox, but you may consider writing to the SU.OS2 Fidonet area... Hrm. Well, the IRC channel is the best option.
 |  | 
|  |   |  | 
|  | Also there is a [http://ru2.halfos.ru/forum/index.html technical forum] at the [http://ru2.halfos.ru/ Russian Underground/2], where you can try writing to, too.
 |  | 
|  |   |  | 
|  | Most of the dialogs in the IRC channel, RU/2 forum, or the echo conference are performed in Russian, but if you jump there in English, you will get a conversation.
 |  | 
|  |   |  | 
|  | ----
 |  | 
|  |   |  | 
|  | Also there is a [http://www.os2world.com/forum/index.php/topic,324.0.html thread in the OS2World forum] (which is in English), where you can get support, too.
 |  |