diff options
author | Marco Peereboom <marco@cvs.openbsd.org> | 2007-06-01 17:43:06 +0000 |
---|---|---|
committer | Marco Peereboom <marco@cvs.openbsd.org> | 2007-06-01 17:43:06 +0000 |
commit | c54ed097c1e1ef429f60d9c3b2d45d7188f30599 (patch) | |
tree | 5b87a116ab66bf577b6aadeafd9ffe26d232ab77 /sys/dev | |
parent | 56b0cc4b4ad126fc894addc1efb00093b073e318 (diff) |
Check return code for resource allocation.
prompted by tedu
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/softraid.c | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/sys/dev/softraid.c b/sys/dev/softraid.c index 5292b80ecd8..1ea56541306 100644 --- a/sys/dev/softraid.c +++ b/sys/dev/softraid.c @@ -1,4 +1,4 @@ -/* $OpenBSD: softraid.c,v 1.65 2007/06/01 01:16:48 marco Exp $ */ +/* $OpenBSD: softraid.c,v 1.66 2007/06/01 17:43:05 marco Exp $ */ /* * Copyright (c) 2007 Marco Peereboom <marco@peereboom.us> * @@ -944,7 +944,8 @@ sr_ioctl_createraid(struct sr_softc *sc, struct bioc_createraid *bc, int user) } /* allocate all resources */ - sd->sd_alloc_resources(sd); + if ((rv = sd->sd_alloc_resources(sd))) + goto unwind; /* setup scsi midlayer */ sd->sd_link.openings = sd->sd_max_wu; @@ -1393,10 +1394,13 @@ sr_raid1_alloc_resources(struct sr_discipline *sd) DNPRINTF(SR_D_DIS, "%s: sr_raid1_alloc_resources\n", DEVNAME(sd->sd_sc)); - sr_alloc_wu(sd); - sr_alloc_ccb(sd); + if (sr_alloc_wu(sd)) + goto bad; + if (sr_alloc_ccb(sd)) + goto bad; rv = 0; +bad: return (rv); } @@ -2963,8 +2967,10 @@ sr_raidc_alloc_resources(struct sr_discipline *sd) DNPRINTF(SR_D_DIS, "%s: sr_raidc_alloc_resources\n", DEVNAME(sd->sd_sc)); - sr_alloc_wu(sd); - sr_alloc_ccb(sd); + if (sr_alloc_wu(sd)) + return (ENOMEM); + if (sr_alloc_ccb(sd)) + return (ENOMEM); /* XXX we need a real key later */ memset(sd->mds.mdd_raidc.src_key, 'k', sizeof sd->mds.mdd_raidc.src_key); |