diff options
Diffstat (limited to 'sys/dev/softraid.c')
-rw-r--r-- | sys/dev/softraid.c | 58 |
1 files changed, 30 insertions, 28 deletions
diff --git a/sys/dev/softraid.c b/sys/dev/softraid.c index c46c7d9f73c..21d56c17c58 100644 --- a/sys/dev/softraid.c +++ b/sys/dev/softraid.c @@ -1,4 +1,4 @@ -/* $OpenBSD: softraid.c,v 1.354 2015/05/29 13:48:45 krw Exp $ */ +/* $OpenBSD: softraid.c,v 1.355 2015/07/19 16:12:10 krw Exp $ */ /* * Copyright (c) 2007, 2008, 2009 Marco Peereboom <marco@peereboom.us> * Copyright (c) 2008 Chris Kuethe <ckuethe@openbsd.org> @@ -215,7 +215,7 @@ struct sr_meta_driver { int (*smd_validate)(struct sr_discipline *, struct sr_metadata *, void *); } smd[] = { - { SR_META_OFFSET, SR_META_SIZE * 512, + { SR_META_OFFSET, SR_META_SIZE * DEV_BSIZE, sr_meta_native_probe, sr_meta_native_attach, NULL, sr_meta_native_read, sr_meta_native_write, NULL }, { 0, 0, NULL, NULL, NULL, NULL } @@ -232,7 +232,8 @@ sr_meta_attach(struct sr_discipline *sd, int chunk_no, int force) DNPRINTF(SR_D_META, "%s: sr_meta_attach(%d)\n", DEVNAME(sc), chunk_no); /* in memory copy of metadata */ - sd->sd_meta = malloc(SR_META_SIZE * 512, M_DEVBUF, M_ZERO | M_NOWAIT); + sd->sd_meta = malloc(SR_META_SIZE * DEV_BSIZE, M_DEVBUF, + M_ZERO | M_NOWAIT); if (!sd->sd_meta) { sr_error(sc, "could not allocate memory for metadata"); goto bad; @@ -509,7 +510,7 @@ sr_meta_clear(struct sr_discipline *sd) goto done; } - m = malloc(SR_META_SIZE * 512, M_DEVBUF, M_WAITOK | M_ZERO); + m = malloc(SR_META_SIZE * DEV_BSIZE, M_DEVBUF, M_WAITOK | M_ZERO); SLIST_FOREACH(ch_entry, cl, src_link) { if (sr_meta_native_write(sd, ch_entry->src_dev_mm, m, NULL)) { /* XXX mark disk offline */ @@ -521,9 +522,9 @@ sr_meta_clear(struct sr_discipline *sd) bzero(&ch_entry->src_meta, sizeof(ch_entry->src_meta)); } - bzero(sd->sd_meta, SR_META_SIZE * 512); + bzero(sd->sd_meta, SR_META_SIZE * DEV_BSIZE); - free(m, M_DEVBUF, SR_META_SIZE * 512); + free(m, M_DEVBUF, SR_META_SIZE * DEV_BSIZE); rv = 0; done: return (rv); @@ -649,7 +650,7 @@ sr_meta_save(struct sr_discipline *sd, u_int32_t flags) /* meta scratchpad */ s = &smd[sd->sd_meta_type]; - m = malloc(SR_META_SIZE * 512, M_DEVBUF, M_ZERO | M_NOWAIT); + m = malloc(SR_META_SIZE * DEV_BSIZE, M_DEVBUF, M_ZERO | M_NOWAIT); if (!m) { printf("%s: could not allocate metadata scratch area\n", DEVNAME(sc)); @@ -726,7 +727,7 @@ restart: wu.swu_dis = sd; sd->sd_scsi_sync(&wu); } - free(m, M_DEVBUF, SR_META_SIZE * 512); + free(m, M_DEVBUF, SR_META_SIZE * DEV_BSIZE); return (0); bad: return (1); @@ -746,7 +747,7 @@ sr_meta_read(struct sr_discipline *sd) DNPRINTF(SR_D_META, "%s: sr_meta_read\n", DEVNAME(sc)); - sm = malloc(SR_META_SIZE * 512, M_DEVBUF, M_WAITOK | M_ZERO); + sm = malloc(SR_META_SIZE * DEV_BSIZE, M_DEVBUF, M_WAITOK | M_ZERO); s = &smd[sd->sd_meta_type]; if (sd->sd_meta_type != SR_META_F_NATIVE) fm = malloc(s->smd_size, M_DEVBUF, M_WAITOK | M_ZERO); @@ -797,7 +798,7 @@ sr_meta_read(struct sr_discipline *sd) cp++; } - free(sm, M_DEVBUF, SR_META_SIZE * 512); + free(sm, M_DEVBUF, SR_META_SIZE * DEV_BSIZE); free(fm, M_DEVBUF, s->smd_size); done: @@ -1050,14 +1051,14 @@ sr_meta_native_bootprobe(struct sr_softc *sc, dev_t devno, } vput(vn); - /* Make sure this is a 512-byte/sector device. */ + /* Make sure this is a DEV_BSIZE byte/sector device. */ if (label.d_secsize != DEV_BSIZE) { DNPRINTF(SR_D_META, "%s: %s has unsupported sector size (%d)", DEVNAME(sc), devname, label.d_secsize); goto done; } - md = malloc(SR_META_SIZE * 512, M_DEVBUF, M_ZERO | M_NOWAIT); + md = malloc(SR_META_SIZE * DEV_BSIZE, M_DEVBUF, M_ZERO | M_NOWAIT); if (md == NULL) { sr_error(sc, "not enough memory for metadata buffer"); goto done; @@ -1128,7 +1129,7 @@ sr_meta_native_bootprobe(struct sr_softc *sc, dev_t devno, done: free(fake_sd, M_DEVBUF, sizeof(struct sr_discipline)); - free(md, M_DEVBUF, SR_META_SIZE * 512); + free(md, M_DEVBUF, SR_META_SIZE * DEV_BSIZE); return (rv); } @@ -1566,7 +1567,7 @@ sr_meta_native_probe(struct sr_softc *sc, struct sr_chunk *ch_entry) } memcpy(ch_entry->src_duid, label.d_uid, sizeof(ch_entry->src_duid)); - /* Make sure this is a 512-byte/sector device. */ + /* Make sure this is a DEV_BSIZE byte/sector device. */ if (label.d_secsize != DEV_BSIZE) { sr_error(sc, "%s has unsupported sector size (%u)", devname, label.d_secsize); @@ -1614,7 +1615,7 @@ sr_meta_native_attach(struct sr_discipline *sd, int force) DNPRINTF(SR_D_META, "%s: sr_meta_native_attach\n", DEVNAME(sc)); - md = malloc(SR_META_SIZE * 512, M_DEVBUF, M_ZERO | M_NOWAIT); + md = malloc(SR_META_SIZE * DEV_BSIZE, M_DEVBUF, M_ZERO | M_NOWAIT); if (md == NULL) { sr_error(sc, "not enough memory for metadata buffer"); goto bad; @@ -1687,7 +1688,7 @@ sr_meta_native_attach(struct sr_discipline *sd, int force) rv = 0; bad: - free(md, M_DEVBUF, SR_META_SIZE * 512); + free(md, M_DEVBUF, SR_META_SIZE * DEV_BSIZE); return (rv); } @@ -1701,8 +1702,8 @@ sr_meta_native_read(struct sr_discipline *sd, dev_t dev, DNPRINTF(SR_D_META, "%s: sr_meta_native_read(0x%x, %p)\n", DEVNAME(sc), dev, md); - return (sr_meta_rw(sd, dev, md, SR_META_SIZE * 512, SR_META_OFFSET, - B_READ)); + return (sr_meta_rw(sd, dev, md, SR_META_SIZE * DEV_BSIZE, + SR_META_OFFSET, B_READ)); } int @@ -1715,8 +1716,8 @@ sr_meta_native_write(struct sr_discipline *sd, dev_t dev, DNPRINTF(SR_D_META, "%s: sr_meta_native_write(0x%x, %p)\n", DEVNAME(sc), dev, md); - return (sr_meta_rw(sd, dev, md, SR_META_SIZE * 512, SR_META_OFFSET, - B_WRITE)); + return (sr_meta_rw(sd, dev, md, SR_META_SIZE * DEV_BSIZE, + SR_META_OFFSET, B_WRITE)); } void @@ -3682,10 +3683,10 @@ sr_ioctl_installboot(struct sr_softc *sc, struct sr_discipline *sd, goto done; } - if (bb->bb_bootblk_size > SR_BOOT_BLOCKS_SIZE * 512) + if (bb->bb_bootblk_size > SR_BOOT_BLOCKS_SIZE * DEV_BSIZE) goto done; - if (bb->bb_bootldr_size > SR_BOOT_LOADER_SIZE * 512) + if (bb->bb_bootldr_size > SR_BOOT_LOADER_SIZE * DEV_BSIZE) goto done; /* Copy in boot block. */ @@ -4031,13 +4032,13 @@ sr_raid_read_cap(struct sr_workunit *wu) _lto4b(0xffffffff, rcd.addr); else _lto4b(addr, rcd.addr); - _lto4b(512, rcd.length); + _lto4b(DEV_BSIZE, rcd.length); sr_copy_internal_data(xs, &rcd, sizeof(rcd)); rv = 0; } else if (xs->cmd->opcode == READ_CAPACITY_16) { bzero(&rcd16, sizeof(rcd16)); _lto8b(addr, rcd16.addr); - _lto4b(512, rcd16.length); + _lto4b(DEV_BSIZE, rcd16.length); sr_copy_internal_data(xs, &rcd16, sizeof(rcd16)); rv = 0; } @@ -4491,7 +4492,7 @@ sr_validate_stripsize(u_int32_t b) { int s = 0; - if (b % 512) + if (b % DEV_BSIZE) return (-1); while ((b & 1) == 0) { @@ -5020,6 +5021,7 @@ sr_hibernate_io(dev_t dev, daddr_t blkno, vaddr_t addr, size_t size, int op, voi daddr_t key_blkno; uint32_t sub_raidoff; /* ofs of sr part in underlying dev */ struct disklabel dl; + struct partition *pp; size_t i, j; u_char iv[8]; @@ -5065,13 +5067,13 @@ sr_hibernate_io(dev_t dev, daddr_t blkno, vaddr_t addr, size_t size, int op, voi return (ENOTSUP); } - if (dl.d_partitions[DISKPART(my->subdev)].p_fstype != FS_RAID || - DL_GETPSIZE(&dl.d_partitions[DISKPART(my->subdev)]) == 0) + pp = &dl.d_partitions[DISKPART(my->subdev)]; + if (pp->p_fstype != FS_RAID || DL_GETPSIZE(pp) == 0) return (ENOTSUP); /* Find the offset of the SR part in the underlying device */ sub_raidoff = my->srd->sd_meta->ssd_data_offset + - DL_GETPOFFSET(&dl.d_partitions[DISKPART(my->subdev)]); + DL_SECTOBLK(&dl, DL_GETPOFFSET(pp)); DNPRINTF(SR_D_MISC,"sr_hibernate_io: blk trans ofs: %d blks\n", sub_raidoff); |