1@c -*- Texinfo -*- 2@node Syscalls 3@chapter System Calls 4 5@cindex linking the C library 6The C subroutine library depends on a handful of subroutine calls for 7operating system services. If you use the C library on a system that 8complies with the POSIX.1 standard (also known as IEEE 1003.1), most of 9these subroutines are supplied with your operating system. 10 11If some of these subroutines are not provided with your system---in 12the extreme case, if you are developing software for a ``bare board'' 13system, without an OS---you will at least need to provide do-nothing 14stubs (or subroutines with minimal functionality) to allow your 15programs to link with the subroutines in @code{libc.a}. 16 17@menu 18* Stubs:: Definitions for OS interface 19* Reentrant Syscalls:: Reentrant covers for OS subroutines 20@end menu 21 22@node Stubs 23@section Definitions for OS interface 24@cindex stubs 25 26@cindex subroutines for OS interface 27@cindex OS interface subroutines 28This is the complete set of system definitions (primarily subroutines) 29required; the examples shown implement the minimal functionality 30required to allow @code{libc} to link, and fail gracefully where OS 31services are not available. 32 33Graceful failure is permitted by returning an error code. A minor 34complication arises here: the C library must be compatible with 35development environments that supply fully functional versions of these 36subroutines. Such environments usually return error codes in a global 37@code{errno}. However, the Red Hat newlib C library provides a @emph{macro} 38definition for @code{errno} in the header file @file{errno.h}, as part 39of its support for reentrant routines (@pxref{Reentrancy,,Reentrancy}). 40 41@cindex @code{errno} global vs macro 42The bridge between these two interpretations of @code{errno} is 43straightforward: the C library routines with OS interface calls 44capture the @code{errno} values returned globally, and record them in 45the appropriate field of the reentrancy structure (so that you can query 46them using the @code{errno} macro from @file{errno.h}). 47 48This mechanism becomes visible when you write stub routines for OS 49interfaces. You must include @file{errno.h}, then disable the macro, 50like this: 51 52@example 53#include <errno.h> 54#undef errno 55extern int errno; 56@end example 57 58@noindent 59The examples in this chapter include this treatment of @code{errno}. 60 61@ftable @code 62@item _exit 63Exit a program without cleaning up files. If your system doesn't 64provide this, it is best to avoid linking with subroutines that require 65it (@code{exit}, @code{system}). 66 67@item close 68Close a file. Minimal implementation: 69 70@example 71int close(int file) @{ 72 return -1; 73@} 74@end example 75 76@item environ 77A pointer to a list of environment variables and their values. For a 78minimal environment, this empty list is adequate: 79 80@example 81char *__env[1] = @{ 0 @}; 82char **environ = __env; 83@end example 84 85@item execve 86Transfer control to a new process. Minimal implementation (for a system 87without processes): 88 89@example 90#include <errno.h> 91#undef errno 92extern int errno; 93int execve(char *name, char **argv, char **env) @{ 94 errno = ENOMEM; 95 return -1; 96@} 97@end example 98 99@item fork 100Create a new process. Minimal implementation (for a system without processes): 101 102@example 103#include <errno.h> 104#undef errno 105extern int errno; 106int fork(void) @{ 107 errno = EAGAIN; 108 return -1; 109@} 110@end example 111 112@item fstat 113Status of an open file. For consistency with other minimal 114implementations in these examples, all files are regarded as character 115special devices. The @file{sys/stat.h} header file required is 116distributed in the @file{include} subdirectory for this C library. 117 118@example 119#include <sys/stat.h> 120int fstat(int file, struct stat *st) @{ 121 st->st_mode = S_IFCHR; 122 return 0; 123@} 124@end example 125 126@item getpid 127Process-ID; this is sometimes used to generate strings unlikely to 128conflict with other processes. Minimal implementation, for a system 129without processes: 130 131@example 132int getpid(void) @{ 133 return 1; 134@} 135@end example 136 137@item isatty 138Query whether output stream is a terminal. For consistency with the 139other minimal implementations, which only support output to 140@code{stdout}, this minimal implementation is suggested: 141 142@example 143int isatty(int file) @{ 144 return 1; 145@} 146@end example 147 148@item kill 149Send a signal. Minimal implementation: 150 151@example 152#include <errno.h> 153#undef errno 154extern int errno; 155int kill(int pid, int sig) @{ 156 errno = EINVAL; 157 return -1; 158@} 159@end example 160 161@item link 162Establish a new name for an existing file. Minimal implementation: 163 164@example 165#include <errno.h> 166#undef errno 167extern int errno; 168int link(char *old, char *new) @{ 169 errno = EMLINK; 170 return -1; 171@} 172@end example 173 174@item lseek 175Set position in a file. Minimal implementation: 176 177@example 178int lseek(int file, int ptr, int dir) @{ 179 return 0; 180@} 181@end example 182 183@item open 184Open a file. Minimal implementation: 185 186@example 187int open(const char *name, int flags, int mode) @{ 188 return -1; 189@} 190@end example 191 192@item read 193Read from a file. Minimal implementation: 194 195@example 196int read(int file, char *ptr, int len) @{ 197 return 0; 198@} 199@end example 200 201@item sbrk 202Increase program data space. As @code{malloc} and related functions 203depend on this, it is useful to have a working implementation. The 204following suffices for a standalone system; it exploits the symbol 205@code{_end} automatically defined by the GNU linker. 206 207@example 208@group 209caddr_t sbrk(int incr) @{ 210 extern char _end; /* @r{Defined by the linker} */ 211 static char *heap_end; 212 char *prev_heap_end; 213 214 if (heap_end == 0) @{ 215 heap_end = &_end; 216 @} 217 prev_heap_end = heap_end; 218 if (heap_end + incr > stack_ptr) @{ 219 write (1, "Heap and stack collision\n", 25); 220 abort (); 221 @} 222 223 heap_end += incr; 224 return (caddr_t) prev_heap_end; 225@} 226@end group 227@end example 228 229@item stat 230Status of a file (by name). Minimal implementation: 231 232@example 233int stat(char *file, struct stat *st) @{ 234 st->st_mode = S_IFCHR; 235 return 0; 236@} 237@end example 238 239@item times 240Timing information for current process. Minimal implementation: 241 242@example 243int times(struct tms *buf) @{ 244 return -1; 245@} 246@end example 247 248@item unlink 249Remove a file's directory entry. Minimal implementation: 250 251@example 252#include <errno.h> 253#undef errno 254extern int errno; 255int unlink(char *name) @{ 256 errno = ENOENT; 257 return -1; 258@} 259@end example 260 261@item wait 262Wait for a child process. Minimal implementation: 263@example 264#include <errno.h> 265#undef errno 266extern int errno; 267int wait(int *status) @{ 268 errno = ECHILD; 269 return -1; 270@} 271@end example 272 273@item write 274Write to a file. @file{libc} subroutines will use this 275system routine for output to all files, @emph{including} 276@code{stdout}---so if you need to generate any output, for example to a 277serial port for debugging, you should make your minimal @code{write} 278capable of doing this. The following minimal implementation is an 279incomplete example; it relies on a @code{outbyte} subroutine (not 280shown; typically, you must write this in assembler from examples 281provided by your hardware manufacturer) to actually perform the output. 282 283@example 284@group 285int write(int file, char *ptr, int len) @{ 286 int todo; 287 288 for (todo = 0; todo < len; todo++) @{ 289 outbyte (*ptr++); 290 @} 291 return len; 292@} 293@end group 294@end example 295 296@end ftable 297 298@page 299@node Reentrant Syscalls 300@section Reentrant covers for OS subroutines 301 302Since the system subroutines are used by other library routines that 303require reentrancy, @file{libc.a} provides cover routines (for example, 304the reentrant version of @code{fork} is @code{_fork_r}). These cover 305routines are consistent with the other reentrant subroutines in this 306library, and achieve reentrancy by using a reserved global data block 307(@pxref{Reentrancy,,Reentrancy}). 308 309@menu 310* Function _close_r:: Reentrant version of close 311* Function _execve_r:: Reentrant version of execve 312* Function _fork_r:: Reentrant version of fork 313@ifset STDIO64 314* Function _fstat64_r:: Reentrant version of fstat64 315@end ifset 316* Function _fstat_r:: Reentrant version of fstat 317* Function _getpid_r:: Reentrant version of getpid 318* Function _kill_r:: Reentrant version of kill 319* Function _link_r:: Reentrant version of link 320@ifset STDIO64 321* Function _lseek64_r:: Reentrant version of lseek64 322@end ifset 323* Function _lseek_r:: Reentrant version of lseek 324@ifset STDIO64 325* Function _open64_r:: Reentrant version of open64 326@end ifset 327* Function _open_r:: Reentrant version of open 328* Function _read_r:: Reentrant version of read 329* Function _sbrk_r:: Reentrant version of sbrk 330@ifset STDIO64 331* Function _stat64_r:: Reentrant version of stat64 332@end ifset 333* Function _stat_r:: Reentrant version of stat 334* Function _times_r:: Reentrant version of times 335* Function _unlink_r:: Reentrant version of unlink 336* Function _wait_r:: Reentrant version of wait 337* Function _write_r:: Reentrant version of write 338@end menu 339 340@lowersections 341@page 342@include reent/closer.def 343 344@page 345@include reent/execr.def 346 347@ifset STDIO64 348@page 349@include reent/fstat64r.def 350@end ifset 351 352@page 353@include reent/fstatr.def 354 355@page 356@include reent/linkr.def 357 358@ifset STDIO64 359@page 360@include reent/lseek64r.def 361@end ifset 362 363@page 364@include reent/lseekr.def 365 366@ifset STDIO64 367@page 368@include reent/open64r.def 369@end ifset 370 371@page 372@include reent/openr.def 373 374@page 375@include reent/readr.def 376 377@page 378@include reent/sbrkr.def 379 380@page 381@include reent/signalr.def 382 383@ifset STDIO64 384@page 385@include reent/stat64r.def 386@end ifset 387 388@page 389@include reent/statr.def 390 391@page 392@include reent/timesr.def 393 394@page 395@include reent/unlinkr.def 396 397@page 398@include reent/writer.def 399@raisesections 400