November 16, 2003 Alfredo Fernandez-Diaz was born in 1976 in Granada, SE Spain. He got into the warped world in 1996 shortly after beginning his studies in Theoretical Physics at the Granada University. He owned an Internet Cafe from 1999 to 2003, and in the meanwhile he founded a computing services company along with some other Spanish Warpers. He is currently at University again, studying Electronics Engineering while he tries to carry on with the company in the business world. If you have a comment about the content of this article, please feel free to vent in the OS/2 e-Zine discussion forums. There is also a Printer Friendly version of this page. |
|
Making a bootable CDBuilding an OS/2 (or eComStation) Boot CD again - or: 333, the number of the beast/2. | |||
What this is all aboutWe have just passed the 3rd quarter of the 3rd year of the 3rd millennium. OS/2 is still alive and kicking, and while it vanishes away (or not) its reincarnation, eComStation, gains strength. It is more certain than ever that the OS/2 community have an open future before our eyes. Certainly not an easy one but who knows the future anyway? We have a future, that many denied us. But a lot of time has passed (again 3 years) since I wrote an article about how to boot OS/2 from a CD and things don't last forever in the computing world. My particular way of celebrating this rather special moment is to bring back to life this old project of mine.
In the next paragraphs and some following articles I'll describe the current
status and issues related to the CD-boot process, the tools you'll need to
make your own CDs, etc. Notes:How to record data CDs or make ISO files will NOT be discussed here, but only which data should be on the CDs/ISO files, OS/2 boot configuration specific issues for booting and some "advanced" CD authoring issues. Most of what I'll be explaining can be done on pretty much every platform, but for the OS/2 specific parts at least DOS compatibility should be handy to execute some configuration tools. Although I can be contacted for help, in the article I'll assume a basic knowledge of CD authoring tools such as makeiso/cdrecord, RSJ or WinOnCD/Nero/whatever on the reader's part so I won't refer to program specific features but rather to abstract actions such as 'add the file XYZ to the CD filesystem' or 'set the boot image/method to ABC'. The pastI intended to begin repeating what I already said in my previous article . I guess most of you already know that, but for the benefit of the newbies and for understandability and completeness sake I think we have to begin from the beginning. As an extra you'll notice that the new text has been slightly enhanced and cleaned up, not only in structure but in style as well. Er... at least I hope so. However, due to timing issues that ended with me delaying this article for so long, I've decided to leave that boring part for my next article. Sorry for that. But this lets us concentrate on more up to date businesses :) The presentSo we begin where my former article ended and where its new incarnation will end next month: we have (or know how to build) a 'basic' CD. Just to remember the basics, there's a 2.88+ MB boot floppy image
(created dumping the info on the floppy sector by sector to a file) merged into
the CD-ROM. At this point it seemed that the hard part was done and all that was left was to add more functionality into this cd-booted system. Wrong. The 'Floppy Emulation' problemOn July 29th, 2000 I got an email from Kim Cheung (in case you don't know he is one of the first visible Serenity Systems heads) stating he had read my article as it appeared on the VOICE newsletter July 2000 issue, and requesting help with one thing I had deliberately left in obscurity just to find out if people were really interested. Obviously Kim was interested enough to ask ;-) This was the beginning of a somewhat sparse exchange of emails about this and that aspect of the process with the people from Serenity that has lasted until these days. I was doing this for fun and they weren't offering me a job, so though I was willing to help they simply asked for what they needed and worked on their won. This led to them facing a lot more test scenarios than me while I almost dropped the project, so they soon discovered there were a lot of problems out there for the CD boot process... In the first days of November, 2000, I got a new email from Glenn Hudson, another SSI'er, requesting help to get eComStation boot from CD but using the 'hard disk emulation' method instead of the floppy emulation that we had been using. An increasing number of PC systems weren't able to boot OS/2 from a CD any more and displayed the deadly "OS/2 cannot operate the floppy or hard disk drive" message. The 'No Emulation' methodFor a variety of reasons I couldn't help them with that. Seeing how things have developed I'd say the other people they contacted had a limited success in the best case. Fortunately for all of us there was still one method left, which has turned out to be the most efficient of what has been tried. It is called the no emulation method. This method consists essentially in loading a small program from the CD (as allowed by the El Torito CD boot specification) and give it control inmediately. I think this is the most successful method because (s)he who developes such a program must be extremely careful on what (s)he's doing and must not rely on a manufacturer provided floppy/hard disk emulation, which turned out to be faulty in a lot of cases. Now let's have a look at the solution Serenity found for the problem, in hands of another well known OS/2 developer, Veit Kannegieser.
MEMDISK.ADDThis excellent program can be found at Veit's homepage, and it works as I have already mentioned, plus it does a number of extra things. The details are in the program docs (though I have always thought that Veit should stop being so productive one day and sit down to write good docs ;) ), so I'll give just a quick explanation and a fast how-to.
The first part of the program is the loader, which used to be called memboot.bin
but has been split lately into a true loader called cdloader.bin and the memdisk
program itself due to some BIOS problems.
When memboot.bin is loaded it creates a RAM drive according to its configuration
parameters that must be established in a response file and integrated into the
program with the corresponding utility (that is you need to do this before getting
a non-default memboot.bin). After that it creates LVM information for this RAM
drive, applies boot code to its first track, unpacks the operating
system files (OS2KRNL, CONFIG.SYS, etc.) onto the RAM drive, loads them and gives
control.
Although the no emulation method seems the way to go, MemDisk is just one possible solution (and though it's still the only viable one there may be others). This program has several PROs and CONs I'm detailing next:
The PRO's
The CON's
Of course none of these is Veit's fault; I'm sure he has done his very best and MemDisk is a great tool. It's just I feel some aspects can still be improved. OTOH I'm dealing with OS/2 boot issues here, while Veit's MemDisk can be used to boot pretty much everything from the RAM drive. We keep going
All in all, this superb program allows us to keep happily booting our favorite OS
form CD without worrying any more. BTW and despite the mentioned CONs, MemDisk
renders RAMFS pretty much unnecesary (not useless) to do the boot part.
Note (warning): the MemDisk drive is FAT so it should work OK for the WPS EAs stuff just like RAMFS, but simply be aware not to do something involving long file names... So once again we're in a position where we should be definitely better off adding useful stuff to our CD i.e studying more OS/2 anatomy.
LANGUAGE and Unicode support, a step into modern times...
... And a little step back.
While I only know of one program that uses OS/2 LANGUAGE facilities currently (the
OS/2 system editor E.EXE, instead of _all the system applets_ to begin with), it is
true that NLS is getting more and more popular, though it is hand-made in most
cases. However, there's something into which it's almost impossible not to step
for what respects to language support: codepage conversion and unicode handling.
So it seems LANGUAGE and UNICODE are a must. Fortunately we already had them when we were about to need them. Almost. Well, this project was indeed good intended, but the developers did a poor job. UNICODE.SYS: When you want to do things your way...
...you usually get hit against a wall, didnt' you know?
It seems that the UNICODE.SYS developers thought: "Why use the
ULSPATH variable
that should point us to the right directory?" Instead, UNICODE.SYS
is hard-coded
to look for the codepage translation files it needs in \LANGUAGE\CODEPAGE
on the
'current' drive (i.e. the boot drive because this happens during the boot process).
I don't think this deserves by itself more comments other than how to face and
solve the problems that this fact arises.
Well no, it's not easier. Perhaps it should not be that hard when booting in floppy emulation mode. However it's impossible when using MemDisk, because its pack method does not allow directories and the files can't be copied to the RAM drive with commands until all the DEVICE= statements (one of which loads UNICODE.SYS), in CONFIG.SYS are processed.
LOCATECD.SYSFortunately, once again Veit Kannegieser comes to help us. This time he developed a device driver (LOCATECD.SYS) that you can get from his homepage and allows the current drive letter to be changed during the boot process. So all we need is the \LANGUAGE directory structure on N:. Then while booting from the MemDisk, Veit's device driver LOCATECD.SYS makes us switch to drive N: just before UNICODE.SYS is loaded in the next line. For floppy emulated boot systems I also recommend following this method that avoids wasting boot image room to add the LANGUAGE files, and also lets you set up a more generic CD boot build environment to easily switch back and forth between emulated and non-emulated boot methods. In either case, I'd leave the ULSPATH environment variable set to this default location, so well-behaved programs and drivers can use it just like the others. And one can hardly think of even more obstacles to get a useful boot CD. Luckily it seems that the universe ran out of bad ideas too, so we can get back to fill the CD... Adding filesystems supportOne of the main purposes of OSs is access data stored in disks, etc. so it seems a good idea to add some filesystem drivers to the CD. FAT32As of today, I'd say 90% of the people out there are using one or other version of Windows, so more likely than not you'll probably face the convenience of being able to access FAT32 partitions. In fact I needed this myself so bad that I got involved in the development of the driver, but that's another story. How to add it to the CD?
This one was easy, so there's not much to say.
Note: from now on "N:" denotes the drive letter I use for the bootable CD; of course you can choose whatever you like.
CONFIG.SYS statements: IFS=N:\OS2\IFS\FAT32\FAT32.IFS [/CACHE:2048] /Q CALL=N:\OS2\IFS\FAT32\CACHEF32.EXE /S LIBPATH=[...;]N:\OS2\IFSFAT32[;...] SET PATH=[...;]N:\OS2\IFSFAT32[;...] JFSThis has to be the favourite of children and grown-ups. The brand new filesystem everyone is installing on their ACP/MCP and eCS machines. Is it worth? I'll let you judge it for yourselves, and I'll simply tell you how to get it onto the CD:
Files on the CD:
CONFIG.SYS statements: IFS=N:\OS2\JFS.IFS [/CACHE:4096] [/AUTOCHECK:*] Note: You should locate this after the CDFS statement so the JFS can be accesed within the CD-ROM filesystem. Anything else?After that we have an OS that should be able to bot on pretty much every PC and acces pretty much every file on its harddisks. If you want to loop the loop, it's not too difficult to add NTFS support; but keep in mind the driver is available for eCS users only, for some reason. TVFS and even CDWFS from RSJ software can be added (with some limitations though)! But I'll leave those as an exercise to the advanced students. As the base OS is quite complete now, at this point I'd recommend you to begin to think which "normal" applications you would need to have on a boot CD and add them yourselves. Think of it as yet another exercise. Just some suggestions: 'survival' tools for emergencies like File Commander/2, perhaps the Graham utilities, or an .INI file disassembler to perform forensic operations on a dead system .INI profiles...
Last words: I'll be backYes, this looks like a fairly long reading by now (or so I've been told), but I still have a couple more things to say about this, at least a complete backgroud review and a future implementations overview. And of course a credits section where I'll mention all the people who supported me one way or another, so stay tuned. BTW, if someone tried to contact me using the e-mail address that appears on my first article, it's not valid anymore although you won't receive your emails bounced back. Use alfredo at netropolis-si dot com instead.
As said, I'll be back.
|
|||||
|