Mercurial > ~darius > hgwebdir.cgi > stm32temp
view syscalls.c @ 6:2b92d9632999
Add LCD app note.
author | Daniel O'Connor <darius@dons.net.au> |
---|---|
date | Sat, 14 Jan 2012 11:42:24 +1030 |
parents | 74e9b3baac1e |
children | 2bce4dbf52b8 |
line wrap: on
line source
/* * syscalls.c * * Created on: 03.12.2009 * Author: Martin Thomas, 3BSD license */ #include <stdio.h> #include <reent.h> #include <errno.h> #include <stdlib.h> /* abort */ #include <sys/types.h> #include <sys/stat.h> #include <sys/time.h> #include "comm.h" #include "stm32f10x.h" /* for _get_PSP() from core_cm3.h*/ #undef errno extern int errno; int _kill(int pid, int sig) { pid = pid; sig = sig; /* avoid warnings */ errno = EINVAL; return -1; } void _exit(int status) { printf("_exit called with parameter %d\n", status); while(1) ; } int _getpid(void) { return 1; } extern char _end; /* Defined by the linker */ static char *heap_end; char * get_heap_end(void) { return (char*) heap_end; } char * get_stack_top(void) { /* Use MSP (vs PSP) - the processor is in Thread mode out of reset */ return (char*) __get_MSP(); } caddr_t _sbrk(int incr) { char *prev_heap_end; if (heap_end == 0) { heap_end = &_end; } prev_heap_end = heap_end; if (heap_end + incr > get_stack_top()) { printf("Heap and stack collision\n"); abort(); } heap_end += incr; return (caddr_t) prev_heap_end; } int _close(int file) { file = file; /* avoid warning */ return -1; } int _fstat(int file, struct stat *st) { file = file; /* avoid warning */ st->st_mode = S_IFCHR; return 0; } int _isatty(int file) { file = file; /* avoid warning */ return 1; } int _lseek(int file, int ptr, int dir) { file = file; /* avoid warning */ ptr = ptr; /* avoid warning */ dir = dir; /* avoid warning */ return 0; } int _read(int file, char *ptr, int len) { file = file; /* avoid warning */ ptr = ptr; /* avoid warning */ len = len; /* avoid warning */ return 0; } int _write(int file, char *ptr, int len) { int todo; file = file; /* avoid warning */ for (todo = 0; todo < len; todo++) { comm_put(*ptr++); } return len; } int _gettimeofday_r(struct _reent *reent __attribute__((unused)), struct timeval *tp, void *tzp __attribute__((unused))) { tp->tv_sec = RTC_GetCounter(); tp->tv_usec = 0; return 0; } int settimeofday(const struct timeval *tp, const struct timezone *tzp __attribute__((unused))) { RTC_SetCounter(tp->tv_sec); return 0; } clock_t _clock (void) { return RTC_GetCounter(); } void __tz_lock (void) { } void __tz_unlock (void) { } static __tzinfo_type tzinfo = {1, 0, { {'J', 0, 0, 0, 0, (time_t)0, 0L }, {'J', 0, 0, 0, 0, (time_t)0, 0L } } }; __tzinfo_type * __gettzinfo (void) { return &tzinfo; } /* Stub, required for strftime?! */ int _open(const char *name __attribute__((unused)), int mode __attribute__((unused)), ...) { return -1; }