Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 23 Sep 1996 14:01:26 -0700
From:      Darryl Okahata <darrylo@hpnmhjw.sr.hp.com>
To:        Bill Fenner <fenner@parc.xerox.com>
Cc:        Poul-Henning Kamp <phk@critter.tfs.com>, "Chris Csanady" <ccsanady@friley216.res.iastate.edu>, freebsd-bugs@freebsd.org, Terry Lambert <terry@lambert.org>
Subject:   Re: Very disturbing boot block problems.. 
Message-ID:  <199609232101.AA000732487@hpnmhjw.sr.hp.com>
In-Reply-To: Your message of "Mon, 23 Sep 1996 12:48:10 PDT." <96Sep23.124822pdt.177476@crevenia.parc.xerox.com> 

next in thread | previous in thread | raw e-mail | index | archive | help
Bill Fenner <fenner@parc.xerox.com> wrote:

> I'm planning to update fsdb to be able to print out all the data
> blocks that a file is in, which will presumably help diagnose why the
> bootblocks will fail to boot a particular file.

     This may not be sufficient.  The various inodes and directory
blocks also have to be below 1024.

     Here's something that Terry Lambert wrote up some time back.  It
gives the various and sundry reasons (and there are many!) for the 1024
cylinder limit.  [ Terry: would you mind if I cleaned it up and
submitted it to the handbook? ]

     -- Darryl Okahata
	Internet: darrylo@sr.hp.com

DISCLAIMER: this message is the author's personal opinion and does not
constitute the support, opinion, or policy of Hewlett-Packard, or of the
little green men that have been following him all day.

===============================================================================
From: Terry Lambert <terry@lambert.org>
Date: Wed, 28 Feb 1996 14:01:10 -0700 (MST)
Subject: Re: Look familiar? --> "Unable to find operating system"

> Hackers and others,
> 
> Last night I completed what was supposedly a "successful
> installation of FreeBSD 2.1 on my 2nd SCSI disk.  I selected
> the option to create the boot manager (I made the boot floppy
> and installed from CD ROM as recommended in the doc).  When
> the installation was complete and I rebooted the machine
> (removing the boot floppy from the A: drive first) I got
> the message:
> 
> Operating system not found

Probably you had the BSD install put in the OS-BS (or other boot
selector) on the first drive, instead of installing it from DOS
(see other articles about this in the -questions list archive
and in the FAQ).


> For some reason I see the message "DOS space > 1 gig" before
> the system tries to boot but I don't think this is the real
> problem.  I'm also not exactly sure how to change this since
> I didn't see any obvious options in the auto-scsi menu.

========================================================================
The 1024 cylinder limit, in a nutshell
========================================================================

The BSD boot blocks use the INT 13 raw sector read interface in
order to read the partition table to look for the BSD partition
entry.  The BSD partition entry is located from the partition entry
by multiplying out the 24 bit C/H/S value to get the start sector
the the BSD partition.

The start sector of the BSD partition contains the BSD boot block
(loaded by the system MBR or the boot manager -- e.g. OS-BS) that
does the above, followed by a disklabel (a BSD-specific mechanism
for making logical partitions).

In the disklabel is the absolute sector offset of the 'a' slice and
its length (the 'a' slice is the default slice for the '/' partition,
which is the FS root).

The second stage boot can not read a disklabel after cylinder 1024.

The second stage boot can not read inode 2 in the file system in
slice 'a' is after cylinder 1024.

The second stage boot can not read the directory data block pointed
to by inode 2 and containing the directory entry for the file 'kernel'
if the directory data block (or *any* intermedia directory data blocks)
is past cylinder 1024.

The second stage boot can not read the inode for the 'kernel' file if
the inode in slice 'a' is after cylinder 1024.

The second stage boot can not read the disk blocks containing the
kernel image and associated with the inode pointed to by the 'kernel'
directory entry if any of the blocks which make up the image (located
in slice 'a') are located after cylinder 1024.

The Cylinder 1024 limitation is an inherent design flaw in the INT 13
raw sector read interface parameter passing mechanism, which can only
take C/H/S values as arguments.

Ther exists an alternative INT 13 interface that take absolute sector
offset as a 32 bit value instead.  This interface is (inaccurately)
called "LBA" (or Logical Block Address).

Most controllers do not support LBA.  Most LBA support is bia a
sector-relocating TSR that is loaded in place of the normal MBR and
subsequently loads the normal MBR, as provided by OnTrack DiskManager
6.x and 7.x products.

The FreeBSD second stage boot blocks use the old INT 13 interface,
since the can not depend on the new one existing, and there are space
limitations which preclude increasing the size of the second stage
boot to accomodate LBA probe and utilization code.


					Terry Lambert
					terry@lambert.org
---
Any opinions in this posting are my own and not those of my present
or previous employers.



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?199609232101.AA000732487>