summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMax Maisel <max.maisel@posteo.de>2018-03-01 17:16:18 +0100
committerMax Maisel <max.maisel@posteo.de>2018-03-01 17:58:28 +0100
commitb0ddedb220094550e28184c1473db69d38421430 (patch)
tree2a54000e11d6f2b1e1d0bb57b5f69ab8ca7c5aee /src
parent2d9c5b5d776dcaa543b4a37f738617dfca64fff1 (diff)
ext4-mbr-write: Fixed partition size calculation
Diffstat (limited to 'src')
-rw-r--r--src/ext4_mbr.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/ext4_mbr.c b/src/ext4_mbr.c
index 7cbbe89..14fe252 100644
--- a/src/ext4_mbr.c
+++ b/src/ext4_mbr.c
@@ -129,7 +129,7 @@ int ext4_mbr_scan(struct ext4_blockdev *parent, struct ext4_mbr_bdevs *bdevs)
int ext4_mbr_write(struct ext4_blockdev *parent, struct ext4_mbr_parts *parts)
{
int r;
- uint64_t disk_size = parent->part_size;
+ uint64_t disk_size;
uint32_t division_sum = parts->division[0] + parts->division[1] +
parts->division[2] + parts->division[3];
@@ -141,6 +141,8 @@ int ext4_mbr_write(struct ext4_blockdev *parent, struct ext4_mbr_parts *parts)
if (r != EOK)
return r;
+ disk_size = parent->part_size;
+
/*Calculate CHS*/
uint32_t k = 16;
while ((k < 256) && ((disk_size / k / 63) > 1024))
@@ -167,7 +169,7 @@ int ext4_mbr_write(struct ext4_blockdev *parent, struct ext4_mbr_parts *parts)
if (i == 0) {
part_start += 63;
- part_size -= 63;
+ part_size -= 63 * parent->bdif->ph_bsize;
}
uint32_t cyl_end = cyl_part + cyl_it - 1;
@@ -182,7 +184,7 @@ int ext4_mbr_write(struct ext4_blockdev *parent, struct ext4_mbr_parts *parts)
mbr->part_entry[i].chs2[2] = cyl_end;
mbr->part_entry[i].first_lba = part_start;
- mbr->part_entry[i].sectors = part_size;
+ mbr->part_entry[i].sectors = part_size / parent->bdif->ph_bsize;
cyl_it += cyl_part;
}