Module Name: src
Committed By: pooka
Date: Fri Nov 26 10:59:14 UTC 2010
Modified Files:
src/lib/librumpuser: rumpuser_sp.c
Log Message:
Plug recently introduced memory leak: release lwp after use instead of
just switching away.
Also, make freeing syscall arguments a little more symmetric.
To generate a diff of this commit:
cvs rdiff -u -r1.15 -r1.16 src/lib/librumpuser/rumpuser_sp.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/librumpuser/rumpuser_sp.c
diff -u src/lib/librumpuser/rumpuser_sp.c:1.15 src/lib/librumpuser/rumpuser_sp.c:1.16
--- src/lib/librumpuser/rumpuser_sp.c:1.15 Thu Nov 25 17:59:02 2010
+++ src/lib/librumpuser/rumpuser_sp.c Fri Nov 26 10:59:14 2010
@@ -1,4 +1,4 @@
-/* $NetBSD: rumpuser_sp.c,v 1.15 2010/11/25 17:59:02 pooka Exp $ */
+/* $NetBSD: rumpuser_sp.c,v 1.16 2010/11/26 10:59:14 pooka Exp $ */
/*
* Copyright (c) 2010 Antti Kantee. All Rights Reserved.
@@ -38,7 +38,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: rumpuser_sp.c,v 1.15 2010/11/25 17:59:02 pooka Exp $");
+__RCSID("$NetBSD: rumpuser_sp.c,v 1.16 2010/11/26 10:59:14 pooka Exp $");
#include <sys/types.h>
#include <sys/atomic.h>
@@ -421,8 +421,7 @@
lwproc_newlwp(spc->spc_pid);
rv = rumpsyscall(sysnum, data, retval);
- lwproc_switch(NULL);
- free(data);
+ lwproc_release();
DPRINTF(("rump_sp: got return value %d & %d/%d\n",
rv, retval[0], retval[1]));
@@ -442,7 +441,8 @@
serv_handlesyscall(barg->sba_spc, &barg->sba_hdr, barg->sba_data);
spcrelease(barg->sba_spc);
- free(arg);
+ free(barg->sba_data);
+ free(barg);
return NULL;
}