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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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