FSlibos.h revision da1f2d5d
12d8abe4fSmrg/* 2ba6a1819Smrg * Copyright 1990 Network Computing Devices; 3ba6a1819Smrg * Portions Copyright 1987 by Digital Equipment Corporation 4ba6a1819Smrg * 51bedbe3fSmrg * Permission to use, copy, modify, distribute, and sell this software 61bedbe3fSmrg * and its documentation for any purpose is hereby granted without fee, 71bedbe3fSmrg * provided that the above copyright notice appear in all copies and 81bedbe3fSmrg * that both that copyright notice and this permission notice appear 91bedbe3fSmrg * in supporting documentation, and that the names of Network Computing 101bedbe3fSmrg * Devices or Digital not be used in advertising or publicity pertaining 111bedbe3fSmrg * to distribution of the software without specific, written prior 121bedbe3fSmrg * permission. Network Computing Devices or Digital make no representations 131bedbe3fSmrg * about the suitability of this software for any purpose. It is provided 14ba6a1819Smrg * "as is" without express or implied warranty. 15ba6a1819Smrg * 16ba6a1819Smrg * NETWORK COMPUTING DEVICES AND DIGITAL DISCLAIM ALL WARRANTIES WITH 171bedbe3fSmrg * REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF 18ba6a1819Smrg * MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL NETWORK COMPUTING DEVICES 191bedbe3fSmrg * OR DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES 201bedbe3fSmrg * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, 211bedbe3fSmrg * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, 221bedbe3fSmrg * ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS 23ba6a1819Smrg * SOFTWARE. 24ba6a1819Smrg */ 25ba6a1819Smrg 26ba6a1819Smrg/* 27ba6a1819Smrg 28ba6a1819SmrgCopyright 1987, 1994, 1998 The Open Group 29ba6a1819Smrg 30ba6a1819SmrgPermission to use, copy, modify, distribute, and sell this software and its 31ba6a1819Smrgdocumentation for any purpose is hereby granted without fee, provided that 32ba6a1819Smrgthe above copyright notice appear in all copies and that both that 33ba6a1819Smrgcopyright notice and this permission notice appear in supporting 34ba6a1819Smrgdocumentation. 35ba6a1819Smrg 36ba6a1819SmrgThe above copyright notice and this permission notice shall be included in 37ba6a1819Smrgall copies or substantial portions of the Software. 38ba6a1819Smrg 39ba6a1819SmrgTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 40ba6a1819SmrgIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 41ba6a1819SmrgFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 42ba6a1819SmrgOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 43ba6a1819SmrgAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 44ba6a1819SmrgCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 45ba6a1819Smrg 46ba6a1819SmrgExcept as contained in this notice, the name of The Open Group shall not be 47ba6a1819Smrgused in advertising or otherwise to promote the sale, use or other dealings 48ba6a1819Smrgin this Software without prior written authorization from The Open Group. 49ba6a1819Smrg 50ba6a1819Smrg*/ 51ba6a1819Smrg 52ba6a1819Smrg/* 53ba6a1819Smrg * FSlib networking & os include file 54ba6a1819Smrg */ 55ba6a1819Smrg 56ba6a1819Smrg#include <X11/Xfuncs.h> 57da1f2d5dSmrg#include <X11/Xfuncproto.h> 58ba6a1819Smrg#include <X11/Xosdefs.h> 59ba6a1819Smrg 60ba6a1819Smrg#ifndef WIN32 61ba6a1819Smrg 62298453a4Smrg# if defined(__SCO__) || defined(__UNIXWARE__) 63298453a4Smrg# include <stdint.h> /* For SIZE_MAX */ 64298453a4Smrg# endif 65ba6a1819Smrg 66ba6a1819Smrg/* 67ba6a1819Smrg * makedepend screws up on #undef OPEN_MAX, so we define a new symbol 68ba6a1819Smrg */ 69ba6a1819Smrg 70298453a4Smrg# ifndef FS_OPEN_MAX 71298453a4Smrg 72298453a4Smrg# ifdef _POSIX_SOURCE 73298453a4Smrg# include <limits.h> 74298453a4Smrg# else 75298453a4Smrg# define _POSIX_SOURCE 76298453a4Smrg# include <limits.h> 77298453a4Smrg# undef _POSIX_SOURCE 78298453a4Smrg# endif 79298453a4Smrg# ifndef SIZE_MAX 80298453a4Smrg# ifdef ULONG_MAX 81298453a4Smrg# define SIZE_MAX ULONG_MAX 82298453a4Smrg# else 83298453a4Smrg# define SIZE_MAX UINT_MAX 84298453a4Smrg# endif 85298453a4Smrg# endif 86298453a4Smrg# ifndef OPEN_MAX 87298453a4Smrg# ifdef SVR4 88298453a4Smrg# define OPEN_MAX 256 89298453a4Smrg# else 90298453a4Smrg# include <sys/param.h> 91298453a4Smrg# ifndef OPEN_MAX 92298453a4Smrg# ifdef __OSF1__ 93298453a4Smrg# define OPEN_MAX 256 94298453a4Smrg# else 95298453a4Smrg# ifdef NOFILE 96298453a4Smrg# define OPEN_MAX NOFILE 97298453a4Smrg# else 98298453a4Smrg# if !defined(__UNIXOS2__) && !defined(__QNX__) 99298453a4Smrg# ifdef __GNU__ 100298453a4Smrg# define OPEN_MAX (sysconf(_SC_OPEN_MAX)) 101298453a4Smrg# else /* !__GNU__ */ 102298453a4Smrg# define OPEN_MAX NOFILES_MAX 103298453a4Smrg# endif /* __GNU__ */ 104298453a4Smrg# else /* !__UNIXOS2__ && !__QNX__ */ 105298453a4Smrg# define OPEN_MAX 256 106298453a4Smrg# endif /* __UNIXOS2__ */ 107298453a4Smrg# endif 108298453a4Smrg# endif 109298453a4Smrg# endif 110298453a4Smrg# endif 111298453a4Smrg# endif 112298453a4Smrg 113298453a4Smrg# ifdef __GNU__ 114298453a4Smrg# define FS_OPEN_MAX 256 115298453a4Smrg# else /*!__GNU__*/ 116298453a4Smrg# if OPEN_MAX > 256 117298453a4Smrg# define FS_OPEN_MAX 256 118298453a4Smrg# else 119298453a4Smrg# define FS_OPEN_MAX OPEN_MAX 120298453a4Smrg# endif 121298453a4Smrg# endif /*__GNU__*/ 122298453a4Smrg 123298453a4Smrg# endif /* FS_OPEN_MAX */ 124ba6a1819Smrg 125ba6a1819Smrg/* Utek leaves kernel macros around in include files (bleah) */ 126ba6a1819Smrg 127298453a4Smrg# ifdef dirty 128298453a4Smrg# undef dirty 129298453a4Smrg# endif 130ba6a1819Smrg 131298453a4Smrg# define NMSKBITS 32 132298453a4Smrg# define MSKCNT ((FS_OPEN_MAX + NMSKBITS - 1) / NMSKBITS) 133ba6a1819Smrg 134298453a4Smrg# ifdef LONG64 135ba6a1819Smrgtypedef unsigned int FdSet[MSKCNT]; 136298453a4Smrg# else 137ba6a1819Smrgtypedef unsigned long FdSet[MSKCNT]; 138298453a4Smrg# endif 139ba6a1819Smrg 140298453a4Smrg# if (MSKCNT==1) 141298453a4Smrg# define BITMASK(i) (1 << (i)) 142298453a4Smrg# define MASKIDX(i) 0 143298453a4Smrg# endif 144ba6a1819Smrg 145298453a4Smrg# if (MSKCNT>1) 146298453a4Smrg# define BITMASK(i) (1 << ((i) & (NMSKBITS - 1))) 147298453a4Smrg# define MASKIDX(i) ((i) / NMSKBITS) 148298453a4Smrg# endif 149ba6a1819Smrg 150298453a4Smrg# define MASKWORD(buf, i) buf[MASKIDX(i)] 151298453a4Smrg# define BITSET(buf, i) MASKWORD(buf, i) |= BITMASK(i) 152298453a4Smrg# define BITCLEAR(buf, i) MASKWORD(buf, i) &= ~BITMASK(i) 153298453a4Smrg# define GETBIT(buf, i) (MASKWORD(buf, i) & BITMASK(i)) 154298453a4Smrg 155298453a4Smrg# if (MSKCNT==1) 156298453a4Smrg# define COPYBITS(src, dst) dst[0] = src[0] 157298453a4Smrg# define CLEARBITS(buf) buf[0] = 0 158298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) dst[0] = (b1[0] & b2[0]) 159298453a4Smrg# define ORBITS(dst, b1, b2) dst[0] = (b1[0] | b2[0]) 160298453a4Smrg# define UNSETBITS(dst, b1) (dst[0] &= ~b1[0]) 161298453a4Smrg# define _FSANYSET(src) (src[0]) 162298453a4Smrg# endif 163ba6a1819Smrg 164298453a4Smrg# if (MSKCNT==2) 165298453a4Smrg# define COPYBITS(src, dst) { dst[0] = src[0]; dst[1] = src[1]; } 166298453a4Smrg# define CLEARBITS(buf) { buf[0] = 0; buf[1] = 0; } 167298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) {\ 168ba6a1819Smrg dst[0] = (b1[0] & b2[0]);\ 169ba6a1819Smrg dst[1] = (b1[1] & b2[1]); } 170298453a4Smrg# define ORBITS(dst, b1, b2) {\ 171ba6a1819Smrg dst[0] = (b1[0] | b2[0]);\ 172ba6a1819Smrg dst[1] = (b1[1] | b2[1]); } 173298453a4Smrg# define UNSETBITS(dst, b1) {\ 174ba6a1819Smrg dst[0] &= ~b1[0]; \ 175ba6a1819Smrg dst[1] &= ~b1[1]; } 176298453a4Smrg# define _FSANYSET(src) (src[0] || src[1]) 177298453a4Smrg# endif 178ba6a1819Smrg 179298453a4Smrg# if (MSKCNT==3) 180298453a4Smrg# define COPYBITS(src, dst) { dst[0] = src[0]; dst[1] = src[1]; \ 181ba6a1819Smrg dst[2] = src[2]; } 182298453a4Smrg# define CLEARBITS(buf) { buf[0] = 0; buf[1] = 0; buf[2] = 0; } 183298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) {\ 184ba6a1819Smrg dst[0] = (b1[0] & b2[0]);\ 185ba6a1819Smrg dst[1] = (b1[1] & b2[1]);\ 186ba6a1819Smrg dst[2] = (b1[2] & b2[2]); } 187298453a4Smrg# define ORBITS(dst, b1, b2) {\ 188ba6a1819Smrg dst[0] = (b1[0] | b2[0]);\ 189ba6a1819Smrg dst[1] = (b1[1] | b2[1]);\ 190ba6a1819Smrg dst[2] = (b1[2] | b2[2]); } 191298453a4Smrg# define UNSETBITS(dst, b1) {\ 192ba6a1819Smrg dst[0] &= ~b1[0]; \ 193ba6a1819Smrg dst[1] &= ~b1[1]; \ 194ba6a1819Smrg dst[2] &= ~b1[2]; } 195298453a4Smrg# define _FSANYSET(src) (src[0] || src[1] || src[2]) 196298453a4Smrg# endif 197ba6a1819Smrg 198298453a4Smrg# if (MSKCNT==4) 199298453a4Smrg# define COPYBITS(src, dst) dst[0] = src[0]; dst[1] = src[1]; \ 200ba6a1819Smrg dst[2] = src[2]; dst[3] = src[3] 201298453a4Smrg# define CLEARBITS(buf) buf[0] = 0; buf[1] = 0; buf[2] = 0; buf[3] = 0 202298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) \ 203ba6a1819Smrg dst[0] = (b1[0] & b2[0]);\ 204ba6a1819Smrg dst[1] = (b1[1] & b2[1]);\ 205ba6a1819Smrg dst[2] = (b1[2] & b2[2]);\ 206ba6a1819Smrg dst[3] = (b1[3] & b2[3]) 207298453a4Smrg# define ORBITS(dst, b1, b2) \ 208ba6a1819Smrg dst[0] = (b1[0] | b2[0]);\ 209ba6a1819Smrg dst[1] = (b1[1] | b2[1]);\ 210ba6a1819Smrg dst[2] = (b1[2] | b2[2]);\ 211ba6a1819Smrg dst[3] = (b1[3] | b2[3]) 212298453a4Smrg# define UNSETBITS(dst, b1) \ 213ba6a1819Smrg dst[0] &= ~b1[0]; \ 214ba6a1819Smrg dst[1] &= ~b1[1]; \ 215ba6a1819Smrg dst[2] &= ~b1[2]; \ 216ba6a1819Smrg dst[3] &= ~b1[3] 217298453a4Smrg# define _FSANYSET(src) (src[0] || src[1] || src[2] || src[3]) 218298453a4Smrg# endif 219ba6a1819Smrg 220298453a4Smrg# if (MSKCNT>4) 221298453a4Smrg# define COPYBITS(src, dst) memmove((caddr_t) dst, (caddr_t) src, sizeof(FdSet)) 222298453a4Smrg# define CLEARBITS(buf) bzero((caddr_t) buf, sizeof(FdSet)) 223298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) \ 224ba6a1819Smrg { int cri; \ 225ba6a1819Smrg for (cri=0; cri<MSKCNT; cri++) \ 226ba6a1819Smrg dst[cri] = (b1[cri] & b2[cri]) } 227298453a4Smrg# define ORBITS(dst, b1, b2) \ 228ba6a1819Smrg { int cri; \ 229ba6a1819Smrg for (cri=0; cri<MSKCNT; cri++) \ 230ba6a1819Smrg dst[cri] = (b1[cri] | b2[cri]) } 231298453a4Smrg# define UNSETBITS(dst, b1) \ 232ba6a1819Smrg { int cri; \ 233ba6a1819Smrg for (cri=0; cri<MSKCNT; cri++) \ 234ba6a1819Smrg dst[cri] &= ~b1[cri]; } 235298453a4Smrg# if (MSKCNT==8) 236298453a4Smrg# define _FSANYSET(src) (src[0] || src[1] || src[2] || src[3] || \ 237ba6a1819Smrg src[4] || src[5] || src[6] || src[7]) 238298453a4Smrg# endif 239ba6a1819Smrg/* 240ba6a1819Smrg * If MSKCNT>4 and not 8, then _FSANYSET is a routine defined in FSlibInt.c. 241ba6a1819Smrg * 242ba6a1819Smrg * #define _FSANYSET(src) (src[0] || src[1] || src[2] || src[3] || src[4] ...) 243ba6a1819Smrg */ 244298453a4Smrg# endif 245ba6a1819Smrg 246ba6a1819Smrg 247ba6a1819Smrg#else 248ba6a1819Smrg 249298453a4Smrg# include <X11/Xwinsock.h> 250298453a4Smrg# include <X11/Xw32defs.h> 251ba6a1819Smrg 252ba6a1819Smrgtypedef fd_set FdSet; 253ba6a1819Smrg 254298453a4Smrg# define CLEARBITS(set) FD_ZERO(&set) 255298453a4Smrg# define BITSET(set,s) FD_SET(s,&set) 256298453a4Smrg# define _FSANYSET(set) set.fd_count 257ba6a1819Smrg 258ba6a1819Smrg#endif 259ba6a1819Smrg 260ba6a1819Smrg#include <X11/Xtrans/Xtrans.h> 261ba6a1819Smrg#include <stdlib.h> 262ba6a1819Smrg#include <string.h> 263ba6a1819Smrg 264ba6a1819Smrg/* 265ba6a1819Smrg * The following definitions can be used for locking requests in multi-threaded 266ba6a1819Smrg * address spaces. 267ba6a1819Smrg */ 268ba6a1819Smrg#define LockDisplay(dis) 269ba6a1819Smrg#define LockMutex(mutex) 270ba6a1819Smrg#define UnlockMutex(mutex) 271ba6a1819Smrg#define UnlockDisplay(dis) 272ba6a1819Smrg#define FSfree(ptr) free((ptr)) 273ba6a1819Smrg 274da1f2d5dSmrg#ifndef HAVE_REALLOCARRAY 275da1f2d5dSmrgextern _X_HIDDEN void *fsreallocarray(void *optr, size_t nmemb, size_t size); 276da1f2d5dSmrg# define reallocarray(ptr, n, size) \ 277da1f2d5dSmrg fsreallocarray((ptr), (size_t)(n), (size_t)(size)) 278da1f2d5dSmrg#endif 279ba6a1819Smrg 280ba6a1819Smrg/* 281ba6a1819Smrg * Note that some machines do not return a valid pointer for malloc(0), in 282ba6a1819Smrg * which case we provide an alternate under the control of the 283ba6a1819Smrg * define MALLOC_0_RETURNS_NULL. This is necessary because some 284ba6a1819Smrg * FSlib code expects malloc(0) to return a valid pointer to storage. 285ba6a1819Smrg */ 286ba6a1819Smrg 287da1f2d5dSmrg#if defined(MALLOC_0_RETURNS_NULL) || defined(__clang_analyzer__) 288298453a4Smrg# define FSmalloc(size) malloc(((size) > 0 ? (size) : 1)) 289298453a4Smrg# define FSrealloc(ptr, size) realloc((ptr), ((size) > 0 ? (size) : 1)) 290298453a4Smrg# define FScalloc(nelem, elsize) calloc(((nelem) > 0 ? (nelem) : 1), (elsize)) 291da1f2d5dSmrg# define FSreallocarray(ptr, n, size) \ 292da1f2d5dSmrg reallocarray((ptr), ((n) == 0 ? 1 : (n)), size) 293ba6a1819Smrg 294ba6a1819Smrg#else 295ba6a1819Smrg 296298453a4Smrg# define FSmalloc(size) malloc((size)) 297298453a4Smrg# define FSrealloc(ptr, size) realloc((ptr), (size)) 298298453a4Smrg# define FScalloc(nelem, elsize) calloc((nelem), (elsize)) 299da1f2d5dSmrg# define FSreallocarray(ptr, n, size) reallocarray((ptr), (n), (size)) 300da1f2d5dSmrg 301ba6a1819Smrg#endif 302ba6a1819Smrg 303da1f2d5dSmrg#define FSmallocarray(n, size) FSreallocarray(NULL, (n), (size)) 304da1f2d5dSmrg 305ba6a1819Smrg#define SearchString(string, char) index((string), (char)) 306