syscalls.c 5.6 KB
Newer Older
1 2 3 4 5 6 7
/*
 * Copyright (c) 2006-2018, RT-Thread Development Team
 *
 * 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
11
 */
12

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

18 19
#include <rtthread.h>

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

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

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

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

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

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 93
    if (fd >=0 && fd < 3)
        return 1;
94

mysterywolf's avatar
mysterywolf 已提交
95 96
    ptr->_errno = ENOTTY ;
    return 0;
97 98 99 100 101
}

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

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

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

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

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

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

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

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

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

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

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

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

void *
_sbrk_r(struct _reent *ptr, ptrdiff_t incr)
{
B
BernardXiong 已提交
193 194
    /* no use this routine to get memory */
    return RT_NULL;
195 196 197 198 199
}

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

B
BernardXiong 已提交
207 208
    rc = stat(file, pstat);
    return rc;
209
#endif
210 211 212 213 214
}

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

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

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

B
BernardXiong 已提交
241 242 243
        console = rt_console_get_device();
        if (console) return rt_device_write(console, -1, buf, nbytes);
    }
244

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

B
BernardXiong 已提交
254 255
    rc = write(fd, buf, nbytes);
    return rc;
256
#endif
257 258 259 260 261 262
}

/* Memory routine */
void *
_malloc_r (struct _reent *ptr, size_t size)
{
B
BernardXiong 已提交
263
    void* result;
264

B
BernardXiong 已提交
265 266 267 268 269
    result = (void*)rt_malloc (size);
    if (result == RT_NULL)
    {
        ptr->_errno = ENOMEM;
    }
270

B
BernardXiong 已提交
271
    return result;
272 273 274 275 276
}

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

B
BernardXiong 已提交
279 280 281 282 283
    result = (void*)rt_realloc (old, newlen);
    if (result == RT_NULL)
    {
        ptr->_errno = ENOMEM;
    }
284

B
BernardXiong 已提交
285
    return result;
286 287 288 289
}

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

B
BernardXiong 已提交
292 293 294 295 296
    result = (void*)rt_calloc (size, len);
    if (result == RT_NULL)
    {
        ptr->_errno = ENOMEM;
    }
297

B
BernardXiong 已提交
298
    return result;
299 300
}

301
void
302 303
_free_r (struct _reent *ptr, void *addr)
{
B
BernardXiong 已提交
304
    rt_free (addr);
305 306
}

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

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

void __libc_init_array(void)
{
B
BernardXiong 已提交
325
    /* we not use __libc init_aray to initialize C++ objects */
326
}
327

328 329 330 331 332
mode_t umask(mode_t mask)
{
    return 022;
}

333 334 335 336
int flock(int fd, int operation)
{
    return 0;
}
337 338

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