1*53ee8cc1Swenshuai.xi /* This header file provides the reentrancy. */ 2*53ee8cc1Swenshuai.xi 3*53ee8cc1Swenshuai.xi /* WARNING: All identifiers here must begin with an underscore. This file is 4*53ee8cc1Swenshuai.xi included by stdio.h and others and we therefore must only use identifiers 5*53ee8cc1Swenshuai.xi in the namespace allotted to us. */ 6*53ee8cc1Swenshuai.xi 7*53ee8cc1Swenshuai.xi #ifndef _SYS_REENT_H_ 8*53ee8cc1Swenshuai.xi #ifdef __cplusplus 9*53ee8cc1Swenshuai.xi extern "C" { 10*53ee8cc1Swenshuai.xi #endif 11*53ee8cc1Swenshuai.xi #define _SYS_REENT_H_ 12*53ee8cc1Swenshuai.xi 13*53ee8cc1Swenshuai.xi #include <_ansi.h> 14*53ee8cc1Swenshuai.xi #include <sys/_types.h> 15*53ee8cc1Swenshuai.xi 16*53ee8cc1Swenshuai.xi #ifndef __Long 17*53ee8cc1Swenshuai.xi #if __LONG_MAX__ == 2147483647L 18*53ee8cc1Swenshuai.xi #define __Long long 19*53ee8cc1Swenshuai.xi typedef unsigned __Long __ULong; 20*53ee8cc1Swenshuai.xi #elif __INT_MAX__ == 2147483647 21*53ee8cc1Swenshuai.xi #define __Long int 22*53ee8cc1Swenshuai.xi typedef unsigned __Long __ULong; 23*53ee8cc1Swenshuai.xi #endif 24*53ee8cc1Swenshuai.xi #endif 25*53ee8cc1Swenshuai.xi 26*53ee8cc1Swenshuai.xi #if !defined( __Long) 27*53ee8cc1Swenshuai.xi #include <sys/types.h> 28*53ee8cc1Swenshuai.xi #endif 29*53ee8cc1Swenshuai.xi 30*53ee8cc1Swenshuai.xi #ifndef __Long 31*53ee8cc1Swenshuai.xi #define __Long __int32_t 32*53ee8cc1Swenshuai.xi typedef __uint32_t __ULong; 33*53ee8cc1Swenshuai.xi #endif 34*53ee8cc1Swenshuai.xi 35*53ee8cc1Swenshuai.xi /* 36*53ee8cc1Swenshuai.xi * If _REENT_SMALL is defined, we make struct _reent as small as possible, 37*53ee8cc1Swenshuai.xi * by having nearly everything possible allocated at first use. 38*53ee8cc1Swenshuai.xi */ 39*53ee8cc1Swenshuai.xi 40*53ee8cc1Swenshuai.xi struct _Bigint 41*53ee8cc1Swenshuai.xi { 42*53ee8cc1Swenshuai.xi struct _Bigint *_next; 43*53ee8cc1Swenshuai.xi int _k, _maxwds, _sign, _wds; 44*53ee8cc1Swenshuai.xi __ULong _x[1]; 45*53ee8cc1Swenshuai.xi }; 46*53ee8cc1Swenshuai.xi 47*53ee8cc1Swenshuai.xi /* needed by reentrant structure */ 48*53ee8cc1Swenshuai.xi struct __tm 49*53ee8cc1Swenshuai.xi { 50*53ee8cc1Swenshuai.xi int __tm_sec; 51*53ee8cc1Swenshuai.xi int __tm_min; 52*53ee8cc1Swenshuai.xi int __tm_hour; 53*53ee8cc1Swenshuai.xi int __tm_mday; 54*53ee8cc1Swenshuai.xi int __tm_mon; 55*53ee8cc1Swenshuai.xi int __tm_year; 56*53ee8cc1Swenshuai.xi int __tm_wday; 57*53ee8cc1Swenshuai.xi int __tm_yday; 58*53ee8cc1Swenshuai.xi int __tm_isdst; 59*53ee8cc1Swenshuai.xi }; 60*53ee8cc1Swenshuai.xi 61*53ee8cc1Swenshuai.xi /* 62*53ee8cc1Swenshuai.xi * atexit() support. 63*53ee8cc1Swenshuai.xi */ 64*53ee8cc1Swenshuai.xi 65*53ee8cc1Swenshuai.xi #define _ATEXIT_SIZE 32 /* must be at least 32 to guarantee ANSI conformance */ 66*53ee8cc1Swenshuai.xi 67*53ee8cc1Swenshuai.xi struct _on_exit_args { 68*53ee8cc1Swenshuai.xi void * _fnargs[_ATEXIT_SIZE]; /* user fn args */ 69*53ee8cc1Swenshuai.xi void * _dso_handle[_ATEXIT_SIZE]; 70*53ee8cc1Swenshuai.xi /* Bitmask is set if user function takes arguments. */ 71*53ee8cc1Swenshuai.xi __ULong _fntypes; /* type of exit routine - 72*53ee8cc1Swenshuai.xi Must have at least _ATEXIT_SIZE bits */ 73*53ee8cc1Swenshuai.xi /* Bitmask is set if function was registered via __cxa_atexit. */ 74*53ee8cc1Swenshuai.xi __ULong _is_cxa; 75*53ee8cc1Swenshuai.xi }; 76*53ee8cc1Swenshuai.xi 77*53ee8cc1Swenshuai.xi #ifdef _REENT_SMALL 78*53ee8cc1Swenshuai.xi struct _atexit { 79*53ee8cc1Swenshuai.xi struct _atexit *_next; /* next in list */ 80*53ee8cc1Swenshuai.xi int _ind; /* next index in this table */ 81*53ee8cc1Swenshuai.xi void (*_fns[_ATEXIT_SIZE])(void); /* the table itself */ 82*53ee8cc1Swenshuai.xi struct _on_exit_args * _on_exit_args_ptr; 83*53ee8cc1Swenshuai.xi }; 84*53ee8cc1Swenshuai.xi #else 85*53ee8cc1Swenshuai.xi struct _atexit { 86*53ee8cc1Swenshuai.xi struct _atexit *_next; /* next in list */ 87*53ee8cc1Swenshuai.xi int _ind; /* next index in this table */ 88*53ee8cc1Swenshuai.xi /* Some entries may already have been called, and will be NULL. */ 89*53ee8cc1Swenshuai.xi void (*_fns[_ATEXIT_SIZE])(void); /* the table itself */ 90*53ee8cc1Swenshuai.xi struct _on_exit_args _on_exit_args; 91*53ee8cc1Swenshuai.xi }; 92*53ee8cc1Swenshuai.xi #endif 93*53ee8cc1Swenshuai.xi 94*53ee8cc1Swenshuai.xi /* 95*53ee8cc1Swenshuai.xi * Stdio buffers. 96*53ee8cc1Swenshuai.xi * 97*53ee8cc1Swenshuai.xi * This and __FILE are defined here because we need them for struct _reent, 98*53ee8cc1Swenshuai.xi * but we don't want stdio.h included when stdlib.h is. 99*53ee8cc1Swenshuai.xi */ 100*53ee8cc1Swenshuai.xi 101*53ee8cc1Swenshuai.xi struct __sbuf { 102*53ee8cc1Swenshuai.xi unsigned char *_base; 103*53ee8cc1Swenshuai.xi int _size; 104*53ee8cc1Swenshuai.xi }; 105*53ee8cc1Swenshuai.xi 106*53ee8cc1Swenshuai.xi /* 107*53ee8cc1Swenshuai.xi * We need fpos_t for the following, but it doesn't have a leading "_", 108*53ee8cc1Swenshuai.xi * so we use _fpos_t instead. 109*53ee8cc1Swenshuai.xi */ 110*53ee8cc1Swenshuai.xi 111*53ee8cc1Swenshuai.xi typedef long _fpos_t; /* XXX must match off_t in <sys/types.h> */ 112*53ee8cc1Swenshuai.xi /* (and must be `long' for now) */ 113*53ee8cc1Swenshuai.xi 114*53ee8cc1Swenshuai.xi #ifdef __LARGE64_FILES 115*53ee8cc1Swenshuai.xi typedef _off64_t _fpos64_t; 116*53ee8cc1Swenshuai.xi #endif 117*53ee8cc1Swenshuai.xi 118*53ee8cc1Swenshuai.xi /* 119*53ee8cc1Swenshuai.xi * Stdio state variables. 120*53ee8cc1Swenshuai.xi * 121*53ee8cc1Swenshuai.xi * The following always hold: 122*53ee8cc1Swenshuai.xi * 123*53ee8cc1Swenshuai.xi * if (_flags&(__SLBF|__SWR)) == (__SLBF|__SWR), 124*53ee8cc1Swenshuai.xi * _lbfsize is -_bf._size, else _lbfsize is 0 125*53ee8cc1Swenshuai.xi * if _flags&__SRD, _w is 0 126*53ee8cc1Swenshuai.xi * if _flags&__SWR, _r is 0 127*53ee8cc1Swenshuai.xi * 128*53ee8cc1Swenshuai.xi * This ensures that the getc and putc macros (or inline functions) never 129*53ee8cc1Swenshuai.xi * try to write or read from a file that is in `read' or `write' mode. 130*53ee8cc1Swenshuai.xi * (Moreover, they can, and do, automatically switch from read mode to 131*53ee8cc1Swenshuai.xi * write mode, and back, on "r+" and "w+" files.) 132*53ee8cc1Swenshuai.xi * 133*53ee8cc1Swenshuai.xi * _lbfsize is used only to make the inline line-buffered output stream 134*53ee8cc1Swenshuai.xi * code as compact as possible. 135*53ee8cc1Swenshuai.xi * 136*53ee8cc1Swenshuai.xi * _ub, _up, and _ur are used when ungetc() pushes back more characters 137*53ee8cc1Swenshuai.xi * than fit in the current _bf, or when ungetc() pushes back a character 138*53ee8cc1Swenshuai.xi * that does not match the previous one in _bf. When this happens, 139*53ee8cc1Swenshuai.xi * _ub._base becomes non-nil (i.e., a stream has ungetc() data iff 140*53ee8cc1Swenshuai.xi * _ub._base!=NULL) and _up and _ur save the current values of _p and _r. 141*53ee8cc1Swenshuai.xi */ 142*53ee8cc1Swenshuai.xi 143*53ee8cc1Swenshuai.xi #ifdef _REENT_SMALL 144*53ee8cc1Swenshuai.xi /* 145*53ee8cc1Swenshuai.xi * struct __sFILE_fake is the start of a struct __sFILE, with only the 146*53ee8cc1Swenshuai.xi * minimal fields allocated. In __sinit() we really allocate the 3 147*53ee8cc1Swenshuai.xi * standard streams, etc., and point away from this fake. 148*53ee8cc1Swenshuai.xi */ 149*53ee8cc1Swenshuai.xi struct __sFILE_fake { 150*53ee8cc1Swenshuai.xi unsigned char *_p; /* current position in (some) buffer */ 151*53ee8cc1Swenshuai.xi int _r; /* read space left for getc() */ 152*53ee8cc1Swenshuai.xi int _w; /* write space left for putc() */ 153*53ee8cc1Swenshuai.xi short _flags; /* flags, below; this FILE is free if 0 */ 154*53ee8cc1Swenshuai.xi short _file; /* fileno, if Unix descriptor, else -1 */ 155*53ee8cc1Swenshuai.xi struct __sbuf _bf; /* the buffer (at least 1 byte, if !NULL) */ 156*53ee8cc1Swenshuai.xi int _lbfsize; /* 0 or -_bf._size, for inline putc */ 157*53ee8cc1Swenshuai.xi 158*53ee8cc1Swenshuai.xi struct _reent *_data; 159*53ee8cc1Swenshuai.xi }; 160*53ee8cc1Swenshuai.xi /* CHECK_INIT() comes from stdio/local.h; be sure to include that. */ 161*53ee8cc1Swenshuai.xi # define _REENT_SMALL_CHECK_INIT(ptr) CHECK_INIT(ptr) 162*53ee8cc1Swenshuai.xi #else 163*53ee8cc1Swenshuai.xi # define _REENT_SMALL_CHECK_INIT(ptr) /* nothing */ 164*53ee8cc1Swenshuai.xi #endif 165*53ee8cc1Swenshuai.xi 166*53ee8cc1Swenshuai.xi struct __sFILE { 167*53ee8cc1Swenshuai.xi unsigned char *_p; /* current position in (some) buffer */ 168*53ee8cc1Swenshuai.xi int _r; /* read space left for getc() */ 169*53ee8cc1Swenshuai.xi int _w; /* write space left for putc() */ 170*53ee8cc1Swenshuai.xi short _flags; /* flags, below; this FILE is free if 0 */ 171*53ee8cc1Swenshuai.xi short _file; /* fileno, if Unix descriptor, else -1 */ 172*53ee8cc1Swenshuai.xi struct __sbuf _bf; /* the buffer (at least 1 byte, if !NULL) */ 173*53ee8cc1Swenshuai.xi int _lbfsize; /* 0 or -_bf._size, for inline putc */ 174*53ee8cc1Swenshuai.xi 175*53ee8cc1Swenshuai.xi #ifdef _REENT_SMALL 176*53ee8cc1Swenshuai.xi struct _reent *_data; 177*53ee8cc1Swenshuai.xi #endif 178*53ee8cc1Swenshuai.xi 179*53ee8cc1Swenshuai.xi /* operations */ 180*53ee8cc1Swenshuai.xi _PTR _cookie; /* cookie passed to io functions */ 181*53ee8cc1Swenshuai.xi 182*53ee8cc1Swenshuai.xi _READ_WRITE_RETURN_TYPE _EXFUN((*_read),(_PTR _cookie, char *_buf, int _n)); 183*53ee8cc1Swenshuai.xi _READ_WRITE_RETURN_TYPE _EXFUN((*_write),(_PTR _cookie, const char *_buf, 184*53ee8cc1Swenshuai.xi int _n)); 185*53ee8cc1Swenshuai.xi _fpos_t _EXFUN((*_seek),(_PTR _cookie, _fpos_t _offset, int _whence)); 186*53ee8cc1Swenshuai.xi int _EXFUN((*_close),(_PTR _cookie)); 187*53ee8cc1Swenshuai.xi 188*53ee8cc1Swenshuai.xi /* separate buffer for long sequences of ungetc() */ 189*53ee8cc1Swenshuai.xi struct __sbuf _ub; /* ungetc buffer */ 190*53ee8cc1Swenshuai.xi unsigned char *_up; /* saved _p when _p is doing ungetc data */ 191*53ee8cc1Swenshuai.xi int _ur; /* saved _r when _r is counting ungetc data */ 192*53ee8cc1Swenshuai.xi 193*53ee8cc1Swenshuai.xi /* tricks to meet minimum requirements even when malloc() fails */ 194*53ee8cc1Swenshuai.xi unsigned char _ubuf[3]; /* guarantee an ungetc() buffer */ 195*53ee8cc1Swenshuai.xi unsigned char _nbuf[1]; /* guarantee a getc() buffer */ 196*53ee8cc1Swenshuai.xi 197*53ee8cc1Swenshuai.xi /* separate buffer for fgetline() when line crosses buffer boundary */ 198*53ee8cc1Swenshuai.xi struct __sbuf _lb; /* buffer for fgetline() */ 199*53ee8cc1Swenshuai.xi 200*53ee8cc1Swenshuai.xi /* Unix stdio files get aligned to block boundaries on fseek() */ 201*53ee8cc1Swenshuai.xi int _blksize; /* stat.st_blksize (may be != _bf._size) */ 202*53ee8cc1Swenshuai.xi int _offset; /* current lseek offset */ 203*53ee8cc1Swenshuai.xi 204*53ee8cc1Swenshuai.xi #ifndef _REENT_SMALL 205*53ee8cc1Swenshuai.xi struct _reent *_data; /* Here for binary compatibility? Remove? */ 206*53ee8cc1Swenshuai.xi #endif 207*53ee8cc1Swenshuai.xi 208*53ee8cc1Swenshuai.xi #ifndef __SINGLE_THREAD__ 209*53ee8cc1Swenshuai.xi _flock_t _lock; /* for thread-safety locking */ 210*53ee8cc1Swenshuai.xi #endif 211*53ee8cc1Swenshuai.xi }; 212*53ee8cc1Swenshuai.xi 213*53ee8cc1Swenshuai.xi #ifdef __LARGE64_FILES 214*53ee8cc1Swenshuai.xi struct __sFILE64 { 215*53ee8cc1Swenshuai.xi unsigned char *_p; /* current position in (some) buffer */ 216*53ee8cc1Swenshuai.xi int _r; /* read space left for getc() */ 217*53ee8cc1Swenshuai.xi int _w; /* write space left for putc() */ 218*53ee8cc1Swenshuai.xi short _flags; /* flags, below; this FILE is free if 0 */ 219*53ee8cc1Swenshuai.xi short _file; /* fileno, if Unix descriptor, else -1 */ 220*53ee8cc1Swenshuai.xi struct __sbuf _bf; /* the buffer (at least 1 byte, if !NULL) */ 221*53ee8cc1Swenshuai.xi int _lbfsize; /* 0 or -_bf._size, for inline putc */ 222*53ee8cc1Swenshuai.xi 223*53ee8cc1Swenshuai.xi struct _reent *_data; 224*53ee8cc1Swenshuai.xi 225*53ee8cc1Swenshuai.xi /* operations */ 226*53ee8cc1Swenshuai.xi _PTR _cookie; /* cookie passed to io functions */ 227*53ee8cc1Swenshuai.xi 228*53ee8cc1Swenshuai.xi _READ_WRITE_RETURN_TYPE _EXFUN((*_read),(_PTR _cookie, char *_buf, int _n)); 229*53ee8cc1Swenshuai.xi _READ_WRITE_RETURN_TYPE _EXFUN((*_write),(_PTR _cookie, const char *_buf, 230*53ee8cc1Swenshuai.xi int _n)); 231*53ee8cc1Swenshuai.xi _fpos_t _EXFUN((*_seek),(_PTR _cookie, _fpos_t _offset, int _whence)); 232*53ee8cc1Swenshuai.xi int _EXFUN((*_close),(_PTR _cookie)); 233*53ee8cc1Swenshuai.xi 234*53ee8cc1Swenshuai.xi /* separate buffer for long sequences of ungetc() */ 235*53ee8cc1Swenshuai.xi struct __sbuf _ub; /* ungetc buffer */ 236*53ee8cc1Swenshuai.xi unsigned char *_up; /* saved _p when _p is doing ungetc data */ 237*53ee8cc1Swenshuai.xi int _ur; /* saved _r when _r is counting ungetc data */ 238*53ee8cc1Swenshuai.xi 239*53ee8cc1Swenshuai.xi /* tricks to meet minimum requirements even when malloc() fails */ 240*53ee8cc1Swenshuai.xi unsigned char _ubuf[3]; /* guarantee an ungetc() buffer */ 241*53ee8cc1Swenshuai.xi unsigned char _nbuf[1]; /* guarantee a getc() buffer */ 242*53ee8cc1Swenshuai.xi 243*53ee8cc1Swenshuai.xi /* separate buffer for fgetline() when line crosses buffer boundary */ 244*53ee8cc1Swenshuai.xi struct __sbuf _lb; /* buffer for fgetline() */ 245*53ee8cc1Swenshuai.xi 246*53ee8cc1Swenshuai.xi /* Unix stdio files get aligned to block boundaries on fseek() */ 247*53ee8cc1Swenshuai.xi int _blksize; /* stat.st_blksize (may be != _bf._size) */ 248*53ee8cc1Swenshuai.xi int _flags2; /* for future use */ 249*53ee8cc1Swenshuai.xi 250*53ee8cc1Swenshuai.xi _off64_t _offset; /* current lseek offset */ 251*53ee8cc1Swenshuai.xi _fpos64_t _EXFUN((*_seek64),(_PTR _cookie, _fpos64_t _offset, int _whence)); 252*53ee8cc1Swenshuai.xi 253*53ee8cc1Swenshuai.xi #ifndef __SINGLE_THREAD__ 254*53ee8cc1Swenshuai.xi _flock_t _lock; /* for thread-safety locking */ 255*53ee8cc1Swenshuai.xi #endif 256*53ee8cc1Swenshuai.xi }; 257*53ee8cc1Swenshuai.xi typedef struct __sFILE64 __FILE; 258*53ee8cc1Swenshuai.xi #else 259*53ee8cc1Swenshuai.xi typedef struct __sFILE __FILE; 260*53ee8cc1Swenshuai.xi #endif /* __LARGE64_FILES */ 261*53ee8cc1Swenshuai.xi 262*53ee8cc1Swenshuai.xi struct _glue 263*53ee8cc1Swenshuai.xi { 264*53ee8cc1Swenshuai.xi struct _glue *_next; 265*53ee8cc1Swenshuai.xi int _niobs; 266*53ee8cc1Swenshuai.xi __FILE *_iobs; 267*53ee8cc1Swenshuai.xi }; 268*53ee8cc1Swenshuai.xi 269*53ee8cc1Swenshuai.xi /* 270*53ee8cc1Swenshuai.xi * rand48 family support 271*53ee8cc1Swenshuai.xi * 272*53ee8cc1Swenshuai.xi * Copyright (c) 1993 Martin Birgmeier 273*53ee8cc1Swenshuai.xi * All rights reserved. 274*53ee8cc1Swenshuai.xi * 275*53ee8cc1Swenshuai.xi * You may redistribute unmodified or modified versions of this source 276*53ee8cc1Swenshuai.xi * code provided that the above copyright notice and this and the 277*53ee8cc1Swenshuai.xi * following conditions are retained. 278*53ee8cc1Swenshuai.xi * 279*53ee8cc1Swenshuai.xi * This software is provided ``as is'', and comes with no warranties 280*53ee8cc1Swenshuai.xi * of any kind. I shall in no event be liable for anything that happens 281*53ee8cc1Swenshuai.xi * to anyone/anything when using this software. 282*53ee8cc1Swenshuai.xi */ 283*53ee8cc1Swenshuai.xi #define _RAND48_SEED_0 (0x330e) 284*53ee8cc1Swenshuai.xi #define _RAND48_SEED_1 (0xabcd) 285*53ee8cc1Swenshuai.xi #define _RAND48_SEED_2 (0x1234) 286*53ee8cc1Swenshuai.xi #define _RAND48_MULT_0 (0xe66d) 287*53ee8cc1Swenshuai.xi #define _RAND48_MULT_1 (0xdeec) 288*53ee8cc1Swenshuai.xi #define _RAND48_MULT_2 (0x0005) 289*53ee8cc1Swenshuai.xi #define _RAND48_ADD (0x000b) 290*53ee8cc1Swenshuai.xi struct _rand48 { 291*53ee8cc1Swenshuai.xi unsigned short _seed[3]; 292*53ee8cc1Swenshuai.xi unsigned short _mult[3]; 293*53ee8cc1Swenshuai.xi unsigned short _add; 294*53ee8cc1Swenshuai.xi #ifdef _REENT_SMALL 295*53ee8cc1Swenshuai.xi /* Put this in here as well, for good luck. */ 296*53ee8cc1Swenshuai.xi __extension__ unsigned long long _rand_next; 297*53ee8cc1Swenshuai.xi #endif 298*53ee8cc1Swenshuai.xi }; 299*53ee8cc1Swenshuai.xi 300*53ee8cc1Swenshuai.xi /* How big the some arrays are. */ 301*53ee8cc1Swenshuai.xi #define _REENT_EMERGENCY_SIZE 25 302*53ee8cc1Swenshuai.xi #define _REENT_ASCTIME_SIZE 26 303*53ee8cc1Swenshuai.xi #define _REENT_SIGNAL_SIZE 24 304*53ee8cc1Swenshuai.xi 305*53ee8cc1Swenshuai.xi /* 306*53ee8cc1Swenshuai.xi * struct _reent 307*53ee8cc1Swenshuai.xi * 308*53ee8cc1Swenshuai.xi * This structure contains *all* globals needed by the library. 309*53ee8cc1Swenshuai.xi * It's raison d'etre is to facilitate threads by making all library routines 310*53ee8cc1Swenshuai.xi * reentrant. IE: All state information is contained here. 311*53ee8cc1Swenshuai.xi */ 312*53ee8cc1Swenshuai.xi 313*53ee8cc1Swenshuai.xi #ifdef _REENT_SMALL 314*53ee8cc1Swenshuai.xi 315*53ee8cc1Swenshuai.xi struct _mprec 316*53ee8cc1Swenshuai.xi { 317*53ee8cc1Swenshuai.xi /* used by mprec routines */ 318*53ee8cc1Swenshuai.xi struct _Bigint *_result; 319*53ee8cc1Swenshuai.xi int _result_k; 320*53ee8cc1Swenshuai.xi struct _Bigint *_p5s; 321*53ee8cc1Swenshuai.xi struct _Bigint **_freelist; 322*53ee8cc1Swenshuai.xi }; 323*53ee8cc1Swenshuai.xi 324*53ee8cc1Swenshuai.xi 325*53ee8cc1Swenshuai.xi struct _misc_reent 326*53ee8cc1Swenshuai.xi { 327*53ee8cc1Swenshuai.xi /* miscellaneous reentrant data */ 328*53ee8cc1Swenshuai.xi char *_strtok_last; 329*53ee8cc1Swenshuai.xi _mbstate_t _mblen_state; 330*53ee8cc1Swenshuai.xi _mbstate_t _wctomb_state; 331*53ee8cc1Swenshuai.xi _mbstate_t _mbtowc_state; 332*53ee8cc1Swenshuai.xi char _l64a_buf[8]; 333*53ee8cc1Swenshuai.xi int _getdate_err; 334*53ee8cc1Swenshuai.xi _mbstate_t _mbrlen_state; 335*53ee8cc1Swenshuai.xi _mbstate_t _mbrtowc_state; 336*53ee8cc1Swenshuai.xi _mbstate_t _mbsrtowcs_state; 337*53ee8cc1Swenshuai.xi _mbstate_t _wcrtomb_state; 338*53ee8cc1Swenshuai.xi _mbstate_t _wcsrtombs_state; 339*53ee8cc1Swenshuai.xi }; 340*53ee8cc1Swenshuai.xi 341*53ee8cc1Swenshuai.xi /* This version of _reent is layed our with "int"s in pairs, to help 342*53ee8cc1Swenshuai.xi * ports with 16-bit int's but 32-bit pointers, align nicely. */ 343*53ee8cc1Swenshuai.xi struct _reent 344*53ee8cc1Swenshuai.xi { 345*53ee8cc1Swenshuai.xi 346*53ee8cc1Swenshuai.xi /* FILE is a big struct and may change over time. To try to achieve binary 347*53ee8cc1Swenshuai.xi compatibility with future versions, put stdin,stdout,stderr here. 348*53ee8cc1Swenshuai.xi These are pointers into member __sf defined below. */ 349*53ee8cc1Swenshuai.xi __FILE *_stdin, *_stdout, *_stderr; /* XXX */ 350*53ee8cc1Swenshuai.xi 351*53ee8cc1Swenshuai.xi int _errno; /* local copy of errno */ 352*53ee8cc1Swenshuai.xi 353*53ee8cc1Swenshuai.xi int _inc; /* used by tmpnam */ 354*53ee8cc1Swenshuai.xi 355*53ee8cc1Swenshuai.xi char *_emergency; 356*53ee8cc1Swenshuai.xi 357*53ee8cc1Swenshuai.xi int __sdidinit; /* 1 means stdio has been init'd */ 358*53ee8cc1Swenshuai.xi 359*53ee8cc1Swenshuai.xi int _current_category; /* used by setlocale */ 360*53ee8cc1Swenshuai.xi _CONST char *_current_locale; 361*53ee8cc1Swenshuai.xi 362*53ee8cc1Swenshuai.xi struct _mprec *_mp; 363*53ee8cc1Swenshuai.xi 364*53ee8cc1Swenshuai.xi void _EXFUN((*__cleanup),(struct _reent *)); 365*53ee8cc1Swenshuai.xi 366*53ee8cc1Swenshuai.xi int _gamma_signgam; 367*53ee8cc1Swenshuai.xi 368*53ee8cc1Swenshuai.xi /* used by some fp conversion routines */ 369*53ee8cc1Swenshuai.xi int _cvtlen; /* should be size_t */ 370*53ee8cc1Swenshuai.xi char *_cvtbuf; 371*53ee8cc1Swenshuai.xi 372*53ee8cc1Swenshuai.xi struct _rand48 *_r48; 373*53ee8cc1Swenshuai.xi struct __tm *_localtime_buf; 374*53ee8cc1Swenshuai.xi char *_asctime_buf; 375*53ee8cc1Swenshuai.xi 376*53ee8cc1Swenshuai.xi /* signal info */ 377*53ee8cc1Swenshuai.xi void (**(_sig_func))(int); 378*53ee8cc1Swenshuai.xi 379*53ee8cc1Swenshuai.xi /* atexit stuff */ 380*53ee8cc1Swenshuai.xi struct _atexit *_atexit; 381*53ee8cc1Swenshuai.xi struct _atexit _atexit0; 382*53ee8cc1Swenshuai.xi 383*53ee8cc1Swenshuai.xi struct _glue __sglue; /* root of glue chain */ 384*53ee8cc1Swenshuai.xi __FILE *__sf; /* file descriptors */ 385*53ee8cc1Swenshuai.xi struct __sFILE_fake __sf_fake; /* fake initial stdin/out/err */ 386*53ee8cc1Swenshuai.xi struct _misc_reent *_misc; /* strtok, multibyte states */ 387*53ee8cc1Swenshuai.xi char *_signal_buf; /* strsignal */ 388*53ee8cc1Swenshuai.xi }; 389*53ee8cc1Swenshuai.xi 390*53ee8cc1Swenshuai.xi #define _REENT_INIT(var) \ 391*53ee8cc1Swenshuai.xi { (__FILE *)&var.__sf_fake, \ 392*53ee8cc1Swenshuai.xi (__FILE *)&var.__sf_fake, \ 393*53ee8cc1Swenshuai.xi (__FILE *)&var.__sf_fake, \ 394*53ee8cc1Swenshuai.xi 0, \ 395*53ee8cc1Swenshuai.xi 0, \ 396*53ee8cc1Swenshuai.xi _NULL, \ 397*53ee8cc1Swenshuai.xi 0, \ 398*53ee8cc1Swenshuai.xi 0, \ 399*53ee8cc1Swenshuai.xi "C", \ 400*53ee8cc1Swenshuai.xi _NULL, \ 401*53ee8cc1Swenshuai.xi _NULL, \ 402*53ee8cc1Swenshuai.xi 0, \ 403*53ee8cc1Swenshuai.xi 0, \ 404*53ee8cc1Swenshuai.xi _NULL, \ 405*53ee8cc1Swenshuai.xi _NULL, \ 406*53ee8cc1Swenshuai.xi _NULL, \ 407*53ee8cc1Swenshuai.xi _NULL, \ 408*53ee8cc1Swenshuai.xi _NULL, \ 409*53ee8cc1Swenshuai.xi _NULL, \ 410*53ee8cc1Swenshuai.xi {_NULL, 0, {_NULL}, _NULL}, \ 411*53ee8cc1Swenshuai.xi {_NULL, 0, _NULL}, \ 412*53ee8cc1Swenshuai.xi _NULL, \ 413*53ee8cc1Swenshuai.xi {_NULL, 0, 0, 0, 0, {_NULL, 0}, 0, _NULL}, \ 414*53ee8cc1Swenshuai.xi _NULL, \ 415*53ee8cc1Swenshuai.xi _NULL \ 416*53ee8cc1Swenshuai.xi } 417*53ee8cc1Swenshuai.xi 418*53ee8cc1Swenshuai.xi #define _REENT_INIT_PTR(var) \ 419*53ee8cc1Swenshuai.xi { var->_stdin = (__FILE *)&var->__sf_fake; \ 420*53ee8cc1Swenshuai.xi var->_stdout = (__FILE *)&var->__sf_fake; \ 421*53ee8cc1Swenshuai.xi var->_stderr = (__FILE *)&var->__sf_fake; \ 422*53ee8cc1Swenshuai.xi var->_errno = 0; \ 423*53ee8cc1Swenshuai.xi var->_inc = 0; \ 424*53ee8cc1Swenshuai.xi var->_emergency = _NULL; \ 425*53ee8cc1Swenshuai.xi var->__sdidinit = 0; \ 426*53ee8cc1Swenshuai.xi var->_current_category = 0; \ 427*53ee8cc1Swenshuai.xi var->_current_locale = "C"; \ 428*53ee8cc1Swenshuai.xi var->_mp = _NULL; \ 429*53ee8cc1Swenshuai.xi var->__cleanup = _NULL; \ 430*53ee8cc1Swenshuai.xi var->_gamma_signgam = 0; \ 431*53ee8cc1Swenshuai.xi var->_cvtlen = 0; \ 432*53ee8cc1Swenshuai.xi var->_cvtbuf = _NULL; \ 433*53ee8cc1Swenshuai.xi var->_r48 = _NULL; \ 434*53ee8cc1Swenshuai.xi var->_localtime_buf = _NULL; \ 435*53ee8cc1Swenshuai.xi var->_asctime_buf = _NULL; \ 436*53ee8cc1Swenshuai.xi var->_sig_func = _NULL; \ 437*53ee8cc1Swenshuai.xi var->_atexit = _NULL; \ 438*53ee8cc1Swenshuai.xi var->_atexit0._next = _NULL; \ 439*53ee8cc1Swenshuai.xi var->_atexit0._ind = 0; \ 440*53ee8cc1Swenshuai.xi var->_atexit0._fns[0] = _NULL; \ 441*53ee8cc1Swenshuai.xi var->_atexit0._on_exit_args_ptr = _NULL; \ 442*53ee8cc1Swenshuai.xi var->__sglue._next = _NULL; \ 443*53ee8cc1Swenshuai.xi var->__sglue._niobs = 0; \ 444*53ee8cc1Swenshuai.xi var->__sglue._iobs = _NULL; \ 445*53ee8cc1Swenshuai.xi var->__sf = 0; \ 446*53ee8cc1Swenshuai.xi var->__sf_fake._p = _NULL; \ 447*53ee8cc1Swenshuai.xi var->__sf_fake._r = 0; \ 448*53ee8cc1Swenshuai.xi var->__sf_fake._w = 0; \ 449*53ee8cc1Swenshuai.xi var->__sf_fake._flags = 0; \ 450*53ee8cc1Swenshuai.xi var->__sf_fake._file = 0; \ 451*53ee8cc1Swenshuai.xi var->__sf_fake._bf._base = _NULL; \ 452*53ee8cc1Swenshuai.xi var->__sf_fake._bf._size = 0; \ 453*53ee8cc1Swenshuai.xi var->__sf_fake._lbfsize = 0; \ 454*53ee8cc1Swenshuai.xi var->__sf_fake._data = _NULL; \ 455*53ee8cc1Swenshuai.xi var->_misc = _NULL; \ 456*53ee8cc1Swenshuai.xi var->_signal_buf = _NULL; \ 457*53ee8cc1Swenshuai.xi } 458*53ee8cc1Swenshuai.xi 459*53ee8cc1Swenshuai.xi /* Only built the assert() calls if we are built with debugging. */ 460*53ee8cc1Swenshuai.xi #if DEBUG 461*53ee8cc1Swenshuai.xi #include <assert.h> 462*53ee8cc1Swenshuai.xi #else 463*53ee8cc1Swenshuai.xi #define assert(x) ((void)0) 464*53ee8cc1Swenshuai.xi #endif 465*53ee8cc1Swenshuai.xi 466*53ee8cc1Swenshuai.xi /* Generic _REENT check macro. */ 467*53ee8cc1Swenshuai.xi #define _REENT_CHECK(var, what, type, size, init) do { \ 468*53ee8cc1Swenshuai.xi struct _reent *_r = (var); \ 469*53ee8cc1Swenshuai.xi if (_r->what == NULL) { \ 470*53ee8cc1Swenshuai.xi _r->what = (type)malloc(size); \ 471*53ee8cc1Swenshuai.xi assert(_r->what); \ 472*53ee8cc1Swenshuai.xi init; \ 473*53ee8cc1Swenshuai.xi } \ 474*53ee8cc1Swenshuai.xi } while (0) 475*53ee8cc1Swenshuai.xi 476*53ee8cc1Swenshuai.xi #define _REENT_CHECK_TM(var) \ 477*53ee8cc1Swenshuai.xi _REENT_CHECK(var, _localtime_buf, struct __tm *, sizeof *((var)->_localtime_buf), \ 478*53ee8cc1Swenshuai.xi /* nothing */) 479*53ee8cc1Swenshuai.xi 480*53ee8cc1Swenshuai.xi #define _REENT_CHECK_ASCTIME_BUF(var) \ 481*53ee8cc1Swenshuai.xi _REENT_CHECK(var, _asctime_buf, char *, _REENT_ASCTIME_SIZE, \ 482*53ee8cc1Swenshuai.xi memset((var)->_asctime_buf, 0, _REENT_ASCTIME_SIZE)) 483*53ee8cc1Swenshuai.xi 484*53ee8cc1Swenshuai.xi /* Handle the dynamically allocated rand48 structure. */ 485*53ee8cc1Swenshuai.xi #define _REENT_INIT_RAND48(var) do { \ 486*53ee8cc1Swenshuai.xi struct _reent *_r = (var); \ 487*53ee8cc1Swenshuai.xi _r->_r48->_seed[0] = _RAND48_SEED_0; \ 488*53ee8cc1Swenshuai.xi _r->_r48->_seed[1] = _RAND48_SEED_1; \ 489*53ee8cc1Swenshuai.xi _r->_r48->_seed[2] = _RAND48_SEED_2; \ 490*53ee8cc1Swenshuai.xi _r->_r48->_mult[0] = _RAND48_MULT_0; \ 491*53ee8cc1Swenshuai.xi _r->_r48->_mult[1] = _RAND48_MULT_1; \ 492*53ee8cc1Swenshuai.xi _r->_r48->_mult[2] = _RAND48_MULT_2; \ 493*53ee8cc1Swenshuai.xi _r->_r48->_add = _RAND48_ADD; \ 494*53ee8cc1Swenshuai.xi } while (0) 495*53ee8cc1Swenshuai.xi #define _REENT_CHECK_RAND48(var) \ 496*53ee8cc1Swenshuai.xi _REENT_CHECK(var, _r48, struct _rand48 *, sizeof *((var)->_r48), _REENT_INIT_RAND48((var))) 497*53ee8cc1Swenshuai.xi 498*53ee8cc1Swenshuai.xi #define _REENT_INIT_MP(var) do { \ 499*53ee8cc1Swenshuai.xi struct _reent *_r = (var); \ 500*53ee8cc1Swenshuai.xi _r->_mp->_result_k = 0; \ 501*53ee8cc1Swenshuai.xi _r->_mp->_result = _r->_mp->_p5s = _NULL; \ 502*53ee8cc1Swenshuai.xi _r->_mp->_freelist = _NULL; \ 503*53ee8cc1Swenshuai.xi } while (0) 504*53ee8cc1Swenshuai.xi #define _REENT_CHECK_MP(var) \ 505*53ee8cc1Swenshuai.xi _REENT_CHECK(var, _mp, struct _mprec *, sizeof *((var)->_mp), _REENT_INIT_MP(var)) 506*53ee8cc1Swenshuai.xi 507*53ee8cc1Swenshuai.xi #define _REENT_CHECK_EMERGENCY(var) \ 508*53ee8cc1Swenshuai.xi _REENT_CHECK(var, _emergency, char *, _REENT_EMERGENCY_SIZE, /* nothing */) 509*53ee8cc1Swenshuai.xi 510*53ee8cc1Swenshuai.xi #define _REENT_INIT_MISC(var) do { \ 511*53ee8cc1Swenshuai.xi struct _reent *_r = (var); \ 512*53ee8cc1Swenshuai.xi _r->_misc->_strtok_last = _NULL; \ 513*53ee8cc1Swenshuai.xi _r->_misc->_mblen_state.__count = 0; \ 514*53ee8cc1Swenshuai.xi _r->_misc->_mblen_state.__value.__wch = 0; \ 515*53ee8cc1Swenshuai.xi _r->_misc->_wctomb_state.__count = 0; \ 516*53ee8cc1Swenshuai.xi _r->_misc->_wctomb_state.__value.__wch = 0; \ 517*53ee8cc1Swenshuai.xi _r->_misc->_mbtowc_state.__count = 0; \ 518*53ee8cc1Swenshuai.xi _r->_misc->_mbtowc_state.__value.__wch = 0; \ 519*53ee8cc1Swenshuai.xi _r->_misc->_mbrlen_state.__count = 0; \ 520*53ee8cc1Swenshuai.xi _r->_misc->_mbrlen_state.__value.__wch = 0; \ 521*53ee8cc1Swenshuai.xi _r->_misc->_mbrtowc_state.__count = 0; \ 522*53ee8cc1Swenshuai.xi _r->_misc->_mbrtowc_state.__value.__wch = 0; \ 523*53ee8cc1Swenshuai.xi _r->_misc->_mbsrtowcs_state.__count = 0; \ 524*53ee8cc1Swenshuai.xi _r->_misc->_mbsrtowcs_state.__value.__wch = 0; \ 525*53ee8cc1Swenshuai.xi _r->_misc->_wcrtomb_state.__count = 0; \ 526*53ee8cc1Swenshuai.xi _r->_misc->_wcrtomb_state.__value.__wch = 0; \ 527*53ee8cc1Swenshuai.xi _r->_misc->_wcsrtombs_state.__count = 0; \ 528*53ee8cc1Swenshuai.xi _r->_misc->_wcsrtombs_state.__value.__wch = 0; \ 529*53ee8cc1Swenshuai.xi _r->_misc->_l64a_buf[0] = '\0'; \ 530*53ee8cc1Swenshuai.xi _r->_misc->_getdate_err = 0; \ 531*53ee8cc1Swenshuai.xi } while (0) 532*53ee8cc1Swenshuai.xi #define _REENT_CHECK_MISC(var) \ 533*53ee8cc1Swenshuai.xi _REENT_CHECK(var, _misc, struct _misc_reent *, sizeof *((var)->_misc), _REENT_INIT_MISC(var)) 534*53ee8cc1Swenshuai.xi 535*53ee8cc1Swenshuai.xi #define _REENT_CHECK_SIGNAL_BUF(var) \ 536*53ee8cc1Swenshuai.xi _REENT_CHECK(var, _signal_buf, char *, _REENT_SIGNAL_SIZE, /* nothing */) 537*53ee8cc1Swenshuai.xi 538*53ee8cc1Swenshuai.xi #define _REENT_SIGNGAM(ptr) ((ptr)->_gamma_signgam) 539*53ee8cc1Swenshuai.xi #define _REENT_RAND_NEXT(ptr) ((ptr)->_r48->_rand_next) 540*53ee8cc1Swenshuai.xi #define _REENT_RAND48_SEED(ptr) ((ptr)->_r48->_seed) 541*53ee8cc1Swenshuai.xi #define _REENT_RAND48_MULT(ptr) ((ptr)->_r48->_mult) 542*53ee8cc1Swenshuai.xi #define _REENT_RAND48_ADD(ptr) ((ptr)->_r48->_add) 543*53ee8cc1Swenshuai.xi #define _REENT_MP_RESULT(ptr) ((ptr)->_mp->_result) 544*53ee8cc1Swenshuai.xi #define _REENT_MP_RESULT_K(ptr) ((ptr)->_mp->_result_k) 545*53ee8cc1Swenshuai.xi #define _REENT_MP_P5S(ptr) ((ptr)->_mp->_p5s) 546*53ee8cc1Swenshuai.xi #define _REENT_MP_FREELIST(ptr) ((ptr)->_mp->_freelist) 547*53ee8cc1Swenshuai.xi #define _REENT_ASCTIME_BUF(ptr) ((ptr)->_asctime_buf) 548*53ee8cc1Swenshuai.xi #define _REENT_TM(ptr) ((ptr)->_localtime_buf) 549*53ee8cc1Swenshuai.xi #define _REENT_EMERGENCY(ptr) ((ptr)->_emergency) 550*53ee8cc1Swenshuai.xi #define _REENT_STRTOK_LAST(ptr) ((ptr)->_misc->_strtok_last) 551*53ee8cc1Swenshuai.xi #define _REENT_MBLEN_STATE(ptr) ((ptr)->_misc->_mblen_state) 552*53ee8cc1Swenshuai.xi #define _REENT_MBTOWC_STATE(ptr)((ptr)->_misc->_mbtowc_state) 553*53ee8cc1Swenshuai.xi #define _REENT_WCTOMB_STATE(ptr)((ptr)->_misc->_wctomb_state) 554*53ee8cc1Swenshuai.xi #define _REENT_MBRLEN_STATE(ptr) ((ptr)->_misc->_mbrlen_state) 555*53ee8cc1Swenshuai.xi #define _REENT_MBRTOWC_STATE(ptr) ((ptr)->_misc->_mbrtowc_state) 556*53ee8cc1Swenshuai.xi #define _REENT_MBSRTOWCS_STATE(ptr) ((ptr)->_misc->_mbsrtowcs_state) 557*53ee8cc1Swenshuai.xi #define _REENT_WCRTOMB_STATE(ptr) ((ptr)->_misc->_wcrtomb_state) 558*53ee8cc1Swenshuai.xi #define _REENT_WCSRTOMBS_STATE(ptr) ((ptr)->_misc->_wcsrtombs_state) 559*53ee8cc1Swenshuai.xi #define _REENT_L64A_BUF(ptr) ((ptr)->_misc->_l64a_buf) 560*53ee8cc1Swenshuai.xi #define _REENT_GETDATE_ERR_P(ptr) (&((ptr)->_misc->_getdate_err)) 561*53ee8cc1Swenshuai.xi #define _REENT_SIGNAL_BUF(ptr) ((ptr)->_signal_buf) 562*53ee8cc1Swenshuai.xi 563*53ee8cc1Swenshuai.xi #else /* !_REENT_SMALL */ 564*53ee8cc1Swenshuai.xi 565*53ee8cc1Swenshuai.xi struct _reent 566*53ee8cc1Swenshuai.xi { 567*53ee8cc1Swenshuai.xi int _errno; /* local copy of errno */ 568*53ee8cc1Swenshuai.xi 569*53ee8cc1Swenshuai.xi /* FILE is a big struct and may change over time. To try to achieve binary 570*53ee8cc1Swenshuai.xi compatibility with future versions, put stdin,stdout,stderr here. 571*53ee8cc1Swenshuai.xi These are pointers into member __sf defined below. */ 572*53ee8cc1Swenshuai.xi __FILE *_stdin, *_stdout, *_stderr; 573*53ee8cc1Swenshuai.xi 574*53ee8cc1Swenshuai.xi int _inc; /* used by tmpnam */ 575*53ee8cc1Swenshuai.xi char _emergency[_REENT_EMERGENCY_SIZE]; 576*53ee8cc1Swenshuai.xi 577*53ee8cc1Swenshuai.xi int _current_category; /* used by setlocale */ 578*53ee8cc1Swenshuai.xi _CONST char *_current_locale; 579*53ee8cc1Swenshuai.xi 580*53ee8cc1Swenshuai.xi int __sdidinit; /* 1 means stdio has been init'd */ 581*53ee8cc1Swenshuai.xi 582*53ee8cc1Swenshuai.xi void _EXFUN((*__cleanup),(struct _reent *)); 583*53ee8cc1Swenshuai.xi 584*53ee8cc1Swenshuai.xi /* used by mprec routines */ 585*53ee8cc1Swenshuai.xi struct _Bigint *_result; 586*53ee8cc1Swenshuai.xi int _result_k; 587*53ee8cc1Swenshuai.xi struct _Bigint *_p5s; 588*53ee8cc1Swenshuai.xi struct _Bigint **_freelist; 589*53ee8cc1Swenshuai.xi 590*53ee8cc1Swenshuai.xi /* used by some fp conversion routines */ 591*53ee8cc1Swenshuai.xi int _cvtlen; /* should be size_t */ 592*53ee8cc1Swenshuai.xi char *_cvtbuf; 593*53ee8cc1Swenshuai.xi 594*53ee8cc1Swenshuai.xi union 595*53ee8cc1Swenshuai.xi { 596*53ee8cc1Swenshuai.xi struct 597*53ee8cc1Swenshuai.xi { 598*53ee8cc1Swenshuai.xi unsigned int _unused_rand; 599*53ee8cc1Swenshuai.xi char * _strtok_last; 600*53ee8cc1Swenshuai.xi char _asctime_buf[_REENT_ASCTIME_SIZE]; 601*53ee8cc1Swenshuai.xi struct __tm _localtime_buf; 602*53ee8cc1Swenshuai.xi int _gamma_signgam; 603*53ee8cc1Swenshuai.xi __extension__ unsigned long long _rand_next; 604*53ee8cc1Swenshuai.xi struct _rand48 _r48; 605*53ee8cc1Swenshuai.xi _mbstate_t _mblen_state; 606*53ee8cc1Swenshuai.xi _mbstate_t _mbtowc_state; 607*53ee8cc1Swenshuai.xi _mbstate_t _wctomb_state; 608*53ee8cc1Swenshuai.xi char _l64a_buf[8]; 609*53ee8cc1Swenshuai.xi char _signal_buf[_REENT_SIGNAL_SIZE]; 610*53ee8cc1Swenshuai.xi int _getdate_err; 611*53ee8cc1Swenshuai.xi _mbstate_t _mbrlen_state; 612*53ee8cc1Swenshuai.xi _mbstate_t _mbrtowc_state; 613*53ee8cc1Swenshuai.xi _mbstate_t _mbsrtowcs_state; 614*53ee8cc1Swenshuai.xi _mbstate_t _wcrtomb_state; 615*53ee8cc1Swenshuai.xi _mbstate_t _wcsrtombs_state; 616*53ee8cc1Swenshuai.xi } _reent; 617*53ee8cc1Swenshuai.xi /* Two next two fields were once used by malloc. They are no longer 618*53ee8cc1Swenshuai.xi used. They are used to preserve the space used before so as to 619*53ee8cc1Swenshuai.xi allow addition of new reent fields and keep binary compatibility. */ 620*53ee8cc1Swenshuai.xi struct 621*53ee8cc1Swenshuai.xi { 622*53ee8cc1Swenshuai.xi #define _N_LISTS 30 623*53ee8cc1Swenshuai.xi unsigned char * _nextf[_N_LISTS]; 624*53ee8cc1Swenshuai.xi unsigned int _nmalloc[_N_LISTS]; 625*53ee8cc1Swenshuai.xi } _unused; 626*53ee8cc1Swenshuai.xi } _new; 627*53ee8cc1Swenshuai.xi 628*53ee8cc1Swenshuai.xi /* atexit stuff */ 629*53ee8cc1Swenshuai.xi struct _atexit *_atexit; /* points to head of LIFO stack */ 630*53ee8cc1Swenshuai.xi struct _atexit _atexit0; /* one guaranteed table, required by ANSI */ 631*53ee8cc1Swenshuai.xi 632*53ee8cc1Swenshuai.xi /* signal info */ 633*53ee8cc1Swenshuai.xi void (**(_sig_func))(int); 634*53ee8cc1Swenshuai.xi 635*53ee8cc1Swenshuai.xi /* These are here last so that __FILE can grow without changing the offsets 636*53ee8cc1Swenshuai.xi of the above members (on the off chance that future binary compatibility 637*53ee8cc1Swenshuai.xi would be broken otherwise). */ 638*53ee8cc1Swenshuai.xi struct _glue __sglue; /* root of glue chain */ 639*53ee8cc1Swenshuai.xi __FILE __sf[3]; /* first three file descriptors */ 640*53ee8cc1Swenshuai.xi }; 641*53ee8cc1Swenshuai.xi 642*53ee8cc1Swenshuai.xi #define _REENT_INIT(var) \ 643*53ee8cc1Swenshuai.xi { 0, \ 644*53ee8cc1Swenshuai.xi &var.__sf[0], \ 645*53ee8cc1Swenshuai.xi &var.__sf[1], \ 646*53ee8cc1Swenshuai.xi &var.__sf[2], \ 647*53ee8cc1Swenshuai.xi 0, \ 648*53ee8cc1Swenshuai.xi "", \ 649*53ee8cc1Swenshuai.xi 0, \ 650*53ee8cc1Swenshuai.xi "C", \ 651*53ee8cc1Swenshuai.xi 0, \ 652*53ee8cc1Swenshuai.xi _NULL, \ 653*53ee8cc1Swenshuai.xi _NULL, \ 654*53ee8cc1Swenshuai.xi 0, \ 655*53ee8cc1Swenshuai.xi _NULL, \ 656*53ee8cc1Swenshuai.xi _NULL, \ 657*53ee8cc1Swenshuai.xi 0, \ 658*53ee8cc1Swenshuai.xi _NULL, \ 659*53ee8cc1Swenshuai.xi { \ 660*53ee8cc1Swenshuai.xi { \ 661*53ee8cc1Swenshuai.xi 0, \ 662*53ee8cc1Swenshuai.xi _NULL, \ 663*53ee8cc1Swenshuai.xi "", \ 664*53ee8cc1Swenshuai.xi {0, 0, 0, 0, 0, 0, 0, 0, 0}, \ 665*53ee8cc1Swenshuai.xi 0, \ 666*53ee8cc1Swenshuai.xi 1, \ 667*53ee8cc1Swenshuai.xi { \ 668*53ee8cc1Swenshuai.xi {_RAND48_SEED_0, _RAND48_SEED_1, _RAND48_SEED_2}, \ 669*53ee8cc1Swenshuai.xi {_RAND48_MULT_0, _RAND48_MULT_1, _RAND48_MULT_2}, \ 670*53ee8cc1Swenshuai.xi _RAND48_ADD \ 671*53ee8cc1Swenshuai.xi }, \ 672*53ee8cc1Swenshuai.xi {0, {0}}, \ 673*53ee8cc1Swenshuai.xi {0, {0}}, \ 674*53ee8cc1Swenshuai.xi {0, {0}}, \ 675*53ee8cc1Swenshuai.xi "", \ 676*53ee8cc1Swenshuai.xi "", \ 677*53ee8cc1Swenshuai.xi 0, \ 678*53ee8cc1Swenshuai.xi {0, {0}}, \ 679*53ee8cc1Swenshuai.xi {0, {0}}, \ 680*53ee8cc1Swenshuai.xi {0, {0}}, \ 681*53ee8cc1Swenshuai.xi {0, {0}}, \ 682*53ee8cc1Swenshuai.xi {0, {0}} \ 683*53ee8cc1Swenshuai.xi } \ 684*53ee8cc1Swenshuai.xi }, \ 685*53ee8cc1Swenshuai.xi _NULL, \ 686*53ee8cc1Swenshuai.xi {_NULL, 0, {_NULL}, {{_NULL}, {_NULL}, 0, 0}}, \ 687*53ee8cc1Swenshuai.xi _NULL, \ 688*53ee8cc1Swenshuai.xi {_NULL, 0, _NULL} \ 689*53ee8cc1Swenshuai.xi } 690*53ee8cc1Swenshuai.xi 691*53ee8cc1Swenshuai.xi #define _REENT_INIT_PTR(var) \ 692*53ee8cc1Swenshuai.xi { var->_errno = 0; \ 693*53ee8cc1Swenshuai.xi var->_stdin = &var->__sf[0]; \ 694*53ee8cc1Swenshuai.xi var->_stdout = &var->__sf[1]; \ 695*53ee8cc1Swenshuai.xi var->_stderr = &var->__sf[2]; \ 696*53ee8cc1Swenshuai.xi var->_inc = 0; \ 697*53ee8cc1Swenshuai.xi memset(&var->_emergency, 0, sizeof(var->_emergency)); \ 698*53ee8cc1Swenshuai.xi var->_current_category = 0; \ 699*53ee8cc1Swenshuai.xi var->_current_locale = "C"; \ 700*53ee8cc1Swenshuai.xi var->__sdidinit = 0; \ 701*53ee8cc1Swenshuai.xi var->__cleanup = _NULL; \ 702*53ee8cc1Swenshuai.xi var->_result = _NULL; \ 703*53ee8cc1Swenshuai.xi var->_result_k = 0; \ 704*53ee8cc1Swenshuai.xi var->_p5s = _NULL; \ 705*53ee8cc1Swenshuai.xi var->_freelist = _NULL; \ 706*53ee8cc1Swenshuai.xi var->_cvtlen = 0; \ 707*53ee8cc1Swenshuai.xi var->_cvtbuf = _NULL; \ 708*53ee8cc1Swenshuai.xi var->_new._reent._unused_rand = 0; \ 709*53ee8cc1Swenshuai.xi var->_new._reent._strtok_last = _NULL; \ 710*53ee8cc1Swenshuai.xi var->_new._reent._asctime_buf[0] = 0; \ 711*53ee8cc1Swenshuai.xi memset(&var->_new._reent._localtime_buf, 0, sizeof(var->_new._reent._localtime_buf)); \ 712*53ee8cc1Swenshuai.xi var->_new._reent._gamma_signgam = 0; \ 713*53ee8cc1Swenshuai.xi var->_new._reent._rand_next = 1; \ 714*53ee8cc1Swenshuai.xi var->_new._reent._r48._seed[0] = _RAND48_SEED_0; \ 715*53ee8cc1Swenshuai.xi var->_new._reent._r48._seed[1] = _RAND48_SEED_1; \ 716*53ee8cc1Swenshuai.xi var->_new._reent._r48._seed[2] = _RAND48_SEED_2; \ 717*53ee8cc1Swenshuai.xi var->_new._reent._r48._mult[0] = _RAND48_MULT_0; \ 718*53ee8cc1Swenshuai.xi var->_new._reent._r48._mult[1] = _RAND48_MULT_1; \ 719*53ee8cc1Swenshuai.xi var->_new._reent._r48._mult[2] = _RAND48_MULT_2; \ 720*53ee8cc1Swenshuai.xi var->_new._reent._r48._add = _RAND48_ADD; \ 721*53ee8cc1Swenshuai.xi var->_new._reent._mblen_state.__count = 0; \ 722*53ee8cc1Swenshuai.xi var->_new._reent._mblen_state.__value.__wch = 0; \ 723*53ee8cc1Swenshuai.xi var->_new._reent._mbtowc_state.__count = 0; \ 724*53ee8cc1Swenshuai.xi var->_new._reent._mbtowc_state.__value.__wch = 0; \ 725*53ee8cc1Swenshuai.xi var->_new._reent._wctomb_state.__count = 0; \ 726*53ee8cc1Swenshuai.xi var->_new._reent._wctomb_state.__value.__wch = 0; \ 727*53ee8cc1Swenshuai.xi var->_new._reent._mbrlen_state.__count = 0; \ 728*53ee8cc1Swenshuai.xi var->_new._reent._mbrlen_state.__value.__wch = 0; \ 729*53ee8cc1Swenshuai.xi var->_new._reent._mbrtowc_state.__count = 0; \ 730*53ee8cc1Swenshuai.xi var->_new._reent._mbrtowc_state.__value.__wch = 0; \ 731*53ee8cc1Swenshuai.xi var->_new._reent._mbsrtowcs_state.__count = 0; \ 732*53ee8cc1Swenshuai.xi var->_new._reent._mbsrtowcs_state.__value.__wch = 0; \ 733*53ee8cc1Swenshuai.xi var->_new._reent._wcrtomb_state.__count = 0; \ 734*53ee8cc1Swenshuai.xi var->_new._reent._wcrtomb_state.__value.__wch = 0; \ 735*53ee8cc1Swenshuai.xi var->_new._reent._wcsrtombs_state.__count = 0; \ 736*53ee8cc1Swenshuai.xi var->_new._reent._wcsrtombs_state.__value.__wch = 0; \ 737*53ee8cc1Swenshuai.xi var->_new._reent._l64a_buf[0] = '\0'; \ 738*53ee8cc1Swenshuai.xi var->_new._reent._signal_buf[0] = '\0'; \ 739*53ee8cc1Swenshuai.xi var->_new._reent._getdate_err = 0; \ 740*53ee8cc1Swenshuai.xi var->_atexit = _NULL; \ 741*53ee8cc1Swenshuai.xi var->_atexit0._next = _NULL; \ 742*53ee8cc1Swenshuai.xi var->_atexit0._ind = 0; \ 743*53ee8cc1Swenshuai.xi var->_atexit0._fns[0] = _NULL; \ 744*53ee8cc1Swenshuai.xi var->_atexit0._on_exit_args._fntypes = 0; \ 745*53ee8cc1Swenshuai.xi var->_atexit0._on_exit_args._fnargs[0] = _NULL; \ 746*53ee8cc1Swenshuai.xi var->_sig_func = _NULL; \ 747*53ee8cc1Swenshuai.xi var->__sglue._next = _NULL; \ 748*53ee8cc1Swenshuai.xi var->__sglue._niobs = 0; \ 749*53ee8cc1Swenshuai.xi var->__sglue._iobs = _NULL; \ 750*53ee8cc1Swenshuai.xi memset(&var->__sf, 0, sizeof(var->__sf)); \ 751*53ee8cc1Swenshuai.xi } 752*53ee8cc1Swenshuai.xi 753*53ee8cc1Swenshuai.xi #define _REENT_CHECK_RAND48(ptr) /* nothing */ 754*53ee8cc1Swenshuai.xi #define _REENT_CHECK_MP(ptr) /* nothing */ 755*53ee8cc1Swenshuai.xi #define _REENT_CHECK_TM(ptr) /* nothing */ 756*53ee8cc1Swenshuai.xi #define _REENT_CHECK_ASCTIME_BUF(ptr) /* nothing */ 757*53ee8cc1Swenshuai.xi #define _REENT_CHECK_EMERGENCY(ptr) /* nothing */ 758*53ee8cc1Swenshuai.xi #define _REENT_CHECK_MISC(ptr) /* nothing */ 759*53ee8cc1Swenshuai.xi #define _REENT_CHECK_SIGNAL_BUF(ptr) /* nothing */ 760*53ee8cc1Swenshuai.xi 761*53ee8cc1Swenshuai.xi #define _REENT_SIGNGAM(ptr) ((ptr)->_new._reent._gamma_signgam) 762*53ee8cc1Swenshuai.xi #define _REENT_RAND_NEXT(ptr) ((ptr)->_new._reent._rand_next) 763*53ee8cc1Swenshuai.xi #define _REENT_RAND48_SEED(ptr) ((ptr)->_new._reent._r48._seed) 764*53ee8cc1Swenshuai.xi #define _REENT_RAND48_MULT(ptr) ((ptr)->_new._reent._r48._mult) 765*53ee8cc1Swenshuai.xi #define _REENT_RAND48_ADD(ptr) ((ptr)->_new._reent._r48._add) 766*53ee8cc1Swenshuai.xi #define _REENT_MP_RESULT(ptr) ((ptr)->_result) 767*53ee8cc1Swenshuai.xi #define _REENT_MP_RESULT_K(ptr) ((ptr)->_result_k) 768*53ee8cc1Swenshuai.xi #define _REENT_MP_P5S(ptr) ((ptr)->_p5s) 769*53ee8cc1Swenshuai.xi #define _REENT_MP_FREELIST(ptr) ((ptr)->_freelist) 770*53ee8cc1Swenshuai.xi #define _REENT_ASCTIME_BUF(ptr) ((ptr)->_new._reent._asctime_buf) 771*53ee8cc1Swenshuai.xi #define _REENT_TM(ptr) (&(ptr)->_new._reent._localtime_buf) 772*53ee8cc1Swenshuai.xi #define _REENT_EMERGENCY(ptr) ((ptr)->_emergency) 773*53ee8cc1Swenshuai.xi #define _REENT_STRTOK_LAST(ptr) ((ptr)->_new._reent._strtok_last) 774*53ee8cc1Swenshuai.xi #define _REENT_MBLEN_STATE(ptr) ((ptr)->_new._reent._mblen_state) 775*53ee8cc1Swenshuai.xi #define _REENT_MBTOWC_STATE(ptr)((ptr)->_new._reent._mbtowc_state) 776*53ee8cc1Swenshuai.xi #define _REENT_WCTOMB_STATE(ptr)((ptr)->_new._reent._wctomb_state) 777*53ee8cc1Swenshuai.xi #define _REENT_MBRLEN_STATE(ptr)((ptr)->_new._reent._mbrlen_state) 778*53ee8cc1Swenshuai.xi #define _REENT_MBRTOWC_STATE(ptr)((ptr)->_new._reent._mbrtowc_state) 779*53ee8cc1Swenshuai.xi #define _REENT_MBSRTOWCS_STATE(ptr)((ptr)->_new._reent._mbsrtowcs_state) 780*53ee8cc1Swenshuai.xi #define _REENT_WCRTOMB_STATE(ptr)((ptr)->_new._reent._wcrtomb_state) 781*53ee8cc1Swenshuai.xi #define _REENT_WCSRTOMBS_STATE(ptr)((ptr)->_new._reent._wcsrtombs_state) 782*53ee8cc1Swenshuai.xi #define _REENT_L64A_BUF(ptr) ((ptr)->_new._reent._l64a_buf) 783*53ee8cc1Swenshuai.xi #define _REENT_SIGNAL_BUF(ptr) ((ptr)->_new._reent._signal_buf) 784*53ee8cc1Swenshuai.xi #define _REENT_GETDATE_ERR_P(ptr) (&((ptr)->_new._reent._getdate_err)) 785*53ee8cc1Swenshuai.xi 786*53ee8cc1Swenshuai.xi #endif /* !_REENT_SMALL */ 787*53ee8cc1Swenshuai.xi 788*53ee8cc1Swenshuai.xi #define _NULL 0 789*53ee8cc1Swenshuai.xi 790*53ee8cc1Swenshuai.xi /* 791*53ee8cc1Swenshuai.xi * All references to struct _reent are via this pointer. 792*53ee8cc1Swenshuai.xi * Internally, newlib routines that need to reference it should use _REENT. 793*53ee8cc1Swenshuai.xi */ 794*53ee8cc1Swenshuai.xi 795*53ee8cc1Swenshuai.xi #ifndef __ATTRIBUTE_IMPURE_PTR__ 796*53ee8cc1Swenshuai.xi #define __ATTRIBUTE_IMPURE_PTR__ 797*53ee8cc1Swenshuai.xi #endif 798*53ee8cc1Swenshuai.xi 799*53ee8cc1Swenshuai.xi extern struct _reent *_impure_ptr __ATTRIBUTE_IMPURE_PTR__; 800*53ee8cc1Swenshuai.xi extern struct _reent *_CONST _global_impure_ptr __ATTRIBUTE_IMPURE_PTR__; 801*53ee8cc1Swenshuai.xi 802*53ee8cc1Swenshuai.xi void _reclaim_reent _PARAMS ((struct _reent *)); 803*53ee8cc1Swenshuai.xi 804*53ee8cc1Swenshuai.xi /* #define _REENT_ONLY define this to get only reentrant routines */ 805*53ee8cc1Swenshuai.xi 806*53ee8cc1Swenshuai.xi #ifndef _REENT_ONLY 807*53ee8cc1Swenshuai.xi 808*53ee8cc1Swenshuai.xi #if defined(__DYNAMIC_REENT__) && !defined(__SINGLE_THREAD__) 809*53ee8cc1Swenshuai.xi #ifndef __getreent 810*53ee8cc1Swenshuai.xi struct _reent * _EXFUN(__getreent, (void)); 811*53ee8cc1Swenshuai.xi #endif 812*53ee8cc1Swenshuai.xi # define _REENT (__getreent()) 813*53ee8cc1Swenshuai.xi #else /* __SINGLE_THREAD__ || !__DYNAMIC_REENT__ */ 814*53ee8cc1Swenshuai.xi # define _REENT _impure_ptr 815*53ee8cc1Swenshuai.xi #endif /* __SINGLE_THREAD__ || !__DYNAMIC_REENT__ */ 816*53ee8cc1Swenshuai.xi 817*53ee8cc1Swenshuai.xi #endif /* !_REENT_ONLY */ 818*53ee8cc1Swenshuai.xi 819*53ee8cc1Swenshuai.xi #define _GLOBAL_REENT _global_impure_ptr 820*53ee8cc1Swenshuai.xi 821*53ee8cc1Swenshuai.xi #ifdef __cplusplus 822*53ee8cc1Swenshuai.xi } 823*53ee8cc1Swenshuai.xi #endif 824*53ee8cc1Swenshuai.xi #endif /* _SYS_REENT_H_ */ 825