This is the third exciting installment of this ongoing saga of restoring Xenix 2.2.3c. When we last left off, we had discovered that it is possible for Xenix to boot with several sectors missing in /etc/init and that the vast majority of the data on the diskettes was intact — to the point that several more steps of the early installation completed.
The story thus far:
[Aside: Quite a while ago, I came across the excellent OS/2 Museum, run by Michal Necasek which helps categorize many of the more obscure bits of PC history, including a series of articles about Xenix, Microsoft’s version of SVR2 UNIX.]
If we were to get any further, Michal and I would have to dig deep into the world of teledisk, floppy disk formats, and perform some creative thinking.
The first step to solving a problem was characterizing it. That meant that the data we did have was almost certainly correct and that they corresponded to the sectors that existed on the disk. Michal had earlier confirmed that the TeleDisk images of Xenix 2.2.3c at the very least were internally consistent. As he worked on the TeleDisk images, I worked on characterizing the damage on the raw images.
The raw images indicated missing sectors by filling them with 0xF6 (unformatted) and were always in multiples of 512 bytes, consistent with the size of an individual sector. As such, I needed to know where in the disks we had holes. After a few hours of tinkering, I wrote sector_detector which generated this list.
Lots of numbers, right? Well, it’s not quite as bad as it looks. By using a hex editor and comparing strings, I got an idea of what is and isn’t missing. In the case of N1, it simply looks like there are some bits of junk data at the end of the filesystem which is why the output is so noisy. As I wrote to Michal, here was my initial report on what is and isn’t there.
The report attached is based on the original Xenix disks, and not ones I modified. Here's the good: - N3, N6, and B2 are healthy out of the box - B1 has a missing sector your already found. - The large number of free blocks at the end corresponds with the end of a set. N3 is the last disk the system needs for minimal installation. - On the whole, we're only missing one or two sectors from each disk - N2's missing 0-1 is probably "intended", since that's where the boot record should sit. Likely an artifact of how the disks were made originally. - The other two missing sectors on N2 are both init. As we've got a spare copy of this, I can reasonably say we have a complete set of minimal images now. Here's the damage elsewhere: - N5: both: ./usr/bin/[a]db (ouch) - X1: both are uucp, code - X2: doscat, data section - X3: 1: /usr/spool/lp/model/imagen.spp - shell script for printer driver 2: The divider between banner and /usr/bin/newline. Not exactly sure how much is lost, but the XOUT file looks like its all there. I see the header. Filename obtained from the manifest - X4: /etc/sysadmin. Shell script. The missing bit is in the backup Xenix code (IRONY!) - X5: Tailing end of dc, start of calendar. Mostly the tar header. - I1: part of ctype or calendar. Code - I2: /usr/lib/mail/alias. Code - I3: Part of the keyboard map script
(There was also damage on N1 that I wasn’t able to characterize at the time due to the fact it was filesystem formatted, and not a tar archive. This was noted shortly later. N4 also had a missing sector which I left out of this email by accident, but that bit of recovery has an article to itself.)
As I previously noted, the first two disks have a standard Xenix filesystem + bootsector. The others are simply raw tar images. As also noted by Michal’s report, he had successfully managed to extract some information from the TeleDisk images. To understand how, we need to break for a moment and dig into the nitty gritty of floppy disk formats.
Most of the older users here remember floppy disks of various formats, low destiny, double destiny, 8in, 5.25-inch, 3.5-inch, and more. Many fondly remember them as a simpler era, or as those infernal devices that eat your data and caused no end of grief. Fewer people understand the specifics of how floppy disks are read, written and encoded.
In a broad sense, floppies are organized in the form of sides-tracks-sectors, identical in many respects to terms used to describe hard drives that use cylinders-heads-sectors. When we think of media, there are two ways to think of it: in terms of logical addressing or physical addressing. Normally, when we say that a file lives at 0x800 on a disk, it needs to be mapped to a physical location. For devices of the era, this mapping was known as drive geometry. By knowing the geometry of a drive, one can say definitively that a file at logical address 0x800 physically resides on side 0, track 0, sector 4.
NOTE: For clarification, sides and tracks are counted starting from 0, but sectors start at 1 and represent 512 bytes. Keep this in mind if you are checking my math by hand.
For normal disks of a given type, one can be reasonably assured of its geometry. For example, the Xenix 2.2.3c floppy disks are 720 KiB, and correspond to dumps of 3.5-inch double-density media. In drive geometry terms, that means by convention the data should be organized in the form of 2 sides, 9 tracks per side, and 80 sectors per track.
However, if one is careful, and understands the specifics of how floppy drives work, it is possible to use non-standard geometry successfully; this was the basis of most of the copy protection systems of the era that would made duplicating disks much more difficult. This functionality could be used as a form of emulation; for example, it is possible to use 5.25-inch geometry on 3.5-inch disks for cases of backwards compatibility. It can also be used to extend a disk past the 720k/1.44MiB mark; for example, Windows 95 shipped on 13 floppies, each of which contained 1.61 MiB.
When a computer talks to the floppy disk controller directly, it indicates the track or sector numbers it wishes to access. As a quirk of how floppy drives work, flat files can only represent disks with traditional geometry. Disks with a non-standard geometry cannot be accurately reproduced by a flat image file or by the standard tools of the era. Special archival tools such as TeleDisk, which knew how to directly interface with the FDC could, however, successfully image and reproduce these disks.
Due to the flakiness of floppies of the era, an entire cottage industry popped up of applications that could successfully copy non-DOS floppies, especially those with non-standard track geometry. One of the most common ones was a DOS utility known as TeleDisk, a shareware utility sold by a company known as Sydev, which wrote files in the form of TD0 files.
Unlike DISKCOPY, TeleDisk directly interfaced with the disk controller, and enumerated each disk’s side, track, and sector count, and stored these in a special file which could accurately represent and retain this information. TeleDisk’s custom format stores each track and sector ID in its own data block, and can represent any type of format that can exist on the physical medium. As such, it could accurately track which data was where, and could successfully map (though not reproduce) bad sectors and such when imaging a disk.
Raw images on the other hand can only accurately represent data in a linear format. Floppy disk emulators such as the one in VirtualBox must map raw sector commands to linear file locations, and can’t (easily) work with non-standard disks, and by default corresponds to a 1.44 MiB floppy disk. Recent versions of VirtualBox have some ability to do media detection based on the size of the floppy disk, while older ones allow you to override the media detection via an advanced option.
Over the years, the TeleDisk format was successfully reverse engineered and documented, and Michal had a set of tools to work with and manipulate them. From his side, he determined the following missing and duplicated data from the disks. From his e-mail:
I attacked the problem from a different angle, the TeleDisk images. Here’s a quick report:
- Disk B1: - track 31, side 0: duplicate sector 6, 9 - track 68, side 0: duplicate sector 5, 6, 7 - Disk B2: all OK - Disk N1: - track 33, side 1: missing sector 6 - Disk N2: - track 39, side 1: missing sector 6, duplicate sector 2, 3, 9 - Disk N3: all OK - Disk N4: - track 36, side 1: missing sector 5, duplicate sector 2, 6, 7, 8 - Disk N5: - track 65, side 0: missing sector 2, duplicate sector 4, 5, 7, 8, 9 - Disk N6: all OK - Disk X1: - track 61, side 1: missing sector 8, duplicate sector 1, 2, 4, 7, 9 - Disk X2: - track 68, side 0: missing sector 5 - Disk X3: - track 30, side 0: missing sector 3, duplicate sector 1, 5, 8 - track 61, side 1: missing sector 8, duplicate sector 1, 5 - Disk X4: - track 65, side 0: missing sector 9, duplicate sector 1, 3 - Disk X5: - track 32, side 0: missing sector 2, duplicate sector 1, 5, 8 - Disk I1: - track 32, side 1: duplicate sector 1, 8, 9 - track 65, side 1: duplicate sector 1, 4, 5, 6, 7, 8 - Disk I2: - track 32, side 0: duplicate sector 1, 5, 9 - Disk I3: - track 64, side 0: missing sector 3, duplicate sector 8I *might* have missed something in case there are exactly as many duplicates as there are missing sectors on some track.
As you can see, there is a bit of a pattern. The problems are all in the track ~34 and ~64 range, plus or minus a few. When there is a problem, there are often sectors missing as well as duplicated, but sometimes there are only missing or only duplicated sectors. Problems happen on both sides of the disks.
Through comparison, we determined that the raw disk images and the TD0 files we had, corresponded to the same dump as the missing sector locations lined up with each other. It is extremely likely that the TD0 files were created first (in 1996 according to the time stamp), and then converted to flat files at a later time. As such, any attempts at locating additional data would have to come from the TeleDisk images, something that Michal managed a breakthrough on.
In a few cases, the missing sectors in the raw were copied by a duplicate sector with the wrong header later in the TD0 file, and Michal was able to reassemble these bytes that way. Through that methodology, he managed to restore B1, I1,I2, and one of the sectors of N5. This gave us a (mostly) complete set of base media to work with! With these recovered sectors, the installer could now successfully run through a minimal installation:
Selecting "Continue installation" would cause it to prompt for more disks and then die due to the broken manifest on N1 and due to missing sectors on the remaining disks. However, selecting "Stop installation now" would reboot the system, and successfully bring it up in multiuser mode!
Not a bad place to be considering where we started but we could do better. In addition, with a working Xenix 2.2 system on hand, I could confirm that Xenix itself uses normal disk geometry, and wouldn’t have been able to read non-standard disks out of the box. This was collaborated by the fact that if one removed the duplicated sector IDs, and added in the missing ones, I got a total of 1440 sectors per TeleDisk file, which corresponds to what you would expect to see for a normal diskette. As such, we were looking at floppy disk corruption or (more likely) a bad dump caused by a bad floppy drive or a TeleDisk bug due to the damage being consistent in similar locations on each disk.
At this point, I was going to go into further details on how the Extended Utilities disks were reconstructed, when something very interesting happened. Michael posted his version of the first part of this story on the 9th. In the comments, one John Elliott dropped a link to a more recent dump of two versions of Xenix 2.2 386 taken on March 5th (the day before Part 1 went up). Unless one of the SoylentNews editors is secretly holding out on me, it’s utterly bizarre that this surfaces now.
A quick check of the disks show that they appear to be completely intact (sector_detector didn’t show any missing bits), but these are not the same dumps we were working from. After pulling the disks apart, the disks correspond to Xenix 2.2.3c or 2.2.2j for the 386PS, while our dumps correspond to 2.2.3c 386AT.
386PS in this case corresponds to IBM’s PS/2 line of computers, which were based on the MicroChannel Architecture (MCA), and not the more common ISA/AT-compatible machines of the era. As such, the 386PS disks, while bootable, panics right after startup trying to enumerate devices.
A review of the kernel link kit shows that this kernel is *very* similar to our 386AT kernel, with the primary difference being that the HDD driver is “hd”, vs. “wd”, and a few MCA configuration files are present within the link kit for tape backup devices.
Unfortunately, to my knowledge, there is no known emulator for MCA-based PCs; MAME has support for the PS/2, but only emulates an ISA-based variant. If anyone here has an MCA based PS/2 machine with a 386 processor, it should be possible to run and install these images; if someone wants to try, drop a line below. I may also try taking these disks, and swapping the kernel on N1 for the 386AT based version to get them running.
These disks also have answered a few lingering questions we had about the sector reconstruction, but we’ll get that into that more in the next installment :)
If you enjoyed this article, please consider subscribing or gifting a subscription to help support SoylentNews.
~ NCommander
[martyb here. I don't know how many here recall, but when SoylentNews got started over three years ago, it took some up-front money to get servers spun up, domains registered, etc. NCommander put up personal funds towards that end and he has not yet been paid back even one cent. Once we have our operating expenses covered, it would be really nice if we could start repaying him. Several people have subscribed multiple times and/or offered more than the minimum subscription amount in the past — quite frankly, without their generosity, this site would have folded long ago. Please accept my heartfelt thanks to all who have contributed to the site. I continue to be humbled by the generosity and wisdom I see shared on our pages. Thanks to you all. ]
(Score: 0) by Anonymous Coward on Monday March 13 2017, @04:14PM (8 children)
Since my comment on the previous part [soylentnews.org] might get missed because it already left the main page, let me re-ask:
Why is this in Meta? It's neither about this site, nor about the software driving this site, nor about the people operating this site. Adding random stuff to Meta degrades its usefulness.
(Score: 0) by Anonymous Coward on Monday March 13 2017, @04:35PM (1 child)
If you were to argue that posts about people running the site should have a different nexus from posts related to the site itself or rehash, that could make sense, but you seem to think the combination of those in meta is okay, just that somehow this isn't that, and it's really puzzling. How isn't it about the people running this site? You do know NCommander is one of the people running it, right?
(Score: 0) by Anonymous Coward on Monday March 13 2017, @05:04PM
This is not about NCommander, this is about running Xenix on a virtual machine on a modern computer. It is in no way relevant to the story that it was NCommander who spent the effort to get it running.
Anyway, it should be clear that in this context "about people running this site" means "information about those people that is relevant to the site". If NCommander explained that in the next half year he would not have time for this site, that would be relevant information about NCommander that belongs in Meta. On the other hand, if NCommander decided to learn Perl 6, that wouldn't belong on Meta, unless he planned to rewrite Rehash in Perl 6.
(Score: 3, Informative) by FatPhil on Monday March 13 2017, @04:51PM (2 children)
Great minds discuss ideas; average minds discuss events; small minds discuss people; the smallest discuss themselves
(Score: 0) by Anonymous Coward on Monday March 13 2017, @05:16PM (1 child)
Note that I don't complain about the article; I complain about it being in Meta. Note that the only time you are likely noticing that it is in Meta is when you specifically open up Meta to find site-specific posts (as I did today to add a comment on the latest post about the site update, to add a comment about the size of the "+"/"-" boxes). And it is exactly in that situation when you don't want to search through unrelated content.
If people think community member generated content needs to be in a nexus other than main page, then a new nexus could be created for it. Anyway, the "Answers" topic also consists of community member generated content (with the exception of the latest story in this topic, [soylentnews.org] of course), but none of them is (nor belongs) in Meta.
(Score: -1, Troll) by Anonymous Coward on Monday March 13 2017, @09:55PM
If people think community member generated content needs to be in a nexus other than main page, then a new nexus could be created for it. Anyway, the "Answers" topic also consists of community member generated content (with the exception of the latest story in this topic, of course), but none of them is (nor belongs) in Meta.
Thank you for your most valuable and learned opinion. I will archive this in the place [iacpublishinglabs.com] reserved for such wonderful pronouncements.
(Score: 2) by martyb on Monday March 13 2017, @08:02PM (2 children)
Strangely enough, when I reviewed the first article in this series, I noticed it being slated for the Meta Nexus and meant to inquire about that with the intention of changing it to the main page. Got caught up in changing other things and never got back to it. My bad. You raise a valid point in that this series has nothing to do with the site itself which I would characterize as things such as: down time for maintenance, report on why the site was down, site upgrade, site governance, etc.
I would concur with the assessment that it does warrant a different nexus in that it is original content for the site. Will mention it to the rest of the editors and devs to see what we can come up with.
In the meantime, I have updated the existing articles in this series to be on the main page nexus, and the upcoming article(!), as well.
Thanks for calling this to our attention!
Wit is intellect, dancing.
(Score: 0) by Anonymous Coward on Tuesday March 14 2017, @11:34AM (1 child)
Thank you for fixing this issue.
BTW, can a story be in several nexuses at once? For example, assume writing a community review: This would obviously belong into the Community Review nexus, but it would also be original content, and thus should logically be in that new Original Content nexus. Or consider some original content about politics. That would belong both in Politics and in Original Content.
(Score: 2) by martyb on Tuesday March 14 2017, @05:08PM
You're welcome! Thanks for mentioning it!
BTW, can a story be in several nexuses at once? For example, assume writing a community review: This would obviously belong into the Community Review nexus, but it would also be original content, and thus should logically be in that new Original Content nexus. Or consider some original content about politics. That would belong both in Politics and in Original Content.
And, yes, as far as I know, one story can be listed in multiple Nexuses/Sections... at least the User Interface (UI) for editing stories permits it, but I have not actually tried it. Of course, it naturally follows that I did not think of that until I was updating the last of Xenix stories. :(
Wit is intellect, dancing.
(Score: 3, Interesting) by Runaway1956 on Monday March 13 2017, @04:35PM (1 child)
points up at the images in the submission ^ which can obviously be done after all
What will those crazy devs come up with next?
A MAN Just Won a Gold Medal for Punching a Woman in the Face
(Score: 2) by NCommander on Monday March 13 2017, @10:23PM
We've worked on the ability to download articles in your sleep, but my posts causes a brain buffer overflow, and their heads exploded.
Still always moving
(Score: 2) by FatPhil on Monday March 13 2017, @05:22PM (10 children)
"... past the 720k/1.44MiB mark; for example, Windows 95 shipped on 13 floppies, each of which contained 1.61 MiB."
720/1440 KiB (exact) - 1440KiB is ~1.406 MiB (approx). No idea what the exact for W95 was, but almost certainly a ratio 21/18 higher (a sectors per track change).
(Oh, episode 2 mentioned "9" as being something apart from sectors per track, maybe tracks per side or something, and if the articles are to be preserved for posterity, which they should be, then that should be corrected.)
I remember we ran Xenix as a server in my first job out of uni (1992, I guess), and that my boss was an old hoarder, but I suspect even he doesn't have the Xenix floppies lying around still, as he has a wife who values storage space more conventionally.
Great minds discuss ideas; average minds discuss events; small minds discuss people; the smallest discuss themselves
(Score: 0) by Anonymous Coward on Monday March 13 2017, @05:29PM (2 children)
I don't know about Windows 95, but OS/2 shipped with specially formatted disks that had a higher capacity than with normal formatting.
(Score: 2) by NCommander on Monday March 13 2017, @10:26PM (1 child)
Windows 95's disk format was known as the Distribution Media Format [wikipedia.org]. I haven't seen OS/2 on floppies in a long time but it might have used the same thing.
Still always moving
(Score: 2) by dry on Tuesday March 14 2017, @04:12AM
OS/2, starting with Warp v3 used XDF formatting, https://en.wikipedia.org/wiki/IBM_Extended_Density_Format [wikipedia.org] which gave 1860 kbs per 3.5 in floppy.
(Score: 1, Interesting) by Anonymous Coward on Monday March 13 2017, @06:14PM
The term "hoarder" is bandied about too much these days. Actual clinical hoarders live in filth- food wrappers, empty cups, bio-hazard, etc. It's not funny nor cool nor hip to misuse terminology.
That said, I, like many I know, am not a minimalist, and I happen to have 2 sets of Xenix 2.3 floppies.
(Score: 2) by LoRdTAW on Monday March 13 2017, @07:11PM (4 children)
There was a tool for formatting past the 1.44MB limit. After a little research I found one called FAIZ SuperFormat. Apparently it uses extra space used by the file system for storage. My guess is there is a specific amount of disk reserved by the FAT through a standard format which is significantly reduced using such tools. Probably limits the amount of files/dirs but for compressed installers, not an issue.
Source: https://groups.yahoo.com/neo/groups/freeware-news/conversations/topics/867?source=1 [yahoo.com]
Excerpt:
(Score: 3, Informative) by SomeGuy on Monday March 13 2017, @07:58PM (1 child)
If you look at how bits on a disk are physically organized, you may notice that there are "gaps" between each sector.
Here is an example of one disk where the physical location is graphically mapped so you can see it:
http://lucasm.cf/?mju0n [lucasm.cf]
The reason for these gaps is that timing variations can cause a floppy drive to write beyond the expected end of the sector, and overwrite the beginning of the next sector. Placing some gap between each sector helps prevent that.
In fact, the above image has visible timing "wobbles", suggesting it may have been written on an older belt-driven floppy drive, where such gap would have been VERY important. An image from a newer direct motor drive would usually show sectors much more lined up.
Anyway, formatters on IBM PCs could instruct the BIOS and FDC to format using less gap, and squeeze in extra sectors, but increasing the risk of write errors.
For some uses, this risk is acceptable. And for write-protected distribution media, this is a non-issue.
Some drives could also handle a few extra tracks, but that trick was not globally reliable.
There were a number of DOS formatters that could create such disks. Maxi disk, FDFormat, and NFORMAT are a few others that come to mind.
On top of reducing the sector gaps, these could indeed reduce some of the overhead used by the FAT. Specifically they could use larger cluster sizes (fewer cluster entries in the FAT) and a lower number of maximum files in the root directory. Which, again, while not ideal for general use, was often ideal for distribution media where each disk only contained one big ZIP.
(Score: 2) by NCommander on Monday March 13 2017, @10:29PM
The absolute theoretical max for a high destiny 1.4MiB floppy is slightly under 2 MiB if you remove sector gaps and if you didn't use a file-system. I've never seen a disk distributed like that, the most common "increased media" size was Microsoft's Distribution Media Format (DMF) [wikipedia.org]
Still always moving
(Score: 2) by FatPhil on Monday March 13 2017, @08:01PM (1 child)
Great minds discuss ideas; average minds discuss events; small minds discuss people; the smallest discuss themselves
(Score: 2) by NCommander on Tuesday March 14 2017, @03:22PM
Going beyond standard media limitations was generally an exercise of the drive itself vs. the FDC; even the PC AT could theoretically go beyond the standard limitations via the commands in the FDC. A drive built "within" tolerances should always work with standard gap sizes, but if you decreased the tolerance, it was possible to get more out of your floppies. Notably, this was more a problem for writing rather than reading due to the very write tolerances a read head has to manage. A double-destiny (720 KiB) floppy should be able to physically store 1 MiB of data. Macs of the era generally ran them at 800 KiB.
Still always moving
(Score: 0) by Anonymous Coward on Thursday March 16 2017, @03:24PM
Man, you forgot a very big one:
Most of the older users here remember floppy disks of various formats, low destiny, double destiny, 8in, 5.25-inch, 3.5-inch, and more.[..]
(Score: 3, Informative) by drussell on Monday March 13 2017, @05:47PM (9 children)
I have some actual MCA PS/2s around here. I 'm pretty sure at least one of them is a model 55SX which should work and I think I have an older model 70 which should be 386DX somewhere in one of the stacks the garage. :)
I'll take a look at what I have later this afternoon and I know I have at least a couple working HDDs that have that silly 72-pin card edge connector for the PS/2s on them and would be happy to try booting it up if you PM the disk images or a link to where I can find them to my e-mail address that is linked to this account.
(Score: 2) by LoRdTAW on Monday March 13 2017, @07:34PM (1 child)
I used to have a working MCA 286 until the great purge. I still kick myself for doing that but you can't keep everything.
(Score: 2) by NCommander on Monday March 13 2017, @10:21PM
For that MCA 286, you would need a 286PS release of Xenix, which I'm not even sure existed; if it did, no known copies exist on the internet. Because the system accesses the hardware in protected mode and bypasses the BIOS, it needs specific drivers for the MCA drives. This is why the the 386PS release can't be run in VirtualBox. OS/2 and Windows simply included both on the same medium, but Xenix released two different versions of the operating system.
Still always moving
(Score: 3, Informative) by jimtheowl on Monday March 13 2017, @09:52PM (6 children)
I would be willing to spend a weekend or two on this and exchange notes.
(Score: 2) by NCommander on Monday March 13 2017, @10:44PM (5 children)
The 95 might be too new; Xenix 2.2 386AT at least goes belly up with greater than 504 MiB HDDs, though that might work properly with the MCA hard drive. We recovered a serial number for the PS2 version and the media can be found through the links above.
drussel: Pinging to get your attention.
Still always moving
(Score: 2) by dry on Tuesday March 14 2017, @04:25AM (4 children)
SCSI drives usually didn't use CHS addressing and at least on OS/2 were one way of getting past the various IDE drive limits. There may have been translation happening somewhere.
What about if you played with the geometry? It is possible to go to 2 TBs (actually slightly less) with CHS addressing, I have a 1TB drive that works fine with OS/2 using
(Score: 2) by NCommander on Tuesday March 14 2017, @05:24AM (3 children)
Unfortunately, Xenix doesn't support SCSI out of the box. A few editions appeared to have support for it (likely non-x86), but it's not in this version. The support is listed in the "master" file however.
scsi 0 0137 014 scsi 0 28 28 1 4 0 0 0 0
This file has a list of basically any hardware Xenix supported at some point, Apple Lisa ProFile harddrives are listed for example, as are some X.25 network adapters (which required a specific connectivity kit to be installed, otherwise the kernel is only linked in w/ a X.25).
The underlying problem is that "raw" CHS addressing can only represent up to 512 MiB of space, but due to implementation issues with the spec, the last track isn't usable, limiting it to 504 MiB. Operating systems that used BIOS for disk I/O could get "translation geometry" which basically converts data blocks from the old format to the new format and other blackmagic to make it work. Notably, Windows 95 could resort to BIOS disk access methods in a pinch if absolutely necessary which lets it work on some devices it won't otherwise support. Due to the fact that Xenix is a true protected mode operating system and don't use the V8086 mode on the 386, it can't talk to BIOS. The first generation fix for the CHS problem allowed drives to use LHA addressing of various sizes which bumped the size limit up to 8 GiB, then 1024 GiB, and then higher.
Non-IDE drives on Xenix (such as a MCA HDD) should theoretically be able to go beyond the 504 MiB; there's no inherent limitation in the OS that prevents it from going to that point, it's just Xenix of this vintage pre-dates basically all the large drive extensions added to ATA over the years.
The osdev article on CHS discusses this somewhat more in-depth: http://wiki.osdev.org/ATA_in_x86_RealMode_(BIOS). [osdev.org]
Still always moving
(Score: 2) by dry on Tuesday March 14 2017, @07:21AM
OK, thanks for refreshing my memory, been a while since thinking about this.
(Score: 2) by RS3 on Tuesday March 14 2017, @07:34PM (1 child)
Actually most SCSI controllers, with system-level BIOS ("visible" in 1st meg. real-mode memory map), honor standard AT (MFM/RLL) system BIOS calls, so no special drivers needed. And you can toggle DOS (legacy) CHS translation- certainly in most Adaptec controllers. (I have some SCSI controllers which have no system-level BIOS, and are only recognized by OS drivers- not recognized by generic motherboard BIOSes.) At various companies I worked for 23 years ago we used SCSI (mostly Adaptec but also Mylex) and ran DOS, Windows (3.x and 95/98), OS/2 "Warp", Novell 3.x, Linux, ... all on the standard AT BIOS calls. You get faster performance if you have OS drivers (rather than BIOS calls).
Some SCSI controllers (and many other hardwares) were (are) supported in Xenix. You had to have a driver diskette, on which were object modules for your device, and you would go through a painful process of exchanging diskettes while the OS re-linked the kernel modules, adding in your new driver(s). Novell 2.x did this too. Novell 3.x became modular, like Linux did later on. Somewhere I probably have diskettes with Adaptec and some other .obj modules, and they might be somewhere online too. At least that's what I remember from 24 years ago when I probably last ran Xenix...
(Score: 2) by NCommander on Tuesday March 14 2017, @09:13PM
CHS translation only works if your kernel talks to the BIOS. Xenix directly talks to the the I/O port interface for ATA; that's why we had to patch it to be less idiotic back in part one to get it work on modern hardware. There's no support for V8086 mode, and Xenix setups the GDT very very early in boot. I've never seen a SCSI controller that actually emulates the hardware ATA interface; they generally just hook the BIOS controller which is good enough for almost everything else. DOS and Windows could always do BIOS calls if necessary, and I think OS/2 just took "ship the kitchen sink" approach to HDD management, but I never tried to load it on a SCSI drive.
When you're talking to the hardware directly, you have to setup the LBA blocks yourself. With Xenix, you get a link kit which lets you rebuild the kernel with whatever object files you want and map function calls to major/minor numbers and there's a set reserved for a SCSI controller and such. As such, you could build a new kernel with SCSI support and then boot of it, but its not included in the box here.
Still always moving