summaryrefslogtreecommitdiff
path: root/sys/arch/sgi/stand/sgivol/sgivol.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/sgi/stand/sgivol/sgivol.c')
-rw-r--r--sys/arch/sgi/stand/sgivol/sgivol.c138
1 files changed, 72 insertions, 66 deletions
diff --git a/sys/arch/sgi/stand/sgivol/sgivol.c b/sys/arch/sgi/stand/sgivol/sgivol.c
index d2d2f640ee0..b522c3f8a7d 100644
--- a/sys/arch/sgi/stand/sgivol/sgivol.c
+++ b/sys/arch/sgi/stand/sgivol/sgivol.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sgivol.c,v 1.3 2004/11/08 21:24:46 miod Exp $ */
+/* $OpenBSD: sgivol.c,v 1.4 2005/04/27 07:13:41 deraadt Exp $ */
/* $NetBSD: sgivol.c,v 1.8 2003/11/08 04:59:00 sekiya Exp $ */
/*-
@@ -63,65 +63,65 @@
#define SGI_SIZE_VOLHDR 3135 /* Can be overridden via -h parameter */
struct local_devparms {
- u_int8_t dp_skew;
- u_int8_t dp_gap1;
- u_int8_t dp_gap2;
- u_int8_t dp_spares_cyl;
- u_int16_t dp_cyls;
- u_int16_t dp_shd0;
- u_int16_t dp_trks0;
- u_int8_t dp_ctq_depth;
- u_int8_t dp_cylshi;
- u_int16_t dp_unused;
- u_int16_t dp_secs;
- u_int16_t dp_secbytes;
- u_int16_t dp_interleave;
- u_int32_t dp_flags;
- u_int32_t dp_datarate;
- u_int32_t dp_nretries;
- u_int32_t dp_mspw;
- u_int16_t dp_xgap1;
- u_int16_t dp_xsync;
- u_int16_t dp_xrdly;
- u_int16_t dp_xgap2;
- u_int16_t dp_xrgate;
- u_int16_t dp_xwcont;
+ u_int8_t dp_skew;
+ u_int8_t dp_gap1;
+ u_int8_t dp_gap2;
+ u_int8_t dp_spares_cyl;
+ u_int16_t dp_cyls;
+ u_int16_t dp_shd0;
+ u_int16_t dp_trks0;
+ u_int8_t dp_ctq_depth;
+ u_int8_t dp_cylshi;
+ u_int16_t dp_unused;
+ u_int16_t dp_secs;
+ u_int16_t dp_secbytes;
+ u_int16_t dp_interleave;
+ u_int32_t dp_flags;
+ u_int32_t dp_datarate;
+ u_int32_t dp_nretries;
+ u_int32_t dp_mspw;
+ u_int16_t dp_xgap1;
+ u_int16_t dp_xsync;
+ u_int16_t dp_xrdly;
+ u_int16_t dp_xgap2;
+ u_int16_t dp_xrgate;
+ u_int16_t dp_xwcont;
} __packed;
#define SGI_SIZE_VOLDIR 15
struct local_sgilabel {
#define SGILABEL_MAGIC 0xbe5a941
- u_int32_t magic;
- int16_t root;
- int16_t swap;
- char bootfile[16];
+ u_int32_t magic;
+ int16_t root;
+ int16_t swap;
+ char bootfile[16];
struct local_devparms dp;
struct {
- char name[8];
- int32_t block;
- int32_t bytes;
- } voldir[SGI_SIZE_VOLDIR];
+ char name[8];
+ int32_t block;
+ int32_t bytes;
+ } voldir[SGI_SIZE_VOLDIR];
struct {
- int32_t blocks;
- int32_t first;
- int32_t type;
- } partitions[MAXPARTITIONS];
- int32_t checksum;
- int32_t _pad;
+ int32_t blocks;
+ int32_t first;
+ int32_t type;
+ } partitions[MAXPARTITIONS];
+ int32_t checksum;
+ int32_t _pad;
} __packed;
-#define SGI_PTYPE_VOLHDR 0
-#define SGI_PTYPE_RAW 3
-#define SGI_PTYPE_BSD 4
-#define SGI_PTYPE_VOLUME 6
-#define SGI_PTYPE_EFS 7
-#define SGI_PTYPE_LVOL 8
-#define SGI_PTYPE_RLVOL 9
-#define SGI_PTYPE_XFS 10
-#define SGI_PTYPE_XFSLOG 11
-#define SGI_PTYPE_XLV 12
-#define SGI_PTYPE_XVM 13
+#define SGI_PTYPE_VOLHDR 0
+#define SGI_PTYPE_RAW 3
+#define SGI_PTYPE_BSD 4
+#define SGI_PTYPE_VOLUME 6
+#define SGI_PTYPE_EFS 7
+#define SGI_PTYPE_LVOL 8
+#define SGI_PTYPE_RLVOL 9
+#define SGI_PTYPE_XFS 10
+#define SGI_PTYPE_XFSLOG 11
+#define SGI_PTYPE_XLV 12
+#define SGI_PTYPE_XVM 13
int fd;
int opt_i; /* Initialize volume header */
@@ -258,7 +258,7 @@ main(int argc, char *argv[])
}
if (argc != 1)
usage();
-
+
fd = open(argv[0], (opt_i | opt_w | opt_d | opt_p) ? O_RDWR : O_RDONLY);
if (fd < 0) {
snprintf(buf, sizeof(buf), "/dev/r%s%c",
@@ -277,7 +277,7 @@ main(int argc, char *argv[])
exit(0);
}
if (betoh32(volhdr->magic) != SGILABEL_MAGIC)
- errx(2, "no Volume Header found, magic=%x. Use -i first.",
+ errx(2, "no Volume Header found, magic=%x. Use -i first.",
betoh32(volhdr->magic));
if (opt_r) {
read_file();
@@ -326,7 +326,7 @@ display_vol(void)
betoh32(volhdr->voldir[i].block),
betoh32(volhdr->voldir[i].bytes),
howmany(betoh32(volhdr->voldir[i].bytes),
- DEV_BSIZE));
+ DEV_BSIZE));
}
}
printf("\nSGI partitions:\n");
@@ -337,9 +337,9 @@ display_vol(void)
betoh32(volhdr->partitions[i].first),
betoh32(volhdr->partitions[i].type),
betoh32(volhdr->partitions[i].type) >
- (sizeof(sgi_types) / sizeof(sgi_types[0])) ?
- "???" :
- sgi_types[betoh32(volhdr->partitions[i].type)]);
+ (sizeof(sgi_types) / sizeof(sgi_types[0])) ?
+ "???" :
+ sgi_types[betoh32(volhdr->partitions[i].type)]);
}
}
}
@@ -384,7 +384,7 @@ read_file(void)
printf("Reading file %s\n", vfilename);
for (i = 0; i < SGI_SIZE_VOLDIR; ++i) {
if (strncmp(vfilename, volhdr->voldir[i].name,
- strlen(volhdr->voldir[i].name)) == 0)
+ strlen(volhdr->voldir[i].name)) == 0)
break;
}
if (i >= SGI_SIZE_VOLDIR)
@@ -434,8 +434,8 @@ write_file(void)
/* -w can overwrite, -a won't overwrite */
if (betoh32(volhdr->voldir[slot].block) > 0) {
if (!opt_q)
- printf("File %s exists, removing old file\n",
- vfilename);
+ printf("File %s exists, removing old file\n",
+ vfilename);
volhdr->voldir[slot].name[0] = 0;
volhdr->voldir[slot].block = volhdr->voldir[slot].bytes = 0;
}
@@ -450,7 +450,7 @@ write_file(void)
*/
if (strlen(vfilename) > sizeof(volhdr->voldir[slot].name))
warnx("%s: filename is too long and will be truncated",
- vfilename);
+ vfilename);
strncpy(volhdr->voldir[slot].name, vfilename,
sizeof(volhdr->voldir[slot].name));
@@ -495,7 +495,7 @@ void
modify_partition(void)
{
if (!opt_q)
- printf("Modify partition %d start %d length %d\n",
+ printf("Modify partition %d start %d length %d\n",
partno, partfirst, partblocks);
volhdr->partitions[partno].blocks = htobe32(partblocks);
volhdr->partitions[partno].first = htobe32(partfirst);
@@ -536,16 +536,22 @@ allocate_space(int size)
if (volhdr->voldir[n].name[0]) {
if (first < (betoh32(volhdr->voldir[n].block) +
howmany(betoh32(volhdr->voldir[n].bytes),
- DEV_BSIZE)) &&
+ DEV_BSIZE)) &&
(first + blocks) > betoh32(volhdr->voldir[n].block)) {
first = betoh32(volhdr->voldir[n].block) +
howmany(betoh32(volhdr->voldir[n].bytes),
- DEV_BSIZE);
+ DEV_BSIZE);
#if 0
- printf("allocate: n=%d first=%d blocks=%d size=%d\n", n, first, blocks, size);
- printf("%s %d %d\n", volhdr->voldir[n].name, volhdr->voldir[n].block, volhdr->voldir[n].bytes);
- printf("first=%d block=%d last=%d end=%d\n", first, volhdr->voldir[n].block,
- first + blocks - 1, volhdr->voldir[n].block + howmany(volhdr->voldir[n].bytes, DEV_BSIZE));
+ printf("allocate: n=%d first=%d blocks=%d size=%d\n",
+ n, first, blocks, size);
+ printf("%s %d %d\n", volhdr->voldir[n].name,
+ volhdr->voldir[n].block,
+ volhdr->voldir[n].bytes);
+ printf("first=%d block=%d last=%d end=%d\n",
+ first, volhdr->voldir[n].block,
+ first + blocks - 1,
+ volhdr->voldir[n].block +
+ howmany(volhdr->voldir[n].bytes, DEV_BSIZE));
#endif
n = 0;
continue;