summaryrefslogtreecommitdiff
path: root/src/alloc.c
diff options
context:
space:
mode:
authorGerd Moellmann <gerd@gnu.org>2000-03-30 09:29:22 +0000
committerGerd Moellmann <gerd@gnu.org>2000-03-30 09:29:22 +0000
commitdca7c6a8d2abaef803a38d1efe40cda8b7eff2a5 (patch)
tree459521ffb36ace18142f3d9e6a2e14129a12de52 /src/alloc.c
parente3130015d6f811729b8d3c883c586ff74f0636ec (diff)
downloademacs-dca7c6a8d2abaef803a38d1efe40cda8b7eff2a5.tar.gz
(xstrdup): Moved here from xfaces.c.
(allocating_for_lisp): Variable removed. (lisp_malloc): Block input around the calls to malloc and mem_insert.
Diffstat (limited to 'src/alloc.c')
-rw-r--r--src/alloc.c31
1 files changed, 17 insertions, 14 deletions
diff --git a/src/alloc.c b/src/alloc.c
index 3b5d0e57ace..a32718d82f4 100644
--- a/src/alloc.c
+++ b/src/alloc.c
@@ -170,11 +170,6 @@ static char *spare_memory;
static int malloc_hysteresis;
-/* Nonzero when malloc is called for allocating Lisp object space.
- Currently set but not used. */
-
-int allocating_for_lisp;
-
/* Non-nil means defun should do purecopy on the function definition. */
Lisp_Object Vpurify_flag;
@@ -464,6 +459,19 @@ xfree (block)
}
+/* Like strdup, but uses xmalloc. */
+
+char *
+xstrdup (s)
+ char *s;
+{
+ int len = strlen (s) + 1;
+ char *p = (char *) xmalloc (len);
+ bcopy (s, p, len);
+ return p;
+}
+
+
/* Like malloc but used for allocating Lisp data. NBYTES is the
number of bytes to allocate, TYPE describes the intended use of the
allcated memory block (for strings, for conses, ...). */
@@ -476,19 +484,16 @@ lisp_malloc (nbytes, type)
register void *val;
BLOCK_INPUT;
- allocating_for_lisp++;
val = (void *) malloc (nbytes);
- allocating_for_lisp--;
- UNBLOCK_INPUT;
- if (!val && nbytes)
- memory_full ();
-
#if GC_MARK_STACK
- if (type != MEM_TYPE_NON_LISP)
+ if (val && type != MEM_TYPE_NON_LISP)
mem_insert (val, (char *) val + nbytes, type);
#endif
+ UNBLOCK_INPUT;
+ if (!val && nbytes)
+ memory_full ();
return val;
}
@@ -512,12 +517,10 @@ lisp_free (block)
long *block;
{
BLOCK_INPUT;
- allocating_for_lisp++;
free (block);
#if GC_MARK_STACK
mem_delete (mem_find (block));
#endif
- allocating_for_lisp--;
UNBLOCK_INPUT;
}