Subject: Re: Disklabel ioctls (was Re: nore on disk ...)
To: None <thorpej@nas.nasa.gov>
From: Leo Weppelman <leo@wau.mis.ah.nl>
List: tech-kern
Date: 11/15/1995 12:47:00
> On Tue, 14 Nov 95 11:15:19 EST 
>  "Gordon W. Ross" <gwr@mc.com> wrote:
> 
>  > Or do it like SunOS: <sun/dkio.h>
>  > 
>  > /*
>  >  * Disk io control commands
>  >  */
>  > #define	DKIOCGGEOM _IOR(d, 2, struct dk_geom)	/* Get geometry */
>  > #define	DKIOCSGEOM _IOW(d, 3, struct dk_geom)	/* Set geometry */
>  > #define	DKIOCGPART _IOR(d, 4, struct dk_map)	/* Get partition info */
>  > #define	DKIOCSPART _IOW(d, 5, struct dk_map)	/* Set partition info */
>  > #define	DKIOCINFO  _IOR(d, 8, struct dk_info)	/* Get info */
> 
> Yah, it would be nice to have these implemented, if nothing else than for 
> the sake of binary compatibility.
> 
> However, I suggested the semantics I did given that we have:
> 
> 	DIOCGDINFO	get disklabel
> 	DIOCSDINFO	set in-core disklabel
> 	DIOCWDINFO	set in-core disklabel, update disk
> 	DIOCGPART	get partition info; only really useful in kernel
> 
> Since our disklabel contains geometry (albeit potentially incorrect if 
> misconfigured) and partition info, it seems like something to just ask 
> the disk for geometry was more in order.  Sort of like a "generic" 
> version of a SCSI rigid-geometry mode-sense and indentify.  Maybe this 
> could be generalized a bit more and provide vendor, model, and revision 
> strings, if applicable.
I think you are right, given the current structure of the disklabel.

> 
> Actually, I've been thinking about disklabels lately; that 30-minute 
> commute gives me that opportunity.  I've been getting pretty frustrated 
> at some of the stupidity in our current disklabel semantics.  I think 
> what bugs me the most is the fact that on some devices, notably SCSI, the 
> total size of the disk is often a few to several blocks larger than:
> 
> 	sectors/track * tracks/cylinder * cylinders
I usually have my pocket calculator ready when setting the disklabel.
Dependent on the disk, you might win a nice swap-device ;-) You can
also gain some space when you partition on cylinder boundaries.

> 
> Indeed, I have a couple of disk manuals at work that flat out say that 
> the disk's reported geometry is _estimated_ based on observed averages.
This is because the number of sectors/track differs with the position of
the head above the platters. The current notion of disklabel/newfs and
friends about cylinders and tracks is rather outdated.
> 
> Disklabel(8)'s inability to deal with this is a problem.  For example, 
> you have a new SCSI disk, you install it, and proceed to install the 
> disklabel.  disklabel(8) chokes because partition `c' (or, whichever 
> RAW_PART happens to be on your system... *ahem*) runs past end of unit.  
> I.e. disklabel(8) did the math, and determined that your absolutely 
> correct disklabel is in error.  (Remember: MI SCSI and other drivers set 
> the size of RAW_PART and some geometry info in the disklabel if no label 
> is read off disk).  So, wanting to label the disk, you shrink `c'.  BZZT!
> Can't do that either; "open partition would move or shrink".
If I remember well, alot of grief can be spared when disklabel(8) would
take the values of:
	d_subtype, d_secperunit, d_sparespertrack,d_sparespercyl, d_acylinders,
	d_bbsize, d_sbsize
from the cpu-disklabel after the call to getasciilabel(). This is one of
the outstanding items on my todo list. I have a patch lying around here
to do just that. If you want to try it, tell me. I haven't thought about
it for quite some time - too busy with other parts...
> 
> So, the way I bypassed this in the hp300 install.sh is, well, sickening:
> 
> 	* Increase the number of cylinders by one.  Add a dummy partition
> 	  (a in this example) of offset 0, size 1 (block).  Label disk, using 
> 	  `disklabel -r -R /dev/rsd?c labelfile'.
> 	* Run `disklabel -e /dev/rsd?a'.  Adjust cylinders back to proper
> 	  value, and adjust the size of `c' so that the math works out.
> 	* Run `disklabel -e /dev/rsd?c' again and actually edit the
> 	  partition map to your liking.
> 
> I would propose something along these lines:
[ Lots of ideas deleted ]
I agree with the basic ideas you presented here. I wonder however if it
is really needed to shrink/grow the raw-partition. If nobody is having
'smart' ideas about disksizes and just adhere to what the disk is saying,
this shouldn't be needed. 
> 
> 	  Any program taking advantage of this interface is inherently
> 	  machine-dependent, and should be condemned spend it's days in
> 	  /usr/mdec.

Leo.