malloc: remove locking

The issue manifests in fork: POSIX fork mandates that a
fork'd process is created with a single thread.  If a
multithreaded program forks, and some thread was in
malloc() when the fork() happened, then in the child
the lock will be held but there will be no thread to
release it.

We assume the system malloc() must already know how to
deal with this and is thread-safe, but it won't know about
our custom spinlock.  Judging that this is no longer
necessary (the lock code was added 15 years ago) we remove
it.

Signed-off-by: Dan Cross <cross@gajendra.net>
This commit is contained in:
Dan Cross 2020-01-16 16:54:19 +00:00
parent 3ef80ba5f5
commit 7bf2db4c2a
3 changed files with 3 additions and 41 deletions

View file

@ -7,8 +7,6 @@
#define NOPLAN9DEFINES #define NOPLAN9DEFINES
#include <libc.h> #include <libc.h>
static Lock malloclock;
void* void*
p9malloc(ulong n) p9malloc(ulong n)
{ {
@ -16,9 +14,7 @@ p9malloc(ulong n)
if(n == 0) if(n == 0)
n++; n++;
lock(&malloclock);
v = malloc(n); v = malloc(n);
unlock(&malloclock);
print("p9malloc %lud => %p; pc %lux\n", n, v, getcallerpc(&n)); print("p9malloc %lud => %p; pc %lux\n", n, v, getcallerpc(&n));
return v; return v;
} }
@ -28,10 +24,8 @@ p9free(void *v)
{ {
if(v == nil) if(v == nil)
return; return;
lock(&malloclock);
print("p9free %p; pc %lux\n", v, getcallerpc(&v)); print("p9free %p; pc %lux\n", v, getcallerpc(&v));
free(v); free(v);
unlock(&malloclock);
} }
void* void*
@ -42,9 +36,7 @@ p9calloc(ulong a, ulong b)
if(a*b == 0) if(a*b == 0)
a = b = 1; a = b = 1;
lock(&malloclock);
v = calloc(a*b, 1); v = calloc(a*b, 1);
unlock(&malloclock);
print("p9calloc %lud %lud => %p; pc %lux\n", a, b, v, getcallerpc(&a)); print("p9calloc %lud %lud => %p; pc %lux\n", a, b, v, getcallerpc(&a));
return v; return v;
} }
@ -54,9 +46,7 @@ p9realloc(void *v, ulong n)
{ {
void *vv; void *vv;
lock(&malloclock);
vv = realloc(v, n); vv = realloc(v, n);
unlock(&malloclock);
print("p9realloc %p %lud => %p; pc %lux\n", v, n, vv, getcallerpc(&v)); print("p9realloc %p %lud => %p; pc %lux\n", v, n, vv, getcallerpc(&v));
return vv; return vv;
} }

View file

@ -6,7 +6,6 @@
* The Unix libc routines cannot be trusted to do their own locking. * The Unix libc routines cannot be trusted to do their own locking.
* Sad but apparently true. * Sad but apparently true.
*/ */
static Lock malloclock;
static int mallocpid; static int mallocpid;
/* /*
@ -112,11 +111,9 @@ p9malloc(ulong n)
if(n == 0) if(n == 0)
n++; n++;
/*fprint(2, "%s %d malloc\n", argv0, getpid()); */ /*fprint(2, "%s %d malloc\n", argv0, getpid()); */
lock(&malloclock);
mallocpid = getpid(); mallocpid = getpid();
v = malloc(n+Overhead); v = malloc(n+Overhead);
v = mark(v, getcallerpc(&n), n, MallocMagic); v = mark(v, getcallerpc(&n), n, MallocMagic);
unlock(&malloclock);
/*fprint(2, "%s %d donemalloc\n", argv0, getpid()); */ /*fprint(2, "%s %d donemalloc\n", argv0, getpid()); */
return v; return v;
} }
@ -128,11 +125,9 @@ p9free(void *v)
return; return;
/*fprint(2, "%s %d free\n", argv0, getpid()); */ /*fprint(2, "%s %d free\n", argv0, getpid()); */
lock(&malloclock);
mallocpid = getpid(); mallocpid = getpid();
v = mark(v, getcallerpc(&v), 0, FreeMagic); v = mark(v, getcallerpc(&v), 0, FreeMagic);
free(v); free(v);
unlock(&malloclock);
/*fprint(2, "%s %d donefree\n", argv0, getpid()); */ /*fprint(2, "%s %d donefree\n", argv0, getpid()); */
} }
@ -142,11 +137,9 @@ p9calloc(ulong a, ulong b)
void *v; void *v;
/*fprint(2, "%s %d calloc\n", argv0, getpid()); */ /*fprint(2, "%s %d calloc\n", argv0, getpid()); */
lock(&malloclock);
mallocpid = getpid(); mallocpid = getpid();
v = calloc(a*b+Overhead, 1); v = calloc(a*b+Overhead, 1);
v = mark(v, getcallerpc(&a), a*b, CallocMagic); v = mark(v, getcallerpc(&a), a*b, CallocMagic);
unlock(&malloclock);
/*fprint(2, "%s %d donecalloc\n", argv0, getpid()); */ /*fprint(2, "%s %d donecalloc\n", argv0, getpid()); */
return v; return v;
} }
@ -155,12 +148,10 @@ void*
p9realloc(void *v, ulong n) p9realloc(void *v, ulong n)
{ {
/*fprint(2, "%s %d realloc\n", argv0, getpid()); */ /*fprint(2, "%s %d realloc\n", argv0, getpid()); */
lock(&malloclock);
mallocpid = getpid(); mallocpid = getpid();
v = mark(v, getcallerpc(&v), 0, CheckMagic); v = mark(v, getcallerpc(&v), 0, CheckMagic);
v = realloc(v, n+Overhead); v = realloc(v, n+Overhead);
v = mark(v, getcallerpc(&v), n, ReallocMagic); v = mark(v, getcallerpc(&v), n, ReallocMagic);
unlock(&malloclock);
/*fprint(2, "%s %d donerealloc\n", argv0, getpid()); */ /*fprint(2, "%s %d donerealloc\n", argv0, getpid()); */
return v; return v;
} }

View file

@ -7,50 +7,31 @@
#define NOPLAN9DEFINES #define NOPLAN9DEFINES
#include <libc.h> #include <libc.h>
static Lock malloclock;
void* void*
p9malloc(ulong n) p9malloc(ulong n)
{ {
void *v;
if(n == 0) if(n == 0)
n++; n++;
lock(&malloclock); return malloc(n);
v = malloc(n);
unlock(&malloclock);
return v;
} }
void void
p9free(void *v) p9free(void *v)
{ {
if(v == nil)
return;
lock(&malloclock);
free(v); free(v);
unlock(&malloclock);
} }
void* void*
p9calloc(ulong a, ulong b) p9calloc(ulong a, ulong b)
{ {
void *v;
if(a*b == 0) if(a*b == 0)
a = b = 1; a = b = 1;
return calloc(a, b);
lock(&malloclock);
v = calloc(a*b, 1);
unlock(&malloclock);
return v;
} }
void* void*
p9realloc(void *v, ulong n) p9realloc(void *v, ulong n)
{ {
lock(&malloclock); return realloc(v, n);
v = realloc(v, n);
unlock(&malloclock);
return v;
} }