summaryrefslogtreecommitdiffstats
path: root/sbin
diff options
context:
space:
mode:
authorphk <phk@FreeBSD.org>2003-04-13 21:57:08 +0000
committerphk <phk@FreeBSD.org>2003-04-13 21:57:08 +0000
commita9021891fc546a05ccda5639e9b06c6e1cfece8b (patch)
tree23dda90ce85edcbe387caf06bed9c8001194eea2 /sbin
parent08ad0d0b12b05574b3ca8dc82085cf761ced1cb6 (diff)
downloadFreeBSD-src-a9021891fc546a05ccda5639e9b06c6e1cfece8b.zip
FreeBSD-src-a9021891fc546a05ccda5639e9b06c6e1cfece8b.tar.gz
Use symbolic constants from <sys/diskmbr.h> instead of local constants.
Always set the magic sequence when we write, rather than trusting the previously read boot code to do so. Use explicit encoding/decoding of little endian disk image. Remove a comment which was OBE. Change the test vector for "fdisk -I" to reflect that there is a magic sequence in the result now. Add test case for "fdisk" which reads the image back. At least for the two test-cases this program now gives the same result on sparc64 as on i386. The lack of an installed /boot/mbr on sparc64 raises an (un)interesting question.
Diffstat (limited to 'sbin')
-rw-r--r--sbin/fdisk/fdisk.c28
-rw-r--r--sbin/fdisk/runtest.sh10
2 files changed, 23 insertions, 15 deletions
diff --git a/sbin/fdisk/fdisk.c b/sbin/fdisk/fdisk.c
index cea2317..35fb205 100644
--- a/sbin/fdisk/fdisk.c
+++ b/sbin/fdisk/fdisk.c
@@ -32,6 +32,7 @@ static const char rcsid[] =
#include <sys/disk.h>
#include <sys/disklabel.h>
#include <sys/diskmbr.h>
+#include <sys/endian.h>
#include <sys/param.h>
#include <sys/stat.h>
#include <sys/mount.h>
@@ -79,7 +80,7 @@ struct mboot {
unsigned char padding[2]; /* force the longs to be long aligned */
unsigned char *bootinst; /* boot code */
off_t bootinst_size;
- struct dos_partition parts[4];
+ struct dos_partition parts[NDOSPART];
};
static struct mboot mboot;
@@ -87,7 +88,6 @@ static int fd, fdw;
#define ACTIVE 0x80
-#define BOOT_MAGIC 0xAA55
static uint dos_cyls;
static uint dos_heads;
@@ -501,7 +501,7 @@ init_boot(void)
if ((mboot.bootinst = malloc(mboot.bootinst_size)) == NULL)
errx(1, "unable to allocate boot block buffer");
memset(mboot.bootinst, 0, mboot.bootinst_size);
- *(uint16_t *)(void *)&mboot.bootinst[MBRSIGOFF] = BOOT_MAGIC;
+ le16enc(&mboot.bootinst[DOSMAGICOFFSET], DOSMAGIC);
#endif
}
@@ -809,6 +809,8 @@ get_params()
static int
read_s0()
{
+ int i;
+
mboot.bootinst_size = secsize;
if (mboot.bootinst != NULL)
free(mboot.bootinst);
@@ -821,31 +823,31 @@ read_s0()
warnx("can't read fdisk partition table");
return -1;
}
- if (*(uint16_t *)(void *)&mboot.bootinst[MBRSIGOFF] != BOOT_MAGIC) {
+ if (le16dec(&mboot.bootinst[DOSMAGICOFFSET]) != DOSMAGIC) {
warnx("invalid fdisk partition table found");
/* So should we initialize things */
return -1;
}
- memcpy(mboot.parts, &mboot.bootinst[DOSPARTOFF], sizeof(mboot.parts));
+ for (i = 0; i < NDOSPART; i++)
+ dos_partition_dec(
+ &mboot.bootinst[DOSPARTOFF + i * DOSPARTSIZE],
+ &mboot.parts[i]);
return 0;
}
static int
write_s0()
{
- int sector;
+ int sector, i;
if (iotest) {
print_s0(-1);
return 0;
}
- memcpy(&mboot.bootinst[DOSPARTOFF], mboot.parts, sizeof(mboot.parts));
- /*
- * write enable label sector before write (if necessary),
- * disable after writing.
- * needed if the disklabel protected area also protects
- * sector 0. (e.g. empty disk)
- */
+ for(i = 0; i < NDOSPART; i++)
+ dos_partition_enc(&mboot.bootinst[DOSPARTOFF + i * DOSPARTSIZE],
+ &mboot.parts[i]);
+ le16enc(&mboot.bootinst[DOSMAGICOFFSET], DOSMAGIC);
for(sector = 0; sector < mboot.bootinst_size / secsize; sector++)
if (write_disk(sector,
&mboot.bootinst[sector * secsize]) == -1) {
diff --git a/sbin/fdisk/runtest.sh b/sbin/fdisk/runtest.sh
index 24ab20b..f25f427 100644
--- a/sbin/fdisk/runtest.sh
+++ b/sbin/fdisk/runtest.sh
@@ -16,9 +16,15 @@ dd if=/dev/zero of=tmp count=1 > /dev/null 2>&1
rm tmp
c=`dd if=/dev/${MD} count=1 2>/dev/null | md5`
-if [ $c != 509b44919d3921502bd31237c4bb1f75 ] ; then
- echo "FAILED: fdisk -I gives bad checksum" 1>&2
+if [ $c != ea4277fcccb6a927a1a497a6b15bfb8c ] ; then
+ echo "FAILED: 'fdisk -I' gives bad checksum ($c)" 1>&2
exit 1
fi
echo "PASSED: fdisk -I"
+c=`./fdisk $MD | md5`
+if [ $c != 4b126d7ac4c6b2af7ef27ede8ef102ec ] ; then
+ echo "FAILED: 'fdisk' gives bad checksum ($c)" 1>&2
+ exit 1
+fi
+echo "PASSED: fdisk"
exit 0
OpenPOWER on IntegriCloud