summaryrefslogtreecommitdiffstats
path: root/usr.bin/mkimg
diff options
context:
space:
mode:
authormarcel <marcel@FreeBSD.org>2014-10-03 20:48:11 +0000
committermarcel <marcel@FreeBSD.org>2014-10-03 20:48:11 +0000
commitad936aa7f4c00106fddfb0c8ef0e057b0fdb1a9f (patch)
treeaa30e6160da2363f94c57d30253e149d81bf5f84 /usr.bin/mkimg
parent5a6c8bb01b9c63a9f82583cd78595b13cc20d4d6 (diff)
downloadFreeBSD-src-ad936aa7f4c00106fddfb0c8ef0e057b0fdb1a9f.zip
FreeBSD-src-ad936aa7f4c00106fddfb0c8ef0e057b0fdb1a9f.tar.gz
Add mkimg_chs() for those schemes that need the LBA broken down into
cylinder, head and track numbers. Return ~0U for these values when mkimg wasn't given both -T and -H (i.e. no geometry) or the cylinder would be larger than the provided maximum. Use mkimgs_chs() for the EBR, MBR and PC98 schemes to fill in the appropriate fields. Make sure to use a "rounded" size so that the partition is always a multiple of the track size. We reserved the room for it in the metadata callback so that's a valid thing to do. Bump the mkimg version number. While doing that again: have mkimg.o depend on the Makefile so that a version change triggers a rebuild as needed.
Diffstat (limited to 'usr.bin/mkimg')
-rw-r--r--usr.bin/mkimg/Makefile4
-rw-r--r--usr.bin/mkimg/ebr.c22
-rw-r--r--usr.bin/mkimg/mbr.c16
-rw-r--r--usr.bin/mkimg/mkimg.c21
-rw-r--r--usr.bin/mkimg/mkimg.h2
-rw-r--r--usr.bin/mkimg/pc98.c14
6 files changed, 58 insertions, 21 deletions
diff --git a/usr.bin/mkimg/Makefile b/usr.bin/mkimg/Makefile
index 563ca58..28aac7d 100644
--- a/usr.bin/mkimg/Makefile
+++ b/usr.bin/mkimg/Makefile
@@ -6,7 +6,9 @@ PROG= mkimg
SRCS= format.c image.c mkimg.c scheme.c
MAN= mkimg.1
-MKIMG_VERSION=20141001
+MKIMG_VERSION=20141003
+mkimg.o: Makefile
+
CFLAGS+=-DMKIMG_VERSION=${MKIMG_VERSION}
CFLAGS+=-DSPARSE_WRITE
diff --git a/usr.bin/mkimg/ebr.c b/usr.bin/mkimg/ebr.c
index 43601cc..28931ea 100644
--- a/usr.bin/mkimg/ebr.c
+++ b/usr.bin/mkimg/ebr.c
@@ -58,12 +58,14 @@ ebr_metadata(u_int where, lba_t blk)
}
static void
-ebr_chs(u_char *cyl, u_char *hd, u_char *sec, uint32_t lba __unused)
+ebr_chs(u_char *cylp, u_char *hdp, u_char *secp, lba_t lba)
{
+ u_int cyl, hd, sec;
- *cyl = 0xff; /* XXX */
- *hd = 0xff; /* XXX */
- *sec = 0xff; /* XXX */
+ mkimg_chs(lba, 1023, &cyl, &hd, &sec);
+ *cylp = cyl;
+ *hdp = hd;
+ *secp = (sec & 0x3f) | ((cyl >> 2) & 0xc0);
}
static int
@@ -72,7 +74,7 @@ ebr_write(lba_t imgsz __unused, void *bootcode __unused)
u_char *ebr;
struct dos_partition *dp;
struct part *part, *next;
- lba_t block;
+ lba_t block, size;
int error;
ebr = malloc(secsz);
@@ -84,24 +86,26 @@ ebr_write(lba_t imgsz __unused, void *bootcode __unused)
error = 0;
STAILQ_FOREACH_SAFE(part, &partlist, link, next) {
block = part->block - nsecs;
+ size = round_track(part->size);
dp = (void *)(ebr + DOSPARTOFF);
ebr_chs(&dp->dp_scyl, &dp->dp_shd, &dp->dp_ssect, nsecs);
dp->dp_typ = ALIAS_TYPE2INT(part->type);
ebr_chs(&dp->dp_ecyl, &dp->dp_ehd, &dp->dp_esect,
- part->block + part->size - 1);
+ part->block + size - 1);
le32enc(&dp->dp_start, nsecs);
- le32enc(&dp->dp_size, part->size);
+ le32enc(&dp->dp_size, size);
/* Add link entry */
if (next != NULL) {
+ size = round_track(next->size);
dp++;
ebr_chs(&dp->dp_scyl, &dp->dp_shd, &dp->dp_ssect,
next->block - nsecs);
dp->dp_typ = DOSPTYP_EXT;
ebr_chs(&dp->dp_ecyl, &dp->dp_ehd, &dp->dp_esect,
- next->block + next->size - 1);
+ next->block + size - 1);
le32enc(&dp->dp_start, next->block - nsecs);
- le32enc(&dp->dp_size, next->size + nsecs);
+ le32enc(&dp->dp_size, size + nsecs);
}
error = image_write(block, ebr, 1);
diff --git a/usr.bin/mkimg/mbr.c b/usr.bin/mkimg/mbr.c
index e9c2aef..c1b7822 100644
--- a/usr.bin/mkimg/mbr.c
+++ b/usr.bin/mkimg/mbr.c
@@ -59,12 +59,14 @@ mbr_metadata(u_int where, lba_t blk)
}
static void
-mbr_chs(u_char *cyl, u_char *hd, u_char *sec, uint32_t lba __unused)
+mbr_chs(u_char *cylp, u_char *hdp, u_char *secp, lba_t lba)
{
+ u_int cyl, hd, sec;
- *cyl = 0xff; /* XXX */
- *hd = 0xff; /* XXX */
- *sec = 0xff; /* XXX */
+ mkimg_chs(lba, 1023, &cyl, &hd, &sec);
+ *cylp = cyl;
+ *hdp = hd;
+ *secp = (sec & 0x3f) | ((cyl >> 2) & 0xc0);
}
static int
@@ -73,6 +75,7 @@ mbr_write(lba_t imgsz __unused, void *bootcode)
u_char *mbr;
struct dos_partition *dpbase, *dp;
struct part *part;
+ lba_t size;
int error;
mbr = malloc(secsz);
@@ -86,15 +89,16 @@ mbr_write(lba_t imgsz __unused, void *bootcode)
le16enc(mbr + DOSMAGICOFFSET, DOSMAGIC);
dpbase = (void *)(mbr + DOSPARTOFF);
STAILQ_FOREACH(part, &partlist, link) {
+ size = round_track(part->size);
dp = dpbase + part->index;
dp->dp_flag = (part->index == 0 && bootcode != NULL) ? 0x80 : 0;
mbr_chs(&dp->dp_scyl, &dp->dp_shd, &dp->dp_ssect,
part->block);
dp->dp_typ = ALIAS_TYPE2INT(part->type);
mbr_chs(&dp->dp_ecyl, &dp->dp_ehd, &dp->dp_esect,
- part->block + part->size - 1);
+ part->block + size - 1);
le32enc(&dp->dp_start, part->block);
- le32enc(&dp->dp_size, part->size);
+ le32enc(&dp->dp_size, size);
}
error = image_write(0, mbr, 1);
free(mbr);
diff --git a/usr.bin/mkimg/mkimg.c b/usr.bin/mkimg/mkimg.c
index d054423..b55ee7e 100644
--- a/usr.bin/mkimg/mkimg.c
+++ b/usr.bin/mkimg/mkimg.c
@@ -340,6 +340,27 @@ sparse_write(int fd, const void *ptr, size_t sz)
#endif /* SPARSE_WRITE */
void
+mkimg_chs(lba_t lba, u_int maxcyl, u_int *cylp, u_int *hdp, u_int *secp)
+{
+ u_int hd, sec;
+
+ *cylp = *hdp = *secp = ~0U;
+ if (nsecs == 1 || nheads == 1)
+ return;
+
+ sec = lba % nsecs + 1;
+ lba /= nsecs;
+ hd = lba % nheads;
+ lba /= nheads;
+ if (lba > maxcyl)
+ return;
+
+ *cylp = lba;
+ *hdp = hd;
+ *secp = sec;
+}
+
+void
mkimg_uuid(struct uuid *uuid)
{
static uint8_t gen[sizeof(struct uuid)];
diff --git a/usr.bin/mkimg/mkimg.h b/usr.bin/mkimg/mkimg.h
index 7a78034..281beeb 100644
--- a/usr.bin/mkimg/mkimg.h
+++ b/usr.bin/mkimg/mkimg.h
@@ -87,6 +87,8 @@ round_track(lba_t n)
ssize_t sparse_write(int, const void *, size_t);
#endif
+void mkimg_chs(lba_t, u_int, u_int *, u_int *, u_int *);
+
struct uuid;
void mkimg_uuid(struct uuid *);
diff --git a/usr.bin/mkimg/pc98.c b/usr.bin/mkimg/pc98.c
index 56acb1e..2db0394 100644
--- a/usr.bin/mkimg/pc98.c
+++ b/usr.bin/mkimg/pc98.c
@@ -68,12 +68,14 @@ pc98_metadata(u_int where, lba_t blk)
}
static void
-pc98_chs(u_short *cyl, u_char *hd, u_char *sec, uint32_t lba __unused)
+pc98_chs(u_short *cylp, u_char *hdp, u_char *secp, lba_t lba)
{
+ u_int cyl, hd, sec;
- *cyl = 0xffff; /* XXX */
- *hd = 0xff; /* XXX */
- *sec = 0xff; /* XXX */
+ mkimg_chs(lba, 0xffff, &cyl, &hd, &sec);
+ le16enc(cylp, cyl);
+ *hdp = hd;
+ *secp = sec;
}
static int
@@ -82,6 +84,7 @@ pc98_write(lba_t imgsz __unused, void *bootcode)
struct part *part;
struct pc98_partition *dpbase, *dp;
u_char *buf;
+ lba_t size;
int error, ptyp;
buf = malloc(PC98_BOOTCODESZ);
@@ -95,6 +98,7 @@ pc98_write(lba_t imgsz __unused, void *bootcode)
le16enc(buf + PC98_MAGICOFS, PC98_MAGIC);
dpbase = (void *)(buf + secsz);
STAILQ_FOREACH(part, &partlist, link) {
+ size = round_track(part->size);
dp = dpbase + part->index;
ptyp = ALIAS_TYPE2INT(part->type);
dp->dp_mid = ptyp;
@@ -102,7 +106,7 @@ pc98_write(lba_t imgsz __unused, void *bootcode)
pc98_chs(&dp->dp_scyl, &dp->dp_shd, &dp->dp_ssect,
part->block);
pc98_chs(&dp->dp_scyl, &dp->dp_shd, &dp->dp_ssect,
- part->block + part->size - 1);
+ part->block + size - 1);
if (part->label != NULL)
memcpy(dp->dp_name, part->label, strlen(part->label));
}
OpenPOWER on IntegriCloud