diff options
author | Marco Peereboom <marco@cvs.openbsd.org> | 2007-04-21 23:50:48 +0000 |
---|---|---|
committer | Marco Peereboom <marco@cvs.openbsd.org> | 2007-04-21 23:50:48 +0000 |
commit | b6ef44e34bde72b36d1eb9bcdc2f69b38a9e3e73 (patch) | |
tree | e746ebfdaa1e466a1640c2412518f01c1a0615ec | |
parent | 94a1a90d0d01ca5fce782e7d27fe9cae9423cf5a (diff) |
Make sure we don't write too much metadata.
-rw-r--r-- | sys/dev/softraid.c | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/sys/dev/softraid.c b/sys/dev/softraid.c index e8c17390e01..501fe5a1670 100644 --- a/sys/dev/softraid.c +++ b/sys/dev/softraid.c @@ -1,4 +1,4 @@ -/* $OpenBSD: softraid.c,v 1.28 2007/04/21 23:39:18 marco Exp $ */ +/* $OpenBSD: softraid.c,v 1.29 2007/04/21 23:50:47 marco Exp $ */ /* * Copyright (c) 2007 Marco Peereboom <marco@peereboom.us> * @@ -1789,6 +1789,14 @@ sr_save_metadata(struct sr_discipline *sd) im_sv = (struct sr_vol_meta *)(sm + 1); im_sc = (struct sr_chunk_meta *)(im_sv + 1); + if (sizeof(struct sr_metadata) + sizeof(struct sr_vol_meta) + + (sizeof(struct sr_chunk_meta) * sd->sd_vol.sv_meta.svm_no_chunk) > + sz) { + printf("%s: too much metadata. Metadata NOT written to disk\n", + DEVNAME(sc)); + goto bad; + } + if (sm->ssd_magic == 0) { /* initial metadata */ sm->ssd_magic = SR_MAGIC; @@ -1798,7 +1806,7 @@ sr_save_metadata(struct sr_discipline *sd) sr_get_uuid(&sm->ssd_uuid); /* volume */ - bcopy(sv, im_sv, sizeof(struct sr_metadata)); + bcopy(sv, im_sv, sizeof(struct sr_vol_meta)); bcopy(&sm->ssd_uuid, &im_sv->svm_uuid, sizeof(im_sv->svm_uuid)); sm->ssd_vd_ver = SR_VOL_VERSION; @@ -1806,7 +1814,6 @@ sr_save_metadata(struct sr_discipline *sd) /* chunk */ - /* XXX do some sanity to prevent too many disks */ for (i = 0; i < sd->sd_vol.sv_meta.svm_no_chunk; i++) { bcopy(&sm->ssd_uuid, &sd->sd_vol.sv_chunks[i]->src_meta.scm_uuid, @@ -1861,7 +1868,7 @@ sr_save_metadata(struct sr_discipline *sd) biowait(&b); /* XXX do something smart here */ - /* marck chunk offline and restart metadata write */ + /* mark chunk offline and restart metadata write */ if (b.b_flags & B_ERROR) { printf("%s: %s i/o error on block %d while writing " "metadata %d\n", DEVNAME(sc), |