FSlibos.h revision 00ca1914
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 6200ca1914Smrg# ifdef HAVE_STDINT_H 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 8700ca1914Smrg# include <sys/param.h> 8800ca1914Smrg# ifndef OPEN_MAX 8900ca1914Smrg# ifdef NOFILE 9000ca1914Smrg# define OPEN_MAX NOFILE 9100ca1914Smrg# else 9200ca1914Smrg# ifdef NOFILES_MAX 9300ca1914Smrg# define OPEN_MAX NOFILES_MAX 94298453a4Smrg# endif 95298453a4Smrg# endif 96298453a4Smrg# endif 97298453a4Smrg# endif 98298453a4Smrg 9900ca1914Smrg# ifndef OPEN_MAX 100298453a4Smrg# define FS_OPEN_MAX 256 10100ca1914Smrg# else /* !OPEN_MAX */ 102298453a4Smrg# if OPEN_MAX > 256 103298453a4Smrg# define FS_OPEN_MAX 256 104298453a4Smrg# else 105298453a4Smrg# define FS_OPEN_MAX OPEN_MAX 106298453a4Smrg# endif 10700ca1914Smrg# endif /* OPEN_MAX */ 108298453a4Smrg 109298453a4Smrg# endif /* FS_OPEN_MAX */ 110ba6a1819Smrg 111298453a4Smrg# define NMSKBITS 32 112298453a4Smrg# define MSKCNT ((FS_OPEN_MAX + NMSKBITS - 1) / NMSKBITS) 113ba6a1819Smrg 114298453a4Smrg# ifdef LONG64 115ba6a1819Smrgtypedef unsigned int FdSet[MSKCNT]; 116298453a4Smrg# else 117ba6a1819Smrgtypedef unsigned long FdSet[MSKCNT]; 118298453a4Smrg# endif 119ba6a1819Smrg 120298453a4Smrg# if (MSKCNT==1) 121298453a4Smrg# define BITMASK(i) (1 << (i)) 122298453a4Smrg# define MASKIDX(i) 0 123298453a4Smrg# endif 124ba6a1819Smrg 125298453a4Smrg# if (MSKCNT>1) 126298453a4Smrg# define BITMASK(i) (1 << ((i) & (NMSKBITS - 1))) 127298453a4Smrg# define MASKIDX(i) ((i) / NMSKBITS) 128298453a4Smrg# endif 129ba6a1819Smrg 130298453a4Smrg# define MASKWORD(buf, i) buf[MASKIDX(i)] 131298453a4Smrg# define BITSET(buf, i) MASKWORD(buf, i) |= BITMASK(i) 132298453a4Smrg# define BITCLEAR(buf, i) MASKWORD(buf, i) &= ~BITMASK(i) 133298453a4Smrg# define GETBIT(buf, i) (MASKWORD(buf, i) & BITMASK(i)) 134298453a4Smrg 135298453a4Smrg# if (MSKCNT==1) 136298453a4Smrg# define COPYBITS(src, dst) dst[0] = src[0] 137298453a4Smrg# define CLEARBITS(buf) buf[0] = 0 138298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) dst[0] = (b1[0] & b2[0]) 139298453a4Smrg# define ORBITS(dst, b1, b2) dst[0] = (b1[0] | b2[0]) 140298453a4Smrg# define UNSETBITS(dst, b1) (dst[0] &= ~b1[0]) 141298453a4Smrg# define _FSANYSET(src) (src[0]) 142298453a4Smrg# endif 143ba6a1819Smrg 144298453a4Smrg# if (MSKCNT==2) 145298453a4Smrg# define COPYBITS(src, dst) { dst[0] = src[0]; dst[1] = src[1]; } 146298453a4Smrg# define CLEARBITS(buf) { buf[0] = 0; buf[1] = 0; } 147298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) {\ 148ba6a1819Smrg dst[0] = (b1[0] & b2[0]);\ 149ba6a1819Smrg dst[1] = (b1[1] & b2[1]); } 150298453a4Smrg# define ORBITS(dst, b1, b2) {\ 151ba6a1819Smrg dst[0] = (b1[0] | b2[0]);\ 152ba6a1819Smrg dst[1] = (b1[1] | b2[1]); } 153298453a4Smrg# define UNSETBITS(dst, b1) {\ 154ba6a1819Smrg dst[0] &= ~b1[0]; \ 155ba6a1819Smrg dst[1] &= ~b1[1]; } 156298453a4Smrg# define _FSANYSET(src) (src[0] || src[1]) 157298453a4Smrg# endif 158ba6a1819Smrg 159298453a4Smrg# if (MSKCNT==3) 160298453a4Smrg# define COPYBITS(src, dst) { dst[0] = src[0]; dst[1] = src[1]; \ 161ba6a1819Smrg dst[2] = src[2]; } 162298453a4Smrg# define CLEARBITS(buf) { buf[0] = 0; buf[1] = 0; buf[2] = 0; } 163298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) {\ 164ba6a1819Smrg dst[0] = (b1[0] & b2[0]);\ 165ba6a1819Smrg dst[1] = (b1[1] & b2[1]);\ 166ba6a1819Smrg dst[2] = (b1[2] & b2[2]); } 167298453a4Smrg# define ORBITS(dst, b1, b2) {\ 168ba6a1819Smrg dst[0] = (b1[0] | b2[0]);\ 169ba6a1819Smrg dst[1] = (b1[1] | b2[1]);\ 170ba6a1819Smrg dst[2] = (b1[2] | b2[2]); } 171298453a4Smrg# define UNSETBITS(dst, b1) {\ 172ba6a1819Smrg dst[0] &= ~b1[0]; \ 173ba6a1819Smrg dst[1] &= ~b1[1]; \ 174ba6a1819Smrg dst[2] &= ~b1[2]; } 175298453a4Smrg# define _FSANYSET(src) (src[0] || src[1] || src[2]) 176298453a4Smrg# endif 177ba6a1819Smrg 178298453a4Smrg# if (MSKCNT==4) 179298453a4Smrg# define COPYBITS(src, dst) dst[0] = src[0]; dst[1] = src[1]; \ 180ba6a1819Smrg dst[2] = src[2]; dst[3] = src[3] 181298453a4Smrg# define CLEARBITS(buf) buf[0] = 0; buf[1] = 0; buf[2] = 0; buf[3] = 0 182298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) \ 183ba6a1819Smrg dst[0] = (b1[0] & b2[0]);\ 184ba6a1819Smrg dst[1] = (b1[1] & b2[1]);\ 185ba6a1819Smrg dst[2] = (b1[2] & b2[2]);\ 186ba6a1819Smrg dst[3] = (b1[3] & b2[3]) 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]);\ 191ba6a1819Smrg dst[3] = (b1[3] | b2[3]) 192298453a4Smrg# define UNSETBITS(dst, b1) \ 193ba6a1819Smrg dst[0] &= ~b1[0]; \ 194ba6a1819Smrg dst[1] &= ~b1[1]; \ 195ba6a1819Smrg dst[2] &= ~b1[2]; \ 196ba6a1819Smrg dst[3] &= ~b1[3] 197298453a4Smrg# define _FSANYSET(src) (src[0] || src[1] || src[2] || src[3]) 198298453a4Smrg# endif 199ba6a1819Smrg 200298453a4Smrg# if (MSKCNT>4) 201298453a4Smrg# define COPYBITS(src, dst) memmove((caddr_t) dst, (caddr_t) src, sizeof(FdSet)) 202298453a4Smrg# define CLEARBITS(buf) bzero((caddr_t) buf, sizeof(FdSet)) 203298453a4Smrg# define MASKANDSETBITS(dst, b1, b2) \ 204ba6a1819Smrg { int cri; \ 205ba6a1819Smrg for (cri=0; cri<MSKCNT; cri++) \ 206ba6a1819Smrg dst[cri] = (b1[cri] & b2[cri]) } 207298453a4Smrg# define ORBITS(dst, b1, b2) \ 208ba6a1819Smrg { int cri; \ 209ba6a1819Smrg for (cri=0; cri<MSKCNT; cri++) \ 210ba6a1819Smrg dst[cri] = (b1[cri] | b2[cri]) } 211298453a4Smrg# define UNSETBITS(dst, b1) \ 212ba6a1819Smrg { int cri; \ 213ba6a1819Smrg for (cri=0; cri<MSKCNT; cri++) \ 214ba6a1819Smrg dst[cri] &= ~b1[cri]; } 215298453a4Smrg# if (MSKCNT==8) 216298453a4Smrg# define _FSANYSET(src) (src[0] || src[1] || src[2] || src[3] || \ 217ba6a1819Smrg src[4] || src[5] || src[6] || src[7]) 218298453a4Smrg# endif 219ba6a1819Smrg/* 220ba6a1819Smrg * If MSKCNT>4 and not 8, then _FSANYSET is a routine defined in FSlibInt.c. 221ba6a1819Smrg * 222ba6a1819Smrg * #define _FSANYSET(src) (src[0] || src[1] || src[2] || src[3] || src[4] ...) 223ba6a1819Smrg */ 224298453a4Smrg# endif 225ba6a1819Smrg 226ba6a1819Smrg 227ba6a1819Smrg#else 228ba6a1819Smrg 229298453a4Smrg# include <X11/Xwinsock.h> 230298453a4Smrg# include <X11/Xw32defs.h> 231ba6a1819Smrg 232ba6a1819Smrgtypedef fd_set FdSet; 233ba6a1819Smrg 234298453a4Smrg# define CLEARBITS(set) FD_ZERO(&set) 235298453a4Smrg# define BITSET(set,s) FD_SET(s,&set) 236298453a4Smrg# define _FSANYSET(set) set.fd_count 237ba6a1819Smrg 238ba6a1819Smrg#endif 239ba6a1819Smrg 240ba6a1819Smrg#include <X11/Xtrans/Xtrans.h> 241ba6a1819Smrg#include <stdlib.h> 242ba6a1819Smrg#include <string.h> 243ba6a1819Smrg 244ba6a1819Smrg/* 245ba6a1819Smrg * The following definitions can be used for locking requests in multi-threaded 246ba6a1819Smrg * address spaces. 247ba6a1819Smrg */ 248ba6a1819Smrg#define LockDisplay(dis) 249ba6a1819Smrg#define LockMutex(mutex) 250ba6a1819Smrg#define UnlockMutex(mutex) 251ba6a1819Smrg#define UnlockDisplay(dis) 252ba6a1819Smrg#define FSfree(ptr) free((ptr)) 253ba6a1819Smrg 254da1f2d5dSmrg#ifndef HAVE_REALLOCARRAY 255da1f2d5dSmrgextern _X_HIDDEN void *fsreallocarray(void *optr, size_t nmemb, size_t size); 256da1f2d5dSmrg# define reallocarray(ptr, n, size) \ 257da1f2d5dSmrg fsreallocarray((ptr), (size_t)(n), (size_t)(size)) 258da1f2d5dSmrg#endif 259ba6a1819Smrg 260ba6a1819Smrg/* 261ba6a1819Smrg * Note that some machines do not return a valid pointer for malloc(0), in 262ba6a1819Smrg * which case we provide an alternate under the control of the 263ba6a1819Smrg * define MALLOC_0_RETURNS_NULL. This is necessary because some 264ba6a1819Smrg * FSlib code expects malloc(0) to return a valid pointer to storage. 265ba6a1819Smrg */ 266ba6a1819Smrg 267da1f2d5dSmrg#if defined(MALLOC_0_RETURNS_NULL) || defined(__clang_analyzer__) 268298453a4Smrg# define FSmalloc(size) malloc(((size) > 0 ? (size) : 1)) 269298453a4Smrg# define FSrealloc(ptr, size) realloc((ptr), ((size) > 0 ? (size) : 1)) 270298453a4Smrg# define FScalloc(nelem, elsize) calloc(((nelem) > 0 ? (nelem) : 1), (elsize)) 271da1f2d5dSmrg# define FSreallocarray(ptr, n, size) \ 272da1f2d5dSmrg reallocarray((ptr), ((n) == 0 ? 1 : (n)), size) 273ba6a1819Smrg 274ba6a1819Smrg#else 275ba6a1819Smrg 276298453a4Smrg# define FSmalloc(size) malloc((size)) 277298453a4Smrg# define FSrealloc(ptr, size) realloc((ptr), (size)) 278298453a4Smrg# define FScalloc(nelem, elsize) calloc((nelem), (elsize)) 279da1f2d5dSmrg# define FSreallocarray(ptr, n, size) reallocarray((ptr), (n), (size)) 280da1f2d5dSmrg 281ba6a1819Smrg#endif 282ba6a1819Smrg 283da1f2d5dSmrg#define FSmallocarray(n, size) FSreallocarray(NULL, (n), (size)) 284da1f2d5dSmrg 285ba6a1819Smrg#define SearchString(string, char) index((string), (char)) 286