123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214 |
- /*
- * 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 <string.h>
- #include <rt_sys.h>
- #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(;;);
- }
|