summaryrefslogtreecommitdiff
path: root/newlib/libc/sys/sysnecv850/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/sysnecv850/sbrk.c
parentf60aca96985e68c7d8a52eb7bc955fb80e132f73 (diff)
Import newlib and create makefile
Diffstat (limited to 'newlib/libc/sys/sysnecv850/sbrk.c')
-rw-r--r--newlib/libc/sys/sysnecv850/sbrk.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/newlib/libc/sys/sysnecv850/sbrk.c b/newlib/libc/sys/sysnecv850/sbrk.c
new file mode 100644
index 0000000..b413705
--- /dev/null
+++ b/newlib/libc/sys/sysnecv850/sbrk.c
@@ -0,0 +1,36 @@
+#include <_ansi.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include "sys/syscall.h"
+
+int errno;
+
+int __trap0 (int function, int p1, int p2, int p3);
+
+#define TRAP0(f, p1, p2, p3) __trap0(f, (int)(p1), (int)(p2), (int)(p3))
+
+caddr_t
+_sbrk (int 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;
+ if (heap_end + incr > sp)
+ {
+ _write (1, "Heap and stack collision\n", 25);
+ abort ();
+ }
+ heap_end += incr;
+ return (caddr_t) prev_heap_end;
+}