summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorMarco Peereboom <marco@cvs.openbsd.org>2007-04-21 23:22:43 +0000
committerMarco Peereboom <marco@cvs.openbsd.org>2007-04-21 23:22:43 +0000
commitf87c1ce3f3c538ce06a5851d85f86d0ad18ceef8 (patch)
tree36a297c5ee242cfb2b93da6a91b1758dc9941add /sys/dev
parentf0ad0e23481cd28bfe28ae749f36211812173433 (diff)
Account for mbr and partition table when writing meta data.
Error report by Johan Mson Lindman <tybollt@solace.miun.se>
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/softraid.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/sys/dev/softraid.c b/sys/dev/softraid.c
index ff6f7575c81..62781bc637a 100644
--- a/sys/dev/softraid.c
+++ b/sys/dev/softraid.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: softraid.c,v 1.26 2007/04/21 23:05:19 marco Exp $ */
+/* $OpenBSD: softraid.c,v 1.27 2007/04/21 23:22:42 marco Exp $ */
/*
* Copyright (c) 2007 Marco Peereboom <marco@peereboom.us>
*
@@ -1081,8 +1081,9 @@ sr_raid1_alloc_resources(struct sr_discipline *sd)
sr_alloc_wu(sd);
sr_alloc_ccb(sd);
- sd->sd_meta = malloc(SR_META_SIZE * 512 , M_DEVBUF, M_WAITOK);
- bzero(sd->sd_meta, SR_META_SIZE * 512);
+ /* -2 because that includes mbr and partition table */
+ sd->sd_meta = malloc((SR_META_SIZE - 2) * 512 , M_DEVBUF, M_WAITOK);
+ bzero(sd->sd_meta, (SR_META_SIZE - 2) * 512);
rv = 0;
return (rv);
@@ -1775,7 +1776,7 @@ sr_save_metadata(struct sr_discipline *sd)
struct sr_chunk *src;
struct buf b;
int i, rv = 1;
- size_t sz = SR_META_SIZE * 512;
+ size_t sz = (SR_META_SIZE - 2) * 512;
DNPRINTF(SR_D_META, "%s: sr_save_metadata %s\n",
DEVNAME(sc), sd->sd_vol.sv_meta.svm_devname);