Annotation of 43BSDTahoe/sys/h/disklabel.h, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1987, 1988 Regents of the University of California.
                      3:  * All rights reserved.
                      4:  *
                      5:  * Redistribution and use in source and binary forms are permitted
                      6:  * provided that the above copyright notice and this paragraph are
                      7:  * duplicated in all such forms and that any documentation,
                      8:  * advertising materials, and other materials related to such
                      9:  * distribution and use acknowledge that the software was developed
                     10:  * by the University of California, Berkeley.  The name of the
                     11:  * University may not be used to endorse or promote products derived
                     12:  * from this software without specific prior written permission.
                     13:  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
                     14:  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
                     15:  * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     16:  *
                     17:  *     @(#)disklabel.h 7.10 (Berkeley) 6/27/88
                     18:  */
                     19: 
                     20: /*
                     21:  * Disk description table, see disktab(5)
                     22:  */
                     23: #define        DISKTAB         "/etc/disktab"
                     24: 
                     25: /*
                     26:  * Each disk has a label which includes information about the hardware
                     27:  * disk geometry, filesystem partitions, and drive specific information.
                     28:  * The label is in block 0 or 1, possibly offset from the beginning
                     29:  * to leave room for a bootstrap, etc.
                     30:  */
                     31: 
                     32: #define LABELSECTOR    0                       /* sector containing label */
                     33: #define LABELOFFSET    64                      /* offset of label in sector */
                     34: #define DISKMAGIC      ((u_long) 0x82564557)   /* The disk magic number */
                     35: #ifndef MAXPARTITIONS
                     36: #define        MAXPARTITIONS   8
                     37: #endif
                     38: 
                     39: 
                     40: #ifndef LOCORE
                     41: struct disklabel {
                     42:        u_long  d_magic;                /* the magic number */
                     43:        short   d_type;                 /* drive type */
                     44:        short   d_subtype;              /* controller/d_type specific */
                     45:        char    d_typename[16];         /* type name, e.g. "eagle" */
                     46:        /* 
                     47:         * d_packname contains the pack identifier and is returned when
                     48:         * the disklabel is read off the disk or in-core copy.
                     49:         * d_boot0 and d_boot1 are the (optional) names of the
                     50:         * primary (block 0) and secondary (block 1-15) bootstraps
                     51:         * as found in /usr/mdec.  These are returned when using
                     52:         * getdiskbyname(3) to retrieve the values from /etc/disktab.
                     53:         */
                     54: #if defined(KERNEL) || defined(STANDALONE)
                     55:        char    d_packname[16];                 /* pack identifier */ 
                     56: #else
                     57:        union {
                     58:                char    un_d_packname[16];      /* pack identifier */ 
                     59:                struct {
                     60:                        char *un_d_boot0;       /* primary bootstrap name */
                     61:                        char *un_d_boot1;       /* secondary bootstrap name */
                     62:                } un_b; 
                     63:        } d_un; 
                     64: #define d_packname     d_un.un_d_packname
                     65: #define d_boot0                d_un.un_b.un_d_boot0
                     66: #define d_boot1                d_un.un_b.un_d_boot1
                     67: #endif /* ! KERNEL or STANDALONE */
                     68:                        /* disk geometry: */
                     69:        u_long  d_secsize;              /* # of bytes per sector */
                     70:        u_long  d_nsectors;             /* # of data sectors per track */
                     71:        u_long  d_ntracks;              /* # of tracks per cylinder */
                     72:        u_long  d_ncylinders;           /* # of data cylinders per unit */
                     73:        u_long  d_secpercyl;            /* # of data sectors per cylinder */
                     74:        u_long  d_secperunit;           /* # of data sectors per unit */
                     75:        /*
                     76:         * Spares (bad sector replacements) below
                     77:         * are not counted in d_nsectors or d_secpercyl.
                     78:         * Spare sectors are assumed to be physical sectors
                     79:         * which occupy space at the end of each track and/or cylinder.
                     80:         */
                     81:        u_short d_sparespertrack;       /* # of spare sectors per track */
                     82:        u_short d_sparespercyl;         /* # of spare sectors per cylinder */
                     83:        /*
                     84:         * Alternate cylinders include maintenance, replacement,
                     85:         * configuration description areas, etc.
                     86:         */
                     87:        u_long  d_acylinders;           /* # of alt. cylinders per unit */
                     88: 
                     89:                        /* hardware characteristics: */
                     90:        /*
                     91:         * d_interleave, d_trackskew and d_cylskew describe perturbations
                     92:         * in the media format used to compensate for a slow controller.
                     93:         * Interleave is physical sector interleave, set up by the formatter
                     94:         * or controller when formatting.  When interleaving is in use,
                     95:         * logically adjacent sectors are not physically contiguous,
                     96:         * but instead are separated by some number of sectors.
                     97:         * It is specified as the ratio of physical sectors traversed
                     98:         * per logical sector.  Thus an interleave of 1:1 implies contiguous
                     99:         * layout, while 2:1 implies that logical sector 0 is separated
                    100:         * by one sector from logical sector 1.
                    101:         * d_trackskew is the offset of sector 0 on track N
                    102:         * relative to sector 0 on track N-1 on the same cylinder.
                    103:         * Finally, d_cylskew is the offset of sector 0 on cylinder N
                    104:         * relative to sector 0 on cylinder N-1.
                    105:         */
                    106:        u_short d_rpm;                  /* rotational speed */
                    107:        u_short d_interleave;           /* hardware sector interleave */
                    108:        u_short d_trackskew;            /* sector 0 skew, per track */
                    109:        u_short d_cylskew;              /* sector 0 skew, per cylinder */
                    110:        u_long  d_headswitch;           /* head switch time, usec */
                    111:        u_long  d_trkseek;              /* track-to-track seek, usec */
                    112:        u_long  d_flags;                /* generic flags */
                    113: #define NDDATA 5
                    114:        u_long  d_drivedata[NDDATA];    /* drive-type specific information */
                    115: #define NSPARE 5
                    116:        u_long  d_spare[NSPARE];        /* reserved for future use */
                    117:        u_long  d_magic2;               /* the magic number (again) */
                    118:        u_short d_checksum;             /* xor of data incl. partitions */
                    119: 
                    120:                        /* filesystem and partition information: */
                    121:        u_short d_npartitions;          /* number of partitions in following */
                    122:        u_long  d_bbsize;               /* size of boot area at sn0, bytes */
                    123:        u_long  d_sbsize;               /* max size of fs superblock, bytes */
                    124:        struct  partition {             /* the partition table */
                    125:                u_long  p_size;         /* number of sectors in partition */
                    126:                u_long  p_offset;       /* starting sector */
                    127:                u_long  p_fsize;        /* filesystem basic fragment size */
                    128:                u_char  p_fstype;       /* filesystem type, see below */
                    129:                u_char  p_frag;         /* filesystem fragments per block */
                    130:                u_short p_cpg;          /* filesystem cylinders per group */
                    131:        } d_partitions[MAXPARTITIONS];  /* actually may be more */
                    132: };
                    133: #else LOCORE
                    134:        /*
                    135:         * offsets for asm boot files.
                    136:         */
                    137:        .set    d_secsize,40
                    138:        .set    d_nsectors,44
                    139:        .set    d_ntracks,48
                    140:        .set    d_ncylinders,52
                    141:        .set    d_secpercyl,56
                    142:        .set    d_secperunit,60
                    143:        .set    d_end_,276              /* size of disk label */
                    144: #endif LOCORE
                    145: 
                    146: /* d_type values: */
                    147: #define        DTYPE_SMD               1               /* SMD, XSMD; VAX hp/up */
                    148: #define        DTYPE_MSCP              2               /* MSCP */
                    149: #define        DTYPE_DEC               3               /* other DEC (rk, rl) */
                    150: #define        DTYPE_SCSI              4               /* SCSI */
                    151: #define        DTYPE_ESDI              5               /* ESDI interface */
                    152: #define        DTYPE_ST506             6               /* ST506 etc. */
                    153: #define        DTYPE_FLOPPY            10              /* floppy */
                    154: 
                    155: #ifdef DKTYPENAMES
                    156: static char *dktypenames[] = {
                    157:        "unknown",
                    158:        "SMD",
                    159:        "MSCP",
                    160:        "old DEC",
                    161:        "SCSI",
                    162:        "ESDI",
                    163:        "type 6",
                    164:        "type 7",
                    165:        "type 8",
                    166:        "type 9",
                    167:        "floppy",
                    168:        0
                    169: };
                    170: #define DKMAXTYPES     (sizeof(dktypenames) / sizeof(dktypenames[0]) - 1)
                    171: #endif
                    172: 
                    173: /*
                    174:  * Filesystem type and version.
                    175:  * Used to interpret other filesystem-specific
                    176:  * per-partition information.
                    177:  */
                    178: #define        FS_UNUSED       0               /* unused */
                    179: #define        FS_SWAP         1               /* swap */
                    180: #define        FS_V6           2               /* Sixth Edition */
                    181: #define        FS_V7           3               /* Seventh Edition */
                    182: #define        FS_SYSV         4               /* System V */
                    183: #define        FS_V71K         5               /* V7 with 1K blocks (4.1, 2.9) */
                    184: #define        FS_V8           6               /* Eighth Edition, 4K blocks */
                    185: #define        FS_BSDFFS       7               /* 4.2BSD fast file system */
                    186: 
                    187: #ifdef DKTYPENAMES
                    188: static char *fstypenames[] = {
                    189:        "unused",
                    190:        "swap",
                    191:        "Version 6",
                    192:        "Version 7",
                    193:        "System V",
                    194:        "4.1BSD",
                    195:        "Eighth Edition",
                    196:        "4.2BSD",
                    197:        0
                    198: };
                    199: #define FSMAXTYPES     (sizeof(fstypenames) / sizeof(fstypenames[0]) - 1)
                    200: #endif
                    201: 
                    202: /*
                    203:  * flags shared by various drives:
                    204:  */
                    205: #define                D_REMOVABLE     0x01            /* removable media */
                    206: #define                D_ECC           0x02            /* supports ECC */
                    207: #define                D_BADSECT       0x04            /* supports bad sector forw. */
                    208: #define                D_RAMDISK       0x08            /* disk emulator */
                    209: #define                D_CHAIN         0x10            /* can do back-back transfers */
                    210: 
                    211: /*
                    212:  * Drive data for SMD.
                    213:  */
                    214: #define        d_smdflags      d_drivedata[0]
                    215: #define                D_SSE           0x1             /* supports skip sectoring */
                    216: #define        d_mindist       d_drivedata[1]
                    217: #define        d_maxdist       d_drivedata[2]
                    218: #define        d_sdist         d_drivedata[3]
                    219: 
                    220: /*
                    221:  * Drive data for ST506.
                    222:  */
                    223: #define d_precompcyl   d_drivedata[0]
                    224: #define d_gap3         d_drivedata[1]          /* used only when formatting */
                    225: 
                    226: #ifndef LOCORE
                    227: /*
                    228:  * Structure used to perform a format
                    229:  * or other raw operation, returning data
                    230:  * and/or register values.
                    231:  * Register identification and format
                    232:  * are device- and driver-dependent.
                    233:  */
                    234: struct format_op {
                    235:        char    *df_buf;
                    236:        int     df_count;               /* value-result */
                    237:        daddr_t df_startblk;
                    238:        int     df_reg[8];              /* result */
                    239: };
                    240: 
                    241: /*
                    242:  * Structure used internally to retrieve
                    243:  * information about a partition on a disk.
                    244:  */
                    245: struct partinfo {
                    246:        struct disklabel *disklab;
                    247:        struct partition *part;
                    248: };
                    249: 
                    250: /*
                    251:  * Disk-specific ioctls.
                    252:  */
                    253:                /* get and set disklabel; DIOCGPART used internally */
                    254: #define DIOCGDINFO     _IOR('d', 101, struct disklabel)/* get */
                    255: #define DIOCSDINFO     _IOW('d', 102, struct disklabel)/* set */
                    256: #define DIOCWDINFO     _IOW('d', 103, struct disklabel)/* set, update disk */
                    257: #define DIOCGPART      _IOW('d', 104, struct partinfo) /* get partition */
                    258: 
                    259: /* do format operation, read or write */
                    260: #define DIOCRFORMAT    _IOWR('d', 105, struct format_op)
                    261: #define DIOCWFORMAT    _IOWR('d', 106, struct format_op)
                    262: 
                    263: #define DIOCSSTEP      _IOW('d', 107, int)     /* set step rate */
                    264: #define DIOCSRETRIES   _IOW('d', 108, int)     /* set # of retries */
                    265: #define DIOCWLABEL     _IOW('d', 109, int)     /* write en/disable label */
                    266: 
                    267: #define DIOCSBAD       _IOW('d', 110, struct dkbad)    /* set kernel dkbad */
                    268: 
                    269: #endif LOCORE
                    270: 
                    271: #if !defined(KERNEL) && !defined(LOCORE)
                    272: struct disklabel *getdiskbyname();
                    273: #endif

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.