2 * The contents of this file are subject to the Mozilla Public
3 * License Version 1.1 (the "License"); you may not use this file
4 * except in compliance with the License. You may obtain a copy of
5 * the License at http://www.mozilla.org/MPL/
7 * Software distributed under the License is distributed on an "AS
8 * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
9 * implied. See the License for the specific language governing
10 * rights and limitations under the License.
12 * The Original Code is the Sablotron XSLT Processor.
14 * The Initial Developer of the Original Code is Ginger Alliance Ltd.
15 * Portions created by Ginger Alliance are Copyright (C) 2000-2002
16 * Ginger Alliance Ltd. All Rights Reserved.
20 * Alternatively, the contents of this file may be used under the
21 * terms of the GNU General Public License Version 2 or later (the
22 * "GPL"), in which case the provisions of the GPL are applicable
23 * instead of those above. If you wish to allow use of your
24 * version of this file only under the terms of the GPL and not to
25 * allow others to use your version of this file under the MPL,
26 * indicate your decision by deleting the provisions above and
27 * replace them with the notice and other provisions required by
28 * the GPL. If you do not delete the provisions above, a recipient
29 * may use your version of this file under either the MPL or the
39 SabArena::SabArena(int bloxize_)
44 void SabArena::initialize(int bloxize_)
46 totalAsked = totalMalloced = 0;
47 bloxize = bloxize_ & ~15; // qword-align the ends of the blocks
48 // delaying: block0 = blockn = newBlock(bloxize);
49 block0 = blockn = NULL;
52 ArenaBlock* SabArena::newBlock(int size)
54 totalMalloced += size;
55 ArenaBlock *b = new ArenaBlock;
57 b -> data = malloc(b -> freeSpace = size); // guaranteed to be well-aligned
61 void SabArena::dispose()
64 ArenaBlock *b, *b_was;
68 b = (b_was = b) -> next;
71 // temporarily removing this to avoid the need for a Situation
72 // Log2(proc -> situation, L2_DISP_ARENA, Str(totalAsked), Str(totalMalloced));
78 // printf("Arena deleted --- asked %d malloced %d", totalAsked, totalMalloced);
82 void* SabArena::armalloc(int size, int alignment /* = sizeof(void*) */)
85 int thisBloxize = bloxize;
87 block0 = blockn = newBlock(bloxize);
88 if ((blockn -> freeSpace &= ~(alignment - 1)) < size) // align as necessary
91 thisBloxize = size | 15 + 1;
92 blockn = blockn -> next = newBlock(thisBloxize);
94 blockn -> freeSpace -= size;
95 return ((char*)(blockn -> data)) + (thisBloxize - blockn -> freeSpace - size);
98 void SabArena::arfree(void *p)