aboutsummaryrefslogtreecommitdiff
path: root/mmalloc/mmemalign.c
diff options
context:
space:
mode:
authorFred Fish <fnf@specifix.com>1992-03-15 02:16:01 +0000
committerFred Fish <fnf@specifix.com>1992-03-15 02:16:01 +0000
commit63abb1e790d634cba4162c2997f2ae330d63b703 (patch)
treee95a308c52d1b1693bc29e74cf3073330edec0a7 /mmalloc/mmemalign.c
parent009898fddb9210e230163940ac173ec681574ccc (diff)
downloadfsf-binutils-gdb-63abb1e790d634cba4162c2997f2ae330d63b703.zip
fsf-binutils-gdb-63abb1e790d634cba4162c2997f2ae330d63b703.tar.gz
fsf-binutils-gdb-63abb1e790d634cba4162c2997f2ae330d63b703.tar.bz2
New memory malloc malloc library, based on GNU malloc.
Diffstat (limited to 'mmalloc/mmemalign.c')
-rw-r--r--mmalloc/mmemalign.c64
1 files changed, 64 insertions, 0 deletions
diff --git a/mmalloc/mmemalign.c b/mmalloc/mmemalign.c
new file mode 100644
index 0000000..63350a2
--- /dev/null
+++ b/mmalloc/mmemalign.c
@@ -0,0 +1,64 @@
+/* Copyright (C) 1991, 1992 Free Software Foundation, Inc.
+This file is part of the GNU C Library.
+
+The GNU C Library is free software; you can redistribute it and/or
+modify it under the terms of the GNU Library General Public License as
+published by the Free Software Foundation; either version 2 of the
+License, or (at your option) any later version.
+
+The GNU C Library is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+Library General Public License for more details.
+
+You should have received a copy of the GNU Library General Public
+License along with the GNU C Library; see the file COPYING.LIB. If
+not, write to the Free Software Foundation, Inc., 675 Mass Ave,
+Cambridge, MA 02139, USA. */
+
+#include "mmalloc.h"
+
+PTR
+mmemalign (md, alignment, size)
+ PTR md;
+ size_t alignment;
+ size_t size;
+{
+ PTR result;
+ unsigned long int adj;
+ struct alignlist *l;
+ struct mdesc *mdp;
+
+ size = ((size + alignment - 1) / alignment) * alignment;
+
+ if ((result = mmalloc (md, size)) != NULL)
+ {
+ adj = RESIDUAL (result, alignment);
+ if (adj != 0)
+ {
+ mdp = MD_TO_MDP (md);
+ for (l = mdp -> aligned_blocks; l != NULL; l = l -> next)
+ {
+ if (l -> aligned == NULL)
+ {
+ /* This slot is free. Use it. */
+ break;
+ }
+ }
+ if (l == NULL)
+ {
+ l = (struct alignlist *) mmalloc (md, sizeof (struct alignlist));
+ if (l == NULL)
+ {
+ mfree (md, result);
+ return (NULL);
+ }
+ }
+ l -> exact = result;
+ result = l -> aligned = (char *) result + alignment - adj;
+ l -> next = mdp -> aligned_blocks;
+ mdp -> aligned_blocks = l;
+ }
+ }
+ return (result);
+}