diff options
author | Christopher Faylor <cgf@redhat.com> | 2000-02-17 19:39:46 +0000 |
---|---|---|
committer | Christopher Faylor <cgf@redhat.com> | 2000-02-17 19:39:46 +0000 |
commit | 6d491d8ad9122891d1a48447e8c49702eb678921 (patch) | |
tree | 45619a131b9f211ceca9fce7a866328344bf00ec /newlib/libc/sys/h8300hms/sbrk.c | |
parent | bd592806f45307757c24ec3f75bdefe13abfd51f (diff) | |
download | gdb-6d491d8ad9122891d1a48447e8c49702eb678921.tar.gz |
import newlib-2000-02-17 snapshotcvs/SNAPSHOT
Diffstat (limited to 'newlib/libc/sys/h8300hms/sbrk.c')
-rw-r--r-- | newlib/libc/sys/h8300hms/sbrk.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/newlib/libc/sys/h8300hms/sbrk.c b/newlib/libc/sys/h8300hms/sbrk.c new file mode 100644 index 00000000000..1456a67eb81 --- /dev/null +++ b/newlib/libc/sys/h8300hms/sbrk.c @@ -0,0 +1,28 @@ +#include <_ansi.h> +#include <sys/types.h> +#include <sys/stat.h> + +register char *stack_ptr asm ("sp"); + +caddr_t + _sbrk(incr) + int incr; +{ + extern char end; /* Defined by the linker */ + static char *heap_end; + char *prev_heap_end; + + if (heap_end == 0) + { + heap_end = &end; + } + prev_heap_end = heap_end; + if (heap_end + incr > stack_ptr) + { + _write (1, "Heap and stack collision\n", 25); + abort (); + } + heap_end += incr; + return (caddr_t)prev_heap_end; +} + |