syscalls.c 5.6 KB
Newer Older
1
/*
2
 * Copyright (c) 2006-2021, RT-Thread Development Team
3 4 5 6 7
 *
 * SPDX-License-Identifier: Apache-2.0
 *
 * Change Logs:
 * Date           Author       Notes
8
 * 2021-02-11     Meco Man     remove _gettimeofday_r() and _times_r()
9
 * 2020-02-13     Meco Man     re-implement exit() and abort()
mysterywolf's avatar
mysterywolf 已提交
10
 * 2020-02-21     Meco Man     improve and beautify syscalls
mysterywolf's avatar
mysterywolf 已提交
11
 * 2020-02-24     Meco Man     fix bug of _isatty_r()
12
 */
13

14
#include <reent.h>
mysterywolf's avatar
mysterywolf 已提交
15
#include <errno.h>
16
#include <stdio.h>
mysterywolf's avatar
mysterywolf 已提交
17
#include <sys/time.h>
18

19 20
#include <rtthread.h>

B
Bernard Xiong 已提交
21 22 23 24
#ifdef RT_USING_DFS
#include <dfs_posix.h>
#endif

25 26 27 28
#ifdef RT_USING_MODULE
#include <dlmodule.h>
#endif

29 30
/* Reentrant versions of system calls.  */

31 32 33 34 35 36 37 38
#ifndef _REENT_ONLY
int *
__errno ()
{
  return _rt_errno();
}
#endif

mysterywolf's avatar
update  
mysterywolf 已提交
39 40 41
int
_getpid_r(struct _reent *ptr)
{
mysterywolf's avatar
update  
mysterywolf 已提交
42
    return 0;
mysterywolf's avatar
update  
mysterywolf 已提交
43 44
}

45 46 47
int
_close_r(struct _reent *ptr, int fd)
{
48
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
49 50 51
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
52
#else
B
BernardXiong 已提交
53
    return close(fd);
54
#endif
55 56 57 58 59
}

int
_execve_r(struct _reent *ptr, const char * name, char *const *argv, char *const *env)
{
B
BernardXiong 已提交
60 61 62
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
63 64 65 66 67
}

int
_fcntl_r(struct _reent *ptr, int fd, int cmd, int arg)
{
B
BernardXiong 已提交
68 69 70
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
71 72 73 74 75
}

int
_fork_r(struct _reent *ptr)
{
B
BernardXiong 已提交
76 77 78
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
79 80 81 82 83
}

int
_fstat_r(struct _reent *ptr, int fd, struct stat *pstat)
{
B
BernardXiong 已提交
84 85 86
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
87 88 89 90 91
}

int
_isatty_r(struct _reent *ptr, int fd)
{
mysterywolf's avatar
mysterywolf 已提交
92
    if (fd >=0 && fd < 3)
mysterywolf's avatar
mysterywolf 已提交
93
    {
mysterywolf's avatar
mysterywolf 已提交
94
        return 1;
mysterywolf's avatar
mysterywolf 已提交
95 96 97 98 99
    }
    else
    {
        return 0;
    }
100
}
mysterywolf's avatar
mysterywolf 已提交
101

102 103 104
int
_kill_r(struct _reent *ptr, int pid, int sig)
{
B
BernardXiong 已提交
105 106 107
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
108 109 110 111 112
}

int
_link_r(struct _reent *ptr, const char *old, const char *new)
{
B
BernardXiong 已提交
113 114 115
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
116 117 118 119 120
}

_off_t
_lseek_r(struct _reent *ptr, int fd, _off_t pos, int whence)
{
121
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
122 123 124
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
125
#else
B
BernardXiong 已提交
126
    _off_t rc;
127

B
BernardXiong 已提交
128 129
    rc = lseek(fd, pos, whence);
    return rc;
130
#endif
131 132 133 134 135
}

int
_mkdir_r(struct _reent *ptr, const char *name, int mode)
{
136
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
137 138 139
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
140
#else
B
BernardXiong 已提交
141
    int rc;
142

B
BernardXiong 已提交
143 144
    rc = mkdir(name, mode);
    return rc;
145
#endif
146 147 148 149 150
}

int
_open_r(struct _reent *ptr, const char *file, int flags, int mode)
{
151
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
152 153 154
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
155
#else
B
BernardXiong 已提交
156
    int rc;
157

B
BernardXiong 已提交
158 159
    rc = open(file, flags, mode);
    return rc;
160
#endif
161 162
}

163
_ssize_t
164 165
_read_r(struct _reent *ptr, int fd, void *buf, size_t nbytes)
{
166
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
167 168 169
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
170
#else
B
BernardXiong 已提交
171
    _ssize_t rc;
172

B
BernardXiong 已提交
173 174
    rc = read(fd, buf, nbytes);
    return rc;
175
#endif
176 177 178 179 180
}

int
_rename_r(struct _reent *ptr, const char *old, const char *new)
{
181
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
182 183 184
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
185
#else
B
BernardXiong 已提交
186
    int rc;
187

B
BernardXiong 已提交
188 189
    rc = rename(old, new);
    return rc;
190
#endif
191 192 193 194 195
}

int
_stat_r(struct _reent *ptr, const char *file, struct stat *pstat)
{
196
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
197 198 199
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
200
#else
B
BernardXiong 已提交
201
    int rc;
202

B
BernardXiong 已提交
203 204
    rc = stat(file, pstat);
    return rc;
205
#endif
206 207 208 209 210
}

int
_unlink_r(struct _reent *ptr, const char *file)
{
211
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
212 213
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
214
    return -1;
215
#else
216
    return unlink(file);
217
#endif
218 219 220 221 222
}

int
_wait_r(struct _reent *ptr, int *status)
{
B
BernardXiong 已提交
223 224 225
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
226 227 228 229 230
}

_ssize_t
_write_r(struct _reent *ptr, int fd, const void *buf, size_t nbytes)
{
B
bernard 已提交
231
#ifndef RT_USING_DFS
mysterywolf's avatar
mysterywolf 已提交
232
#ifdef RT_USING_DEVICE
233
    if (fileno(stdout) == fd)
B
BernardXiong 已提交
234 235
    {
        rt_device_t console;
236

B
BernardXiong 已提交
237 238 239
        console = rt_console_get_device();
        if (console) return rt_device_write(console, -1, buf, nbytes);
    }
240

B
bernard 已提交
241
    return 0;
mysterywolf's avatar
mysterywolf 已提交
242 243 244 245 246
#else
    /* return "not supported" */
    ptr->_errno = ENOTSUP;
    return -1;
#endif /*RT_USING_DEVICE*/
247
#else
B
BernardXiong 已提交
248
    _ssize_t rc;
B
bernard 已提交
249

B
BernardXiong 已提交
250 251
    rc = write(fd, buf, nbytes);
    return rc;
252
#endif
253 254
}

255
#ifdef RT_USING_HEAP /* Memory routine */
256 257 258
void *
_malloc_r (struct _reent *ptr, size_t size)
{
B
BernardXiong 已提交
259
    void* result;
260

B
BernardXiong 已提交
261 262 263 264 265
    result = (void*)rt_malloc (size);
    if (result == RT_NULL)
    {
        ptr->_errno = ENOMEM;
    }
266

B
BernardXiong 已提交
267
    return result;
268 269 270 271 272
}

void *
_realloc_r (struct _reent *ptr, void *old, size_t newlen)
{
B
BernardXiong 已提交
273
    void* result;
274

B
BernardXiong 已提交
275 276 277 278 279
    result = (void*)rt_realloc (old, newlen);
    if (result == RT_NULL)
    {
        ptr->_errno = ENOMEM;
    }
280

B
BernardXiong 已提交
281
    return result;
282 283 284 285
}

void *_calloc_r (struct _reent *ptr, size_t size, size_t len)
{
B
BernardXiong 已提交
286
    void* result;
287

B
BernardXiong 已提交
288 289 290 291 292
    result = (void*)rt_calloc (size, len);
    if (result == RT_NULL)
    {
        ptr->_errno = ENOMEM;
    }
293

B
BernardXiong 已提交
294
    return result;
295 296
}

297
void
298 299
_free_r (struct _reent *ptr, void *addr)
{
B
BernardXiong 已提交
300
    rt_free (addr);
301 302
}

303 304 305 306 307 308 309 310
#else
void *
_sbrk_r(struct _reent *ptr, ptrdiff_t incr)
{
    return RT_NULL;
}
#endif /*RT_USING_HEAP*/

mysterywolf's avatar
update  
mysterywolf 已提交
311
/* for exit() and abort() */
mysterywolf's avatar
mysterywolf 已提交
312 313
__attribute__ ((noreturn)) void
_exit (int status)
314
{
mysterywolf's avatar
update  
mysterywolf 已提交
315 316
    extern void __rt_libc_exit(int status);
    __rt_libc_exit(status);
mysterywolf's avatar
update  
mysterywolf 已提交
317
    while(1);
318
}
319

320
void
321 322
_system(const char *s)
{
mysterywolf's avatar
update  
mysterywolf 已提交
323 324
    extern int __rt_libc_system(const char *string);
    __rt_libc_system(s);
325
}
326 327 328

void __libc_init_array(void)
{
B
BernardXiong 已提交
329
    /* we not use __libc init_aray to initialize C++ objects */
330
}
331

332 333 334 335 336
mode_t umask(mode_t mask)
{
    return 022;
}

337 338 339 340
int flock(int fd, int operation)
{
    return 0;
}
341 342

/*
mysterywolf's avatar
mysterywolf 已提交
343
These functions are implemented and replaced by the 'common/time.c' file
344 345 346
int _gettimeofday_r(struct _reent *ptr, struct timeval *__tp, void *__tzp);
_CLOCK_T_  _times_r(struct _reent *ptr, struct tms *ptms);
*/