📄 execr.c
字号:
/* Reentrant versions of execution system calls. These implementations just call the usual system calls. */#include <reent.h>#include <unistd.h>#include <_syslist.h>/* Some targets provides their own versions of these functions. Those targets should define REENTRANT_SYSCALLS_PROVIDED in TARGET_CFLAGS. */#ifdef _REENT_ONLY#ifndef REENTRANT_SYSCALLS_PROVIDED#define REENTRANT_SYSCALLS_PROVIDED#endif#endif/* If NO_EXEC is defined, we don't need these functions. */#if defined (REENTRANT_SYSCALLS_PROVIDED) || defined (NO_EXEC)int _dummy_exec_syscalls = 1;#else/* We use the errno variable used by the system dependent layer. */#undef errnoint errno;/*FUNCTION <<_fork_r>>---Reentrant version of fork INDEX _fork_rANSI_SYNOPSIS #include <reent.h> int _fork_r(struct _reent *<[ptr]>);TRAD_SYNOPSIS #include <reent.h> int _fork_r(<[ptr]>) struct _reent *<[ptr]>;DESCRIPTION This is a reentrant version of <<fork>>. It takes a pointer to the global data block, which holds <<errno>>.*/int_fork_r (ptr) struct _reent *ptr;{ int ret; errno = 0; ret = _fork (); if (errno != 0) ptr->_errno = errno; return ret;}/*FUNCTION <<_wait_r>>---Reentrant version of wait INDEX _wait_rANSI_SYNOPSIS #include <reent.h> int _wait_r(struct _reent *<[ptr]>, int *<[status]>);TRAD_SYNOPSIS #include <reent.h> int _wait_r(<[ptr]>, <[status]>) struct _reent *<[ptr]>; int *<[status]>;DESCRIPTION This is a reentrant version of <<wait>>. It takes a pointer to the global data block, which holds <<errno>>.*/int_wait_r (ptr, status) struct _reent *ptr; int *status;{ int ret; errno = 0; ret = _wait (status); if (errno != 0) ptr->_errno = errno; return ret;}#endif /* ! defined (REENTRANT_SYSCALLS_PROVIDED) */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -