1*63df928bSapb /* $NetBSD: printlabel.c,v 1.16 2011/01/06 21:39:01 apb Exp $ */
21c5cb88eSlukem
31c5cb88eSlukem /*
41c5cb88eSlukem * Copyright (c) 1987, 1993
51c5cb88eSlukem * The Regents of the University of California. All rights reserved.
61c5cb88eSlukem *
71c5cb88eSlukem * This code is derived from software contributed to Berkeley by
81c5cb88eSlukem * Symmetric Computer Systems.
91c5cb88eSlukem *
101c5cb88eSlukem * Redistribution and use in source and binary forms, with or without
111c5cb88eSlukem * modification, are permitted provided that the following conditions
121c5cb88eSlukem * are met:
131c5cb88eSlukem * 1. Redistributions of source code must retain the above copyright
141c5cb88eSlukem * notice, this list of conditions and the following disclaimer.
151c5cb88eSlukem * 2. Redistributions in binary form must reproduce the above copyright
161c5cb88eSlukem * notice, this list of conditions and the following disclaimer in the
171c5cb88eSlukem * documentation and/or other materials provided with the distribution.
18bf07c871Sagc * 3. Neither the name of the University nor the names of its contributors
191c5cb88eSlukem * may be used to endorse or promote products derived from this software
201c5cb88eSlukem * without specific prior written permission.
211c5cb88eSlukem *
221c5cb88eSlukem * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
231c5cb88eSlukem * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
241c5cb88eSlukem * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
251c5cb88eSlukem * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
261c5cb88eSlukem * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
271c5cb88eSlukem * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
281c5cb88eSlukem * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
291c5cb88eSlukem * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
301c5cb88eSlukem * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
311c5cb88eSlukem * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
321c5cb88eSlukem * SUCH DAMAGE.
331c5cb88eSlukem */
341c5cb88eSlukem
351726c417Sdyoung #if HAVE_NBTOOL_CONFIG_H
361726c417Sdyoung #include "nbtool_config.h"
371726c417Sdyoung #endif
381726c417Sdyoung
391c5cb88eSlukem #include <sys/cdefs.h>
401c5cb88eSlukem #ifndef lint
41*63df928bSapb __RCSID("$NetBSD: printlabel.c,v 1.16 2011/01/06 21:39:01 apb Exp $");
421c5cb88eSlukem #endif /* not lint */
431c5cb88eSlukem
441c5cb88eSlukem #include <sys/param.h>
451c5cb88eSlukem
461c5cb88eSlukem #define DKTYPENAMES
471c5cb88eSlukem #define FSTYPENAMES
481726c417Sdyoung #if HAVE_NBTOOL_CONFIG_H
491726c417Sdyoung #include <nbinclude/sys/disklabel.h>
501726c417Sdyoung #else
511c5cb88eSlukem #include <sys/disklabel.h>
521726c417Sdyoung #endif /* HAVE_NBTOOL_CONFIG_H */
531c5cb88eSlukem
541c5cb88eSlukem #include <stdio.h>
551c5cb88eSlukem
561c5cb88eSlukem #include "extern.h"
571c5cb88eSlukem
581c5cb88eSlukem
591c5cb88eSlukem void
showinfo(FILE * f,struct disklabel * lp,const char * specialname)6080644903Slukem showinfo(FILE *f, struct disklabel *lp, const char *specialname)
611c5cb88eSlukem {
621c5cb88eSlukem int i, j;
631c5cb88eSlukem
6480644903Slukem (void)fprintf(f, "# %s:\n", specialname);
651c5cb88eSlukem if ((unsigned) lp->d_type < DKMAXTYPES)
661c5cb88eSlukem (void)fprintf(f, "type: %s\n", dktypenames[lp->d_type]);
671c5cb88eSlukem else
68*63df928bSapb (void)fprintf(f, "type: %" PRIu16 "\n", lp->d_type);
691c5cb88eSlukem (void)fprintf(f, "disk: %.*s\n", (int) sizeof(lp->d_typename),
701c5cb88eSlukem lp->d_typename);
711c5cb88eSlukem (void)fprintf(f, "label: %.*s\n", (int) sizeof(lp->d_packname),
721c5cb88eSlukem lp->d_packname);
731c5cb88eSlukem (void)fprintf(f, "flags:");
741c5cb88eSlukem if (lp->d_flags & D_REMOVABLE)
751c5cb88eSlukem (void)fprintf(f, " removable");
761c5cb88eSlukem if (lp->d_flags & D_ECC)
771c5cb88eSlukem (void)fprintf(f, " ecc");
781c5cb88eSlukem if (lp->d_flags & D_BADSECT)
791c5cb88eSlukem (void)fprintf(f, " badsect");
801c5cb88eSlukem (void)fprintf(f, "\n");
817d06c8beSdsl (void)fprintf(f, "bytes/sector: %" PRIu32 "\n", lp->d_secsize);
827d06c8beSdsl (void)fprintf(f, "sectors/track: %" PRIu32 "\n", lp->d_nsectors);
837d06c8beSdsl (void)fprintf(f, "tracks/cylinder: %" PRIu32 "\n", lp->d_ntracks);
847d06c8beSdsl (void)fprintf(f, "sectors/cylinder: %" PRIu32 "\n", lp->d_secpercyl);
857d06c8beSdsl (void)fprintf(f, "cylinders: %" PRIu32 "\n", lp->d_ncylinders);
867d06c8beSdsl (void)fprintf(f, "total sectors: %" PRIu32 "\n", lp->d_secperunit);
877d06c8beSdsl (void)fprintf(f, "rpm: %" PRIu32 "\n", lp->d_rpm);
887d06c8beSdsl (void)fprintf(f, "interleave: %" PRIu32 "\n", lp->d_interleave);
897d06c8beSdsl (void)fprintf(f, "trackskew: %" PRIu32 "\n", lp->d_trackskew);
907d06c8beSdsl (void)fprintf(f, "cylinderskew: %" PRIu32 "\n", lp->d_cylskew);
917d06c8beSdsl (void)fprintf(f, "headswitch: %" PRIu32 "\t\t# microseconds\n",
927d06c8beSdsl lp->d_headswitch);
937d06c8beSdsl (void)fprintf(f, "track-to-track seek: %" PRIu32 "\t# microseconds\n",
947d06c8beSdsl lp->d_trkseek);
951c5cb88eSlukem (void)fprintf(f, "drivedata: ");
961c5cb88eSlukem for (i = NDDATA - 1; i >= 0; i--)
971c5cb88eSlukem if (lp->d_drivedata[i])
981c5cb88eSlukem break;
991c5cb88eSlukem if (i < 0)
1001c5cb88eSlukem i = 0;
1011c5cb88eSlukem for (j = 0; j <= i; j++)
102*63df928bSapb (void)fprintf(f, "%" PRIu32 " ", lp->d_drivedata[j]);
1031c5cb88eSlukem (void)fprintf(f, "\n\n");
1041c5cb88eSlukem (void)fflush(f);
1051c5cb88eSlukem }
1061c5cb88eSlukem
1071c5cb88eSlukem void
showpartition(FILE * f,struct disklabel * lp,int i,int ctsformat)10879569512Schristos showpartition(FILE *f, struct disklabel *lp, int i, int ctsformat)
1091c5cb88eSlukem {
11079569512Schristos struct partition *pp = lp->d_partitions + i;
11179569512Schristos if (pp->p_size == 0)
11279569512Schristos return;
1131c5cb88eSlukem
1141c5cb88eSlukem if (ctsformat && lp->d_secpercyl && lp->d_nsectors) {
11579569512Schristos char sbuf[64], obuf[64];
11679569512Schristos
117*63df928bSapb (void)snprintf(sbuf, sizeof(sbuf),
118*63df928bSapb "%" PRIu32 "/%" PRIu32 "/%" PRIu32,
1191c5cb88eSlukem pp->p_size/lp->d_secpercyl,
12079569512Schristos (pp->p_size%lp->d_secpercyl) / lp->d_nsectors,
1211c5cb88eSlukem pp->p_size%lp->d_nsectors);
1221c5cb88eSlukem
123*63df928bSapb (void)snprintf(obuf, sizeof(obuf),
124*63df928bSapb "%" PRIu32 "/%" PRIu32 "/%" PRIu32,
1251c5cb88eSlukem pp->p_offset/lp->d_secpercyl,
12679569512Schristos (pp->p_offset%lp->d_secpercyl) / lp->d_nsectors,
1271c5cb88eSlukem pp->p_offset%lp->d_nsectors);
12879569512Schristos
12979569512Schristos (void)fprintf(f, " %c: %9s %9s ",
1301c5cb88eSlukem 'a' + i, sbuf, obuf);
13179569512Schristos } else {
132*63df928bSapb (void)fprintf(f, " %c: %9" PRIu32 " %9" PRIu32 " ",
133*63df928bSapb 'a' + i, pp->p_size, pp->p_offset);
13479569512Schristos }
13579569512Schristos
1361c5cb88eSlukem if ((unsigned) pp->p_fstype < FSMAXTYPES)
13779569512Schristos (void)fprintf(f, "%10.10s", fstypenames[pp->p_fstype]);
1381c5cb88eSlukem else
139*63df928bSapb (void)fprintf(f, "%10" PRIu8, pp->p_fstype);
1401c5cb88eSlukem
14179569512Schristos switch (pp->p_fstype) {
1421c5cb88eSlukem case FS_UNUSED: /* XXX */
143*63df928bSapb (void)fprintf(f, " %5" PRIu32 " %5" PRIu64 " %5.5s ",
144*63df928bSapb pp->p_fsize, (uint64_t)pp->p_fsize * pp->p_frag, "");
1451c5cb88eSlukem break;
1461c5cb88eSlukem
1471c5cb88eSlukem case FS_BSDFFS:
1481c5cb88eSlukem case FS_ADOS:
149a323eac3Sdbj case FS_APPLEUFS:
150*63df928bSapb (void)fprintf(f, " %5" PRIu32 " %5" PRIu64 " %5" PRIu16 " ",
151*63df928bSapb pp->p_fsize, (uint64_t)pp->p_fsize * pp->p_frag, pp->p_cpg);
1521c5cb88eSlukem break;
1531c5cb88eSlukem
1541c5cb88eSlukem case FS_BSDLFS:
155*63df928bSapb (void)fprintf(f, " %5" PRIu32 " %5" PRIu64 " %5" PRIu16 " ",
156*63df928bSapb pp->p_fsize, (uint64_t)pp->p_fsize * pp->p_frag, pp->p_sgs);
1571c5cb88eSlukem break;
1581c5cb88eSlukem
1591c5cb88eSlukem case FS_EX2FS:
160*63df928bSapb (void)fprintf(f, " %5" PRIu32 " %5" PRIu64 " ",
161*63df928bSapb pp->p_fsize, (uint64_t)pp->p_fsize * pp->p_frag);
1621c5cb88eSlukem break;
1631c5cb88eSlukem
164ec943f31Sdrochner case FS_ISO9660:
165*63df928bSapb (void)fprintf(f, " %6" PRIu32 " ",
166*63df928bSapb pp->p_cdsession);
167ec943f31Sdrochner break;
168ec943f31Sdrochner
1691c5cb88eSlukem default:
17079569512Schristos (void)fprintf(f, "%20.20s", "");
1711c5cb88eSlukem break;
1721c5cb88eSlukem }
1731c5cb88eSlukem if (lp->d_secpercyl != 0) {
174*63df928bSapb (void)fprintf(f, " # (Cyl. %6" PRIu32,
1751c5cb88eSlukem pp->p_offset / lp->d_secpercyl);
17679569512Schristos
177dbc3f179Sjdc if (pp->p_offset > lp->d_secperunit)
178dbc3f179Sjdc putc('+', f);
179dbc3f179Sjdc else if (pp->p_offset % lp->d_secpercyl)
1801c5cb88eSlukem putc('*', f);
1811c5cb88eSlukem else
1821c5cb88eSlukem putc(' ', f);
18379569512Schristos
184*63df928bSapb (void)fprintf(f, "- %6" PRIu32,
1851c5cb88eSlukem (pp->p_offset +
1861c5cb88eSlukem pp->p_size + lp->d_secpercyl - 1) /
1871c5cb88eSlukem lp->d_secpercyl - 1);
18879569512Schristos
189dbc3f179Sjdc if ((pp->p_offset + pp->p_size) > lp->d_secperunit)
190dbc3f179Sjdc putc('+', f);
191dbc3f179Sjdc else if ((pp->p_offset + pp->p_size) % lp->d_secpercyl)
1921c5cb88eSlukem putc('*', f);
19379569512Schristos
1941c5cb88eSlukem (void)fprintf(f, ")\n");
1951c5cb88eSlukem } else
1961c5cb88eSlukem (void)fprintf(f, "\n");
1971c5cb88eSlukem }
19879569512Schristos
19979569512Schristos void
showpartitions(FILE * f,struct disklabel * lp,int ctsformat)20079569512Schristos showpartitions(FILE *f, struct disklabel *lp, int ctsformat)
20179569512Schristos {
20279569512Schristos int i;
20379569512Schristos
204*63df928bSapb (void)fprintf(f, "%" PRIu16 " partitions:\n", lp->d_npartitions);
20579569512Schristos (void)fprintf(f,
20679569512Schristos "# size offset fstype [fsize bsize cpg/sgs]\n");
20779569512Schristos
20879569512Schristos for (i = 0; i < lp->d_npartitions; i++)
20979569512Schristos showpartition(f, lp, i, ctsformat);
2101c5cb88eSlukem (void)fflush(f);
2111c5cb88eSlukem }
212