Miscellaneous constification.
[u/mdw/catacomb] / lmem.c
diff --git a/lmem.c b/lmem.c
index a56108a..e534d4a 100644 (file)
--- a/lmem.c
+++ b/lmem.c
@@ -1,6 +1,6 @@
 /* -*-c-*-
  *
- * $Id: lmem.c,v 1.2 2000/06/17 11:29:20 mdw Exp $
+ * $Id: lmem.c,v 1.5 2004/04/02 01:03:49 mdw Exp $
  *
  * Locked memory allocation (Unix-specific)
  *
 /*----- Revision history --------------------------------------------------* 
  *
  * $Log: lmem.c,v $
+ * Revision 1.5  2004/04/02 01:03:49  mdw
+ * Miscellaneous constification.
+ *
+ * Revision 1.4  2002/01/24 22:26:11  mdw
+ * Fix build failure when @mlock@ not available.
+ *
+ * Revision 1.3  2000/07/29 21:58:15  mdw
+ * (l_destroy): New function for destroying locked memory blocks.
+ *
  * Revision 1.2  2000/06/17 11:29:20  mdw
  * Add arena support.
  *
@@ -67,7 +76,7 @@ static void *aalloc(arena *a, size_t sz) { return l_alloc((lmem *)a, sz); }
 static void afree(arena *a, void *p) { l_free((lmem *)a, p); }
 static void apurge(arena *a) { l_purge((lmem *)a); }
 
-static arena_ops l_ops = { aalloc, arena_fakerealloc, afree, apurge };
+static const arena_ops l_ops = { aalloc, arena_fakerealloc, afree, apurge };
 
 /*----- Main code ---------------------------------------------------------*/
 
@@ -97,6 +106,7 @@ int l_init(lmem *lm, size_t sz)
 
   lm->a.ops = &l_ops;
   lm->err = 0;
+  lm->f = 0;
 
   /* --- Try making a secure locked passphrase buffer --- *
    *
@@ -133,7 +143,8 @@ int l_init(lmem *lm, size_t sz)
     lm->err = errno;
     munmap(p, sz);
     p = 0;
-  }
+  } else
+    lm->f |= LF_LOCKED;
 
 #endif
 
@@ -142,8 +153,8 @@ int l_init(lmem *lm, size_t sz)
 #ifdef HAVE_MLOCK
   if (!p)
 #else
-  ll->err = 0;
-  ll->emsg = "locked memory not available on this system";
+  lm->err = 0;
+  lm->emsg = "locked memory not available on this system";
 #endif
   {
     if ((p = malloc(sz)) == 0) {
@@ -295,6 +306,33 @@ void l_purge(lmem *lm)
   lm->free = l->sz;
 }
 
+/* --- @l_destroy@ --- *
+ *
+ * Arguments:  @lmem *lm@ = pointer to locked memory descriptor
+ *
+ * Returns:    ---
+ *
+ * Use:                Disposes of a locked memory arena permanently.
+ */
+
+void l_destroy(lmem *lm)
+{
+  l_node *l;
+
+  l = lm->l;
+  while (l) {
+    l_node *ll = l->next;
+    DESTROY(l);
+    l = ll;
+  }
+  memset(lm->p, 0, lm->sz);
+
+  if (lm->f & LF_LOCKED)
+    munmap(lm->p, lm->sz);
+  else
+    free(lm->p);
+}
+
 /* --- @l_report@ --- *
  *
  * Arguments:  @lmem *lm@ = pointer to locked memory descriptor