summaryrefslogtreecommitdiff
path: root/newlib/libc/sys/h8300hms/sbrk.c
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2017-12-15 09:38:53 -0500
committerPikalaxALT <pikalaxalt@gmail.com>2017-12-15 09:39:34 -0500
commitf95a4a932476be2ba99e2fd081e8d2bc6ea12813 (patch)
tree75f67192cb2d7b7b575c94edda318e475239b63c /newlib/libc/sys/h8300hms/sbrk.c
parentf60aca96985e68c7d8a52eb7bc955fb80e132f73 (diff)
Import newlib and create makefile
Diffstat (limited to 'newlib/libc/sys/h8300hms/sbrk.c')
-rw-r--r--newlib/libc/sys/h8300hms/sbrk.c28
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 0000000..1456a67
--- /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;
+}
+