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