summaryrefslogtreecommitdiffstats
path: root/lib/libufs
diff options
context:
space:
mode:
authordelphij <delphij@FreeBSD.org>2009-04-02 17:16:39 +0000
committerdelphij <delphij@FreeBSD.org>2009-04-02 17:16:39 +0000
commitf0600f6414be2ef3fa25531cf962a53364017a95 (patch)
treed34266bb7db568ee25a9108728901a9a50d1bab0 /lib/libufs
parent08539c697dcfc5d69245a5f2088732d8ace63636 (diff)
downloadFreeBSD-src-f0600f6414be2ef3fa25531cf962a53364017a95.zip
FreeBSD-src-f0600f6414be2ef3fa25531cf962a53364017a95.tar.gz
Bail out when memory allocation is failed, rather than referencing
a NULL pointer. PR: kern/94480 Submitted by: Michiel Pelt <m.pelt xs4all nl>
Diffstat (limited to 'lib/libufs')
-rw-r--r--lib/libufs/block.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/libufs/block.c b/lib/libufs/block.c
index 5450a5d..212cdc6 100644
--- a/lib/libufs/block.c
+++ b/lib/libufs/block.c
@@ -64,8 +64,10 @@ bread(struct uufsd *disk, ufs2_daddr_t blockno, void *data, size_t size)
*/
if (((intptr_t)data) & 0x3f) {
p2 = malloc(size);
- if (p2 == NULL)
+ if (p2 == NULL) {
ERROR(disk, "allocate bounce buffer");
+ goto fail;
+ }
}
cnt = pread(disk->d_fd, p2, size, (off_t)(blockno * disk->d_bsize));
if (cnt == -1) {
@@ -115,8 +117,10 @@ bwrite(struct uufsd *disk, ufs2_daddr_t blockno, const void *data, size_t size)
*/
if (((intptr_t)data) & 0x3f) {
p2 = malloc(size);
- if (p2 == NULL)
+ if (p2 == NULL) {
ERROR(disk, "allocate bounce buffer");
+ return (-1);
+ }
memcpy(p2, data, size);
data = p2;
}
OpenPOWER on IntegriCloud