/* * File : stubs.c * Brief : reimplement some basic functions of arm standard c library * * This file is part of Device File System in RT-Thread RTOS * COPYRIGHT (C) 2004-2012, RT-Thread Development Team * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at * http://www.rt-thread.org/license/LICENSE. * * Change Logs: * Date Author Notes * 2012-11-23 Yihui The first version */ #include #include #include "rtthread.h" #ifdef RT_USING_DFS #include "dfs_posix.h" #endif #pragma import(__use_no_semihosting_swi) /* TODO: Standard IO device handles. */ #define STDIN 1 #define STDOUT 2 #define STDERR 3 /* Standard IO device name defines. */ const char __stdin_name[] = "STDIN"; const char __stdout_name[] = "STDOUT"; const char __stderr_name[] = "STDERR"; /** * required by fopen() and freopen(). * * @param name - file name with path. * @param openmode - a bitmap hose bits mostly correspond directly to * the ISO mode specification. * @return -1 if an error occurs. */ FILEHANDLE _sys_open(const char *name, int openmode) { /* Register standard Input Output devices. */ if (strcmp(name, __stdin_name) == 0) return (STDIN); if (strcmp(name, __stdout_name) == 0) return (STDOUT); if (strcmp(name, __stderr_name) == 0) return (STDERR); #ifndef RT_USING_DFS return -1; #else /* TODO: adjust open file mode */ return open(name, openmode, 0); #endif } int _sys_close(FILEHANDLE fh) { #ifndef RT_USING_DFS return 0; #else if (fh < 3) return 0; return close(fh); #endif } /** * read data * * @param fh - file handle * @param buf - buffer to save read data * @param len - max length of data buffer * @param mode - useless, for historical reasons * @return actual read data length */ int _sys_read(FILEHANDLE fh, unsigned char *buf, unsigned len, int mode) { if (fh == STDIN) { /* TODO */ return 0; } #ifndef RT_USING_DFS return 0; #else return read(fh, buf, len); #endif } /** * write data * * @param fh - file handle * @param buf - data buffer * @param len - buffer length * @param mode - useless, for historical reasons * @return actual written data length */ int _sys_write(FILEHANDLE fh, const unsigned char *buf, unsigned len, int mode) { if ((fh == STDOUT) || (fh == STDERR)) { #ifndef RT_USING_CONSOLE return 0; #else rt_device_t console_device; extern rt_device_t rt_console_get_device(void); console_device = rt_console_get_device(); if (console_device != 0) rt_device_write(console_device, 0, buf, len); return len; #endif } #ifndef RT_USING_DFS return 0; #else return write(fh, buf, len); #endif } /** * put he file pointer at offset pos from the beginning of the file. * * @param pos - offset * @return the current file position, or -1 on failed */ int _sys_seek(FILEHANDLE fh, long pos) { #ifndef RT_USING_DFS return -1; #else /* position is relative to the start of file fh */ return lseek(fh, pos, 0); #endif } /** * used by tmpnam() or tmpfile() */ int _sys_tmpnam(char *name, int fileno, unsigned maxlength) { return -1; } char *_sys_command_string(char *cmd, int len) { /* no support */ return cmd; } void _ttywrch(int ch) { /* TODO */ } void _sys_exit(int return_code) { /* TODO: perhaps exit the thread which is invoking this function */ while (1); } /** * return current length of file. * * @param fh - file handle * @return file length, or -1 on failed */ long _sys_flen(FILEHANDLE fh) { return -1; } int _sys_istty(FILEHANDLE fh) { return 0; } int remove(const char *filename) { #ifndef RT_USING_DFS return -1; #else return unlink(filename); #endif } /* rename() is defined in dfs_posix.c instead */ #if 0 int rename(const char *old, const char *new) { return -1; } #endif int system(const char *string) { RT_ASSERT(0); for(;;); }