alloc.c revision 1.1 1 1.1 brezak /*-
2 1.1 brezak * Copyright (c) 1993
3 1.1 brezak * The Regents of the University of California. All rights reserved.
4 1.1 brezak *
5 1.1 brezak * This code is derived from software contributed to Berkeley by
6 1.1 brezak * The Mach Operating System project at Carnegie-Mellon University.
7 1.1 brezak *
8 1.1 brezak * Redistribution and use in source and binary forms, with or without
9 1.1 brezak * modification, are permitted provided that the following conditions
10 1.1 brezak * are met:
11 1.1 brezak * 1. Redistributions of source code must retain the above copyright
12 1.1 brezak * notice, this list of conditions and the following disclaimer.
13 1.1 brezak * 2. Redistributions in binary form must reproduce the above copyright
14 1.1 brezak * notice, this list of conditions and the following disclaimer in the
15 1.1 brezak * documentation and/or other materials provided with the distribution.
16 1.1 brezak * 3. All advertising materials mentioning features or use of this software
17 1.1 brezak * must display the following acknowledgement:
18 1.1 brezak * This product includes software developed by the University of
19 1.1 brezak * California, Berkeley and its contributors.
20 1.1 brezak * 4. Neither the name of the University nor the names of its contributors
21 1.1 brezak * may be used to endorse or promote products derived from this software
22 1.1 brezak * without specific prior written permission.
23 1.1 brezak *
24 1.1 brezak * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
25 1.1 brezak * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 1.1 brezak * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 1.1 brezak * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
28 1.1 brezak * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29 1.1 brezak * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 1.1 brezak * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31 1.1 brezak * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32 1.1 brezak * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33 1.1 brezak * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 1.1 brezak * SUCH DAMAGE.
35 1.1 brezak *
36 1.1 brezak * from: @(#)alloc.c 8.1 (Berkeley) 6/11/93
37 1.1 brezak *
38 1.1 brezak *
39 1.1 brezak * Copyright (c) 1989, 1990, 1991 Carnegie Mellon University
40 1.1 brezak * All Rights Reserved.
41 1.1 brezak *
42 1.1 brezak * Author: Alessandro Forin
43 1.1 brezak *
44 1.1 brezak * Permission to use, copy, modify and distribute this software and its
45 1.1 brezak * documentation is hereby granted, provided that both the copyright
46 1.1 brezak * notice and this permission notice appear in all copies of the
47 1.1 brezak * software, derivative works or modified versions, and any portions
48 1.1 brezak * thereof, and that both notices appear in supporting documentation.
49 1.1 brezak *
50 1.1 brezak * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
51 1.1 brezak * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
52 1.1 brezak * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
53 1.1 brezak *
54 1.1 brezak * Carnegie Mellon requests users of this software to return to
55 1.1 brezak *
56 1.1 brezak * Software Distribution Coordinator or Software.Distribution (at) CS.CMU.EDU
57 1.1 brezak * School of Computer Science
58 1.1 brezak * Carnegie Mellon University
59 1.1 brezak * Pittsburgh PA 15213-3890
60 1.1 brezak *
61 1.1 brezak * any improvements or extensions that they make and grant Carnegie the
62 1.1 brezak * rights to redistribute these changes.
63 1.1 brezak *
64 1.1 brezak * $Id: alloc.c,v 1.1 1994/01/26 02:03:35 brezak Exp $
65 1.1 brezak */
66 1.1 brezak
67 1.1 brezak /*
68 1.1 brezak * Dynamic memory allocator
69 1.1 brezak */
70 1.1 brezak struct fl {
71 1.1 brezak struct fl *next;
72 1.1 brezak unsigned size;
73 1.1 brezak } *freelist = (struct fl *)0;
74 1.1 brezak
75 1.1 brezak extern char end[];
76 1.1 brezak static char *top = end;
77 1.1 brezak
78 1.1 brezak void *
79 1.1 brezak alloc(size)
80 1.1 brezak unsigned size;
81 1.1 brezak {
82 1.1 brezak register struct fl *f = freelist, **prev;
83 1.1 brezak
84 1.1 brezak prev = &freelist;
85 1.1 brezak while (f && f->size < size) {
86 1.1 brezak prev = &f->next;
87 1.1 brezak f = f->next;
88 1.1 brezak }
89 1.1 brezak if (f == (struct fl *)0) {
90 1.1 brezak f = (struct fl *)top;
91 1.1 brezak top += (size + 3) & ~3;
92 1.1 brezak } else
93 1.1 brezak *prev = f->next;
94 1.1 brezak return ((void *)f);
95 1.1 brezak }
96 1.1 brezak
97 1.1 brezak void
98 1.1 brezak free(ptr, size)
99 1.1 brezak void *ptr;
100 1.1 brezak unsigned size;
101 1.1 brezak {
102 1.1 brezak register struct fl *f = (struct fl *)ptr;
103 1.1 brezak
104 1.1 brezak f->size = (size + 3) & ~3;
105 1.1 brezak f->next = freelist;
106 1.1 brezak freelist = f;
107 1.1 brezak }
108