Home | History | Annotate | Line # | Download | only in include
disklabel.h revision 1.6.4.1
      1  1.6.4.1  thorpej /*	$NetBSD: disklabel.h,v 1.6.4.1 2001/09/13 01:14:03 thorpej Exp $	*/
      2      1.1    chuck 
      3      1.1    chuck /*
      4      1.2    chuck  * Copyright (c) 1995 Dale Rahn.
      5      1.1    chuck  * All rights reserved.
      6      1.2    chuck  *
      7      1.1    chuck  * Redistribution and use in source and binary forms, with or without
      8      1.1    chuck  * modification, are permitted provided that the following conditions
      9      1.1    chuck  * are met:
     10      1.1    chuck  * 1. Redistributions of source code must retain the above copyright
     11      1.1    chuck  *    notice, this list of conditions and the following disclaimer.
     12      1.1    chuck  * 2. Redistributions in binary form must reproduce the above copyright
     13      1.1    chuck  *    notice, this list of conditions and the following disclaimer in the
     14      1.1    chuck  *    documentation and/or other materials provided with the distribution.
     15      1.1    chuck  * 3. All advertising materials mentioning features or use of this software
     16      1.1    chuck  *    must display the following acknowledgement:
     17      1.2    chuck  *   This product includes software developed by Dale Rahn.
     18      1.1    chuck  * 4. The name of the author may not be used to endorse or promote products
     19      1.2    chuck  *    derived from this software without specific prior written permission.
     20      1.1    chuck  *
     21      1.1    chuck  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     22      1.1    chuck  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     23      1.1    chuck  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     24      1.1    chuck  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     25      1.1    chuck  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     26      1.1    chuck  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     27      1.1    chuck  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     28      1.1    chuck  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     29      1.1    chuck  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     30      1.1    chuck  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     31      1.2    chuck  */
     32      1.1    chuck 
     33      1.1    chuck #ifndef _MACHINE_DISKLABEL_H_
     34      1.1    chuck #define _MACHINE_DISKLABEL_H_
     35      1.1    chuck 
     36      1.2    chuck /* number of boot pieces , ie xxboot bootxx */
     37      1.4    chuck #define NUMBOOT		0
     38      1.2    chuck 
     39      1.4    chuck #define	PARTITIONSHIFT	3 /* could also be 4 if you need 16 partitions */
     40      1.2    chuck 
     41      1.2    chuck #define LABELSECTOR     0                       /* sector containing label */
     42      1.2    chuck #define LABELOFFSET	0			/* offset of label in sector */
     43      1.2    chuck #define MAXPARTITIONS	(1 << PARTITIONSHIFT)	/* number of partitions */
     44      1.2    chuck #define RAW_PART	2			/* raw partition: xx?c */
     45      1.1    chuck 
     46      1.4    chuck /*
     47      1.4    chuck  * a cpu_disklabel is a disklabel that the bug (prom) can understand
     48      1.4    chuck  * and live with.   the bug works in terms of 256 byte blocks.   in our
     49      1.4    chuck  * case the first two bug blocks make up the cpu_disklabel (which is 512
     50      1.4    chuck  * bytes [i.e. one sector] in length).
     51      1.4    chuck  *
     52      1.4    chuck  * we use a fixed layout the BSD disk structure (in 256 byte blocks):
     53      1.4    chuck  *   block 0  = the volume ID block  (part of cpu_disklabel)
     54      1.4    chuck  *   block 1  = media configuration area (part of cpu_disklabel)
     55      1.4    chuck  *   block 2  = start of first level OS bootstrap (continues ...)
     56      1.4    chuck  *   block 31 = end of OS bootstrap
     57      1.4    chuck  *   block 32 = BSD filesystem superblock
     58      1.4    chuck  *
     59      1.4    chuck  * this gives us 30 blocks (30*256 = 7680 bytes) for the bootstrap's text+data
     60      1.4    chuck  *
     61      1.4    chuck  * disksubr.c translates between cpu_disklabel and BSD disklabel.
     62      1.4    chuck  *
     63      1.4    chuck  */
     64      1.4    chuck 
     65      1.1    chuck struct cpu_disklabel {
     66      1.2    chuck 	/* VID */
     67      1.4    chuck 	u_char  vid_id[4];	/* volume ID */
     68      1.4    chuck #define VID_ID		"NBSD"
     69      1.4    chuck 	u_char  vid_0[16];
     70      1.4    chuck 	u_int   vid_oss;	/* starting block # of bootstrap */
     71      1.4    chuck #define VID_OSS		2
     72      1.4    chuck 	u_short	vid_osl;	/* bootstrap length (30 blocks) */
     73      1.4    chuck #define VID_OSL		30
     74      1.4    chuck 	u_char	vid_1[4];
     75      1.4    chuck 	u_short	vid_osa_u;	/* bootstrap start address (upper) */
     76      1.4    chuck 	u_short	vid_osa_l;	/* bootstrap start address (lower) */
     77      1.4    chuck #define VID_OSA		0x3f0000	/* MUST match bootstrap code */
     78      1.4    chuck #define VID_OSAU	((VID_OSA >> 16) & 0xffff)
     79      1.4    chuck #define VID_OSAL	(VID_OSA & 0xffff)
     80      1.4    chuck 	u_char	vid_2[2];
     81      1.4    chuck 	u_short	partitions;
     82      1.4    chuck 	u_char	vid_vd[16];
     83      1.4    chuck 	u_long	bbsize;
     84      1.4    chuck 	u_long	magic1;		/* 4 */
     85      1.4    chuck 	u_short	type;		/* 2 */
     86      1.4    chuck 	u_short	subtype;	/* 2 */
     87      1.4    chuck 	u_char	packname[16];	/* 16 */
     88      1.4    chuck 	u_long	flags;		/* 4 */
     89      1.4    chuck 	u_long	drivedata[5];	/* 4 */
     90      1.4    chuck 	u_long	spare[5];	/* 4 */
     91      1.4    chuck 	u_short	checksum;	/* 2 */
     92      1.4    chuck 
     93      1.4    chuck 	u_long	secpercyl;	/* 4 */
     94      1.4    chuck 	u_long	secperunit;	/* 4 */
     95      1.4    chuck 	u_long	headswitch;	/* 4 */
     96      1.4    chuck 
     97      1.4    chuck 	u_char	vid_3[4];
     98      1.4    chuck 	u_int	vid_cas;	/* block # of CFG area, hardwired at 1 */
     99      1.4    chuck #define VID_CAS		1
    100      1.4    chuck 	u_char	vid_cal;	/* length of CFG area, in blocks (1) */
    101      1.4    chuck #define VID_CAL		1
    102      1.4    chuck 	u_char	vid_4_0[3];
    103      1.4    chuck 	u_char	vid_4[64];
    104      1.4    chuck 	u_char	vid_4_1[28];
    105      1.4    chuck 	u_long	sbsize;
    106      1.4    chuck 	u_char	vid_mot[8];	/* must contain "MOTOROLA" */
    107      1.4    chuck #define VID_MOT		"MOTOROLA"
    108      1.2    chuck 
    109      1.2    chuck 	/* CFG */
    110      1.4    chuck 	u_char	cfg_0[4];
    111      1.4    chuck 	u_short	cfg_atm;
    112      1.4    chuck 	u_short	cfg_prm;
    113      1.4    chuck 	u_short	cfg_atw;
    114      1.4    chuck 	u_short	cfg_rec;	/* block size (256) */
    115      1.4    chuck #define	CFG_REC		256
    116      1.4    chuck 
    117      1.4    chuck 	u_short	sparespertrack;
    118      1.4    chuck 	u_short	sparespercyl;
    119      1.4    chuck 	u_long	acylinders;
    120      1.4    chuck 	u_short	rpm;
    121      1.4    chuck 	u_short	cylskew;
    122      1.4    chuck 
    123      1.4    chuck 	u_char	cfg_spt;
    124      1.4    chuck 	u_char	cfg_hds;
    125      1.4    chuck 	u_short	cfg_trk;
    126      1.4    chuck 	u_char	cfg_ilv;
    127      1.4    chuck 	u_char	cfg_sof;
    128      1.4    chuck 	u_short	cfg_psm;	/* physical sector size (512) */
    129      1.4    chuck #define CFG_PSM		512
    130      1.4    chuck 	u_short	cfg_shd;
    131      1.4    chuck 	u_char	cfg_2[2];
    132      1.4    chuck 	u_short	cfg_pcom;
    133      1.4    chuck 	u_char	cfg_3;
    134      1.4    chuck 	u_char	cfg_ssr;
    135      1.4    chuck 	u_short	cfg_rwcc;
    136      1.4    chuck 	u_short	cfg_ecc;
    137      1.4    chuck 	u_short	cfg_eatm;
    138      1.4    chuck 	u_short	cfg_eprm;
    139      1.4    chuck 	u_short	cfg_eatw;
    140      1.4    chuck 	u_char	cfg_gpb1;
    141      1.4    chuck 	u_char	cfg_gpb2;
    142      1.4    chuck 	u_char	cfg_gpb3;
    143      1.4    chuck 	u_char	cfg_gpb4;
    144      1.4    chuck 	u_char	cfg_ssc;
    145      1.4    chuck 	u_char	cfg_runit;
    146      1.4    chuck 	u_short	cfg_rsvc1;
    147      1.4    chuck 	u_short	cfg_rsvc2;
    148      1.4    chuck 	u_long	magic2;
    149      1.4    chuck 	u_char	cfg_4[192];
    150      1.6      scw } __attribute__((__packed__));
    151  1.6.4.1  thorpej #endif /* _MACHINE_DISKLABEL_H_ */
    152