diff options
author | Ranjith Kumaran <ranjith@cygnus.com> | 2000-03-17 22:48:54 +0000 |
---|---|---|
committer | Ranjith Kumaran <ranjith@cygnus.com> | 2000-03-17 22:48:54 +0000 |
commit | 03261851a10dd2d6900a0a00a7515a0a46fb5d76 (patch) | |
tree | 7c22ac6cbbc99fd5cd1b5426853be8d4fd7bfcf1 /libgloss/mn10300/sbrk.c | |
parent | fae4c299f14fc23e2829c8656992eba21f79242a (diff) | |
download | cygnal-03261851a10dd2d6900a0a00a7515a0a46fb5d76.tar.gz cygnal-03261851a10dd2d6900a0a00a7515a0a46fb5d76.tar.bz2 cygnal-03261851a10dd2d6900a0a00a7515a0a46fb5d76.zip |
20000317 sourceware import
Diffstat (limited to 'libgloss/mn10300/sbrk.c')
-rw-r--r-- | libgloss/mn10300/sbrk.c | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/libgloss/mn10300/sbrk.c b/libgloss/mn10300/sbrk.c new file mode 100644 index 000000000..376fd3285 --- /dev/null +++ b/libgloss/mn10300/sbrk.c @@ -0,0 +1,31 @@ +#include <_ansi.h> +#include <sys/types.h> +#include <sys/stat.h> +#include "trap.h" + + +caddr_t +_sbrk (size_t incr) +{ + extern char end; /* Defined by the linker */ + static char *heap_end; + char *prev_heap_end; +#if 0 + char *sp = (char *)stack_ptr; +#else + char *sp = (char *)&sp; +#endif + + if (heap_end == 0) + { + heap_end = &end; + } + prev_heap_end = heap_end; + heap_end += incr; + if (heap_end > sp) + { + _write (1, "Heap and stack collision\n", 25); + abort (); + } + return (caddr_t) prev_heap_end; +} |