Poul-Henning Kamp 7812d86f03 (This commit touches about 15 disk device drivers in a very consistent
and predictable way, and I apologize if I have gotten it wrong anywhere,
getting prior review on a patch like this is not feasible, considering
the number of people involved and hardware availability etc.)

If struct disklabel is the messenger: kill the messenger.

Inside struct disk we had a struct disklabel which disk drivers used to
communicate certain metrics to the disklayer above (GEOM or the disk
mini-layer).  This commit changes this communication to use four
explicit fields instead.

Amongst the benefits is that the fields do not get overwritten by
wrong or bogus on-disk disklabels.

Once that is clear, <sys/disk.h> which is included in the drivers
no longer need to pull <sys/disklabel.h> and <sys/diskslice.h> in,
the few places that needs them, have gotten explicit #includes for
them.

The disklabel inside struct disk is now only for internal use in
the disk mini-layer, so instead of embedding it, we malloc it as
we need it.

This concludes (modulus any mistakes) the series of disklabel related
commits.

I belive it all amounts to a NOP for all the rest of you :-)

Sponsored by:   DARPA & NAI Labs.
2002-09-20 19:36:05 +00:00
..

                README and FAQ for the fla driver.
		==================================


[0]	COPYRIGHT & LICENSE

	Please read the COPYRIGHT file carefully.  If you cannot
	agree to be bound by the terms of this license, please
	contact M-systems and make arrangements with them.

[1]	What does this driver do ?

	This driver supports up to eight M-systems DiskOnChip
	devices.

	The driver has been tested with the following devices:

	DiskOnChip2000 (8, 12, 24, 32, 40, 72, 144 MB)
	DiskOnChipMillenium (8 MB)
	DiskOnChipMillenium TSOP (8 MB)

	You can find full details, specs etc on M-systems homepage:
	http://www.m-sys.com

[2]	Which firmware version ?

	The driver has only been tested with version 1.21.

[3]	How many devices ?

	The driver supports up to 8 devices but have been tested only
	with 5 due to hardware limitations in my test setup.

[4]	Which FreeBSD versions ?

	The driver is tested for 4.0-CURRENT and 3.3-RELEASE.

	Porting to earlier versions of FreeBSD should be a simple
	matter of modifying the fla.c file.  [patches are welcome]

[5]	Can I install FreeBSD with sysinstall ?

	Yes, it has been tested in FreeBSD-4.0-CURRENT and it works.
	You will need to build a kernel with the fla driver since
	the default "GENERIC" kernel doesn't contain the fla driver.

[6]	How to boot from a fla device ?

	FreeBSD 4.0 and forward find their root device by reading
	the /etc/fstab, so the DiskOnChip devices will work just
	like any other device.

	Earlier FreeBSD kernels recognizes the root device using
	various hacks.  These hacks doesn't recognize the fla device
	so some "real" hacks are needed to boot from your fla
	device.

	In pre 4.0 versions specifying the boot device in the kernel
	config file this way is the easiest way to do it:

		config          kernel  root on major 28 minor 65538

[7]	How to disklabel a fla device ?

	Look at the script in prep.fla.sh, it will do the job for you.

[8]	Who to contact ?

	doc2k@phk.freebsd.dk will offer limited best-effort help
	to the extent time permits.  Further support for special
	projects or configurations available at reasonable hourly
	rates.

[9]	Getting detailed

	The DiskOnChip product gets out in some odd corners of the
	PC-architecture, and chances are that things don't do what
	you expect.  Here are some hints and random observations
	I've made during my work with these devices.

[9a]	Choosing an address for the DOC

	Each DOC needs a 8K memory window starting on an 8K boundary.
	The lowest possible address is C000:0, the highest is DE00:0

	If your hardware puts the DOC another place, you will need
	to modify the doc2k_probe() call in fla.c.

	It is important that you set the BIOS to not do "fancy things"
	with this window, in particular no kind of cache or shadowing
	can be enabled.

	Be aware that some hardware will decode a 32k memory window 
	for the DOC device.

	If everything is OK, the DOC will print a message during
	the BIOS startup.

	For large devices it can take some time to check the flash
	data structures, but if it takes more than 3 minutes
	something is wrong.

	If you boot a MSDOS floppy and run FDISK you should be able
	to see the DOC device.

	If it doesnt work:

	If you machine never gets to the point where it will boot,
	but just hangs it could be because you have a BIOS which
	need the "slightly special" DOC firmware.  Obviously you
	will need to put the DOC in another machine to load this
	firmware.  You can download the firmware and utilities
	from M-systems website http://www.m-sys.com

	If the machine boots, but the device isn't visible it can
	be because some other device uses the same memory window,
	or because the BIOS prevents it from being used.  If you
	boot MSDOS and enter DEBUG, you should be able to find a
	BIOS extension signature at the address using the 'd'
	command, for instance 'd d800:0'.

	A special case is when the DOC prints the BIOS message
	but disappears afterwards, this can happen because another
	card (NCR SCSI controllers for instance) steal the memory
	window later in the boot process.  In such a case the
	above check with DEBUG will not show the BIOS signature.

[9b]	So just who is drive 'C' here anyway ?

	Using the DUPDATE program you can choose to have the DOC
	add itself at the front or the back of the device list.

	This is, unfortunately not the only thing affecting the
	drive order, the above mentioned NCR SCSI controllers also
	have some builtin AI, and the result can be very confusing
	because the DOC will come before even the floppy as a result.

	There is no simple solution for this case, only variuos
	work-arounds.  But chances are good that most users will
	not use both a DOC and a SCSI in the same system, except
	maybe for initial programming.

[9c]	MBR/fdisk

	The boot firmware in the DOC and/or the FreeBSD bootblocks
	mandate that the first MBR slice/(partition in FDISK lingo)
	start exactly at "sector #1, head #1, cylinder #0."  You 
	will have problems booting from the fla if you don't get this
	right.  The prep.fla.sh script will do this for you.

	DO NOT WRITE JUNK IN THE MBR!  The DOC firmware relies on
	various fields and can get utterly confused if they don't
	make sense.

[9d]	Getting the FreeBSD kernel to use the fla as root

	Please see above under item 6.

[9e]	I turned the machine off while it was running and now my
	DOC hangs during boot/panics the machine/does weird things.

	If a write operation to the DOC gets interrupted by reset
	or power-failure, it can happen that the flash data structures
	are left in a state the sofware cannot cope with.

	Your best chance is to DUPDATE, DFORMAT the device again.

	If it hangs during boot, you can use this particular dirty
	trick ENTIRELY AT YOUR OWN RISK!  DO NOT COMPLAIN IF THIS
	DOESN'T WORK FOR YOU OR IF YOU DESTROY YOUR COMPUTER OR
	DOC DEVICE DOING IT!

	Jumper the DOC for an address which will not work, but which
	will not interfere with the system either, C000:0 seems to
	work pretty universally for this.

	Boot MSDOS and rejumper the DOC for its real (working) address.

	Run DUPDATE and use the /win:xxxx argument to point it at the
	DOC device.

[9f]	Apart from that...

	...the DOC is just like any other disk, but it is silent,
	has better MTBF and doesn't take up a lot of space.


[10]	History

	The fla driver was written by Poul-Henning Kamp <phk@FreeBSD.org>
	under contract for M-systems, and using their "OSAK"
	development kit.

Good Luck,

Poul-Henning

$FreeBSD$