1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
/* yForth? - Written by Luca Padovani (C) 1996/97
* ------------------------------------------------------------------------
* This software is FreeWare as long as it comes with this header in each
* source file, anyway you can use it or any part of it whatever
* you want. It comes without any warranty, so use it at your own risk.
* ------------------------------------------------------------------------
* Module name: memall.c
* Abstract: Memory allocation word set
*/
#include <string.h>
#include <malloc.h>
#include "yforth.h"
#include "core.h"
#include "coree.h"
/**************************************************************************/
/* WORDS ******************************************************************/
/**************************************************************************/
void _allocate() {
register void *addr = malloc(*sp);
if (addr == NULL) *sp = 0;
else *sp = (Cell) addr;
*--sp = FFLAG(addr == NULL);
}
void _free() {
free((void *) *sp);
*sp = FFLAG(0);
}
void _resize() {
register void *addr = realloc((void *) sp[1], sp[0]);
if (addr == NULL) sp[1] = 0;
else sp[1] = (Cell) addr;
*sp = FFLAG(addr == NULL);
}
|