Module Name:    src
Committed By:   christos
Date:           Mon Jul  9 03:11:59 UTC 2012

Modified Files:
        src/lib/libexecinfo: backtrace.c

Log Message:
fix cleanup on error


To generate a diff of this commit:
cvs rdiff -u -r1.1 -r1.2 src/lib/libexecinfo/backtrace.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/lib/libexecinfo/backtrace.c
diff -u src/lib/libexecinfo/backtrace.c:1.1 src/lib/libexecinfo/backtrace.c:1.2
--- src/lib/libexecinfo/backtrace.c:1.1	Sat May 26 18:02:29 2012
+++ src/lib/libexecinfo/backtrace.c	Sun Jul  8 23:11:59 2012
@@ -1,4 +1,4 @@
-/*	$NetBSD: backtrace.c,v 1.1 2012/05/26 22:02:29 christos Exp $	*/
+/*	$NetBSD: backtrace.c,v 1.2 2012/07/09 03:11:59 christos Exp $	*/
 
 /*-
  * Copyright (c) 2012 The NetBSD Foundation, Inc.
@@ -29,7 +29,7 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: backtrace.c,v 1.1 2012/05/26 22:02:29 christos Exp $");
+__RCSID("$NetBSD: backtrace.c,v 1.2 2012/07/09 03:11:59 christos Exp $");
 
 #include <sys/param.h>
 #include <assert.h>
@@ -168,7 +168,7 @@ backtrace_symbols_fmt(void *const *trace
 		st = NULL;
 
 	if ((ptr = calloc(len, slen)) == NULL)
-		return NULL;
+		goto out;
 
 	size_t psize = len * slen;
 	size_t offs = len * sizeof(char *);
@@ -180,7 +180,8 @@ backtrace_symbols_fmt(void *const *trace
 		x = format_address(st, &ptr, &psize, offs, fmt, trace[i]);
 		if (x == -1) {
 			free(ptr);
-			return NULL;
+			ptr = NULL;
+			goto out;
 		}
 		offs += x;
 		ptr[offs++] = '\0';
@@ -191,6 +192,7 @@ backtrace_symbols_fmt(void *const *trace
 	for (size_t j = 0; j < len; j++)
 		((char **)(void *)ptr)[j] += (intptr_t)ptr;
 
+out:
 	symtab_destroy(st);
 	if (fd != -1)
 		(void)close(fd);

Reply via email to