/* $OpenBSD: sd_compat.c,v 1.4 1997/02/03 04:47:47 downsj Exp $ */ /* $NetBSD: sd_compat.c,v 1.5 1997/01/30 09:14:21 thorpej Exp $ */ /* * Copyright (c) 1990, 1993 * The Regents of the University of California. All rights reserved. * * This code is derived from software contributed to Berkeley by * Van Jacobson of Lawrence Berkeley Laboratory. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by the University of * California, Berkeley and its contributors. * 4. Neither the name of the University nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * @(#)sd_compat.c 8.1 (Berkeley) 6/10/93 */ /* * Compatibility for SCSI disks without labels. */ #include #include #include #include #include /* XXX */ #include /* XXX */ #include #include /* * Since the SCSI standard tends to hide the disk structure, we define * partitions in terms of DEV_BSIZE blocks. The default partition table * (for an unlabeled disk) reserves 512K for a boot area, has an 8 meg * root (A) and 32 meg of swap (B). The rest of the space on the drive * goes in the G partition. As usual, the C partition covers the entire * disk (including the boot area). * * We also define the D, E, F and H partitions as an alternative to B and G. * D is 48Mb, starts after A and is intended for swapping. * E is 50Mb, starts after D and is intended for /usr. * F starts after E and is what ever is left. * H starts after D and is what ever is left (i.e. combo of E and F). */ struct partition sddefaultpart[] = { { 16384, 1024, 1024, FS_BSDFFS, 8 }, { 65536, 17408, 0, FS_SWAP, 0 }, { 0, 0, 0, FS_BOOT, 0 }, { 98304, 17408, 0, FS_SWAP, 0 }, { 102400, 115712, 1024, FS_BSDFFS, 8 }, { 0, 218112, 1024, FS_BSDFFS, 8 }, { 0, 82944, 1024, FS_BSDFFS, 8 }, { 0, 115712, 1024, FS_BSDFFS, 8 } }; int sdnumdefaultpart = sizeof(sddefaultpart)/sizeof(sddefaultpart[0]); sdmakedisklabel(unit, lp) int unit; register struct disklabel *lp; { extern struct cfdriver sd_cd; struct sd_softc *sc = sd_cd.cd_devs[unit]; register struct partition *pi, *dpi; register int dcount; lp->d_secperunit = sc->sc_blks; lp->d_rpm = 3600; lp->d_interleave = 1; if (sc->sc_flags & SDF_RMEDIA) lp->d_flags |= D_REMOVABLE; lp->d_npartitions = sdnumdefaultpart; pi = lp->d_partitions; dpi = sddefaultpart; dcount = sdnumdefaultpart; while (dcount-- > 0) *pi++ = *dpi++; pi = lp->d_partitions; /* * C gets everything */ pi[2].p_size = sc->sc_blks; /* * G gets from end of B to end of disk */ pi[6].p_size = sc->sc_blks - pi[6].p_offset; /* * H gets from end of D to end of disk */ pi[7].p_size = sc->sc_blks - pi[7].p_offset; /* * If disk is big enough, define E and F */ if (sc->sc_blks > pi[5].p_offset) pi[5].p_size = sc->sc_blks - pi[5].p_offset; else { pi[4].p_offset = pi[4].p_size = 0; pi[5].p_offset = pi[5].p_size = 0; } }