3 * (c) 1995 Microsoft Corporation. All rights reserved.
4 * Developed by hip communications inc.
6 * You may distribute under the terms of either the GNU General Public
7 * License or the Artistic License, as specified in the README file.
9 #ifndef _INC_WIN32_PERL5
10 #define _INC_WIN32_PERL5
13 # define _WIN32_WINNT 0x0500 /* needed for CreateHardlink() etc. */
16 /* Win32 only optimizations for faster building */
17 #ifdef PERL_IS_MINIPERL
18 /* this macro will remove Winsock only on miniperl, PERL_IMPLICIT_SYS and
19 * makedef.pl create dependencies that will keep Winsock linked in even with
20 * this macro defined, even though sockets will be umimplemented from a script
23 # define WIN32_NO_SOCKETS
24 /* less I/O calls during each require */
25 # define PERL_DISABLE_PMC
27 /* unnecessery for miniperl to lookup anything from an "installed" perl */
28 # define WIN32_NO_REGISTRY
30 /* allow minitest to work */
31 # define PERL_TEXTMODE_SCRIPTS
34 #ifdef WIN32_NO_SOCKETS
36 # undef HAS_GETPROTOBYNAME
37 # undef HAS_GETPROTOBYNUMBER
38 # undef HAS_GETPROTOENT
39 # undef HAS_GETNETBYNAME
40 # undef HAS_GETNETBYADDR
42 # undef HAS_GETSERVBYNAME
43 # undef HAS_GETSERVBYPORT
44 # undef HAS_GETSERVENT
45 # undef HAS_GETHOSTBYNAME
46 # undef HAS_GETHOSTBYADDR
47 # undef HAS_GETHOSTENT
54 # define WIN32SCK_IS_STDSCK
57 #if defined(PERL_IMPLICIT_SYS)
58 # define DYNAMIC_ENV_FETCH
59 # define HAS_GETENV_LEN
60 # define prime_env_iter()
61 # define WIN32IO_IS_STDIO /* don't pull in custom stdio layer */
62 # define WIN32SCK_IS_STDSCK /* don't pull in custom wsock layer */
63 # ifdef PERL_GLOBAL_STRUCT
64 # error PERL_GLOBAL_STRUCT cannot be defined with PERL_IMPLICIT_SYS
69 # ifndef __int64 /* some versions seem to #define it already */
70 # define __int64 long long
72 # define Win32_Winsock
76 /* Define DllExport akin to perl's EXT,
77 * If we are in the DLL then Export the symbol,
78 * otherwise import it.
81 /* now even GCC supports __declspec() */
82 /* miniperl has no reason to export anything */
83 #if defined(PERL_IS_MINIPERL)
87 # define DllExport __declspec(dllexport)
89 # define DllExport __declspec(dllimport)
93 /* The Perl APIs can only be called directly inside the perl5xx.dll.
94 * All other code has to import them. By declaring them as "dllimport"
95 * we tell the compiler to generate an indirect call instruction and
96 * avoid redirection through a call thunk.
98 * The XS code in the re extension is special, in that it redefines
99 * core APIs locally, so don't mark them as "dllimport" because GCC
100 * cannot handle this situation.
102 * Certain old GCCs will not allow the function pointer of dllimport marked
103 * function to be "const". This was fixed later on. Since this is a
104 * deoptimization, target "gcc version 3.4.5 (mingw-vista special r3)" only,
105 * The GCC bug was fixed in GCC patch "varasm.c (initializer_constant_valid_p):
106 * Don't deny DECL_DLLIMPORT_P on functions", which probably was first released
107 * in GCC 4.3.0, this #if can be expanded upto but not including 4.3.0 if more
108 * deployed GCC are found that wont build with the follow error, initializer
109 * element is a PerlIO func exported from perl5xx.dll.
111 * encoding.xs:610: error: initializer element is not constant
112 * encoding.xs:610: error: (near initialization for `PerlIO_encode.Open')
115 #if (defined(__GNUC__) && defined(__MINGW32__) && \
116 !defined(__MINGW64_VERSION_MAJOR) && !defined(__clang__) && \
117 ((__GNUC__ < 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ <= 5))))
118 /* use default fallbacks from perl.h for this particular GCC */
120 # if !defined(PERLDLL) && !defined(PERL_EXT_RE_BUILD)
122 # define PERL_CALLCONV extern "C" __declspec(dllimport)
124 # define PERL_CALLCONV_NO_RET extern "C" __declspec(dllimport) __declspec(noreturn)
127 # define PERL_CALLCONV __declspec(dllimport)
129 # define PERL_CALLCONV_NO_RET __declspec(dllimport) __declspec(noreturn)
132 # else /* MSVC noreturn support inside the interp */
134 # define PERL_CALLCONV_NO_RET __declspec(noreturn)
140 # define PERL_STATIC_NO_RET __declspec(noreturn) static
141 # define PERL_STATIC_INLINE_NO_RET __declspec(noreturn) PERL_STATIC_INLINE
144 #define WIN32_LEAN_AND_MEAN
148 * Bug in winbase.h in mingw-w64 4.4.0-1 at least... they
149 * do #define GetEnvironmentStringsA GetEnvironmentStrings and fail
150 * to declare GetEnvironmentStringsA.
152 #if defined(__MINGW64__) && defined(GetEnvironmentStringsA) && !defined(UNICODE)
156 #undef GetEnvironmentStringsA
157 WINBASEAPI LPCH WINAPI GetEnvironmentStringsA(VOID);
158 #define GetEnvironmentStrings GetEnvironmentStringsA
164 #ifdef WIN32_LEAN_AND_MEAN /* C file is NOT a Perl5 original. */
165 #define CONTEXT PERL_CONTEXT /* Avoid conflict of CONTEXT defs. */
166 #endif /*WIN32_LEAN_AND_MEAN */
168 #ifndef TLS_OUT_OF_INDEXES
169 #define TLS_OUT_OF_INDEXES (DWORD)0xFFFFFFFF
196 char sysname[SYS_NMLN];
197 char nodename[SYS_NMLN];
198 char release[SYS_NMLN];
199 char version[SYS_NMLN];
200 char machine[SYS_NMLN];
203 #ifndef START_EXTERN_C
206 # define START_EXTERN_C extern "C" {
207 # define END_EXTERN_C }
208 # define EXTERN_C extern "C"
210 # define START_EXTERN_C
211 # define END_EXTERN_C
216 #define DOSISH 1 /* no escaping our roots */
217 #define OP_BINARY O_BINARY /* mistake in in pp_sys.c? */
219 /* read() and write() aren't transparent for socket handles */
220 #ifndef WIN32_NO_SOCKETS
221 # define PERL_SOCK_SYSREAD_IS_RECV
222 # define PERL_SOCK_SYSWRITE_IS_SEND
225 #ifdef WIN32_NO_REGISTRY
226 /* the last _ in WIN32_NO_REGISTRY_M_ is like the _ in aTHX_ */
227 # define WIN32_NO_REGISTRY_M_(x)
229 # define WIN32_NO_REGISTRY_M_(x) x,
232 #define PERL_NO_FORCE_LINK /* no need for PL_force_link_funcs */
234 #define ENV_IS_CASELESS
236 #define PIPESOCK_MODE "b" /* pipes, sockets default to binmode */
238 /* access() mode bits */
251 #define PERL_GET_CONTEXT_DEFINED
253 /* Compiler-specific stuff. */
255 /* VC uses non-standard way to determine the size and alignment if bit-fields */
256 /* MinGW will compile with -mms-bitfields, so should use the same types */
257 #define PERL_BITFIELD8 unsigned char
258 #define PERL_BITFIELD16 unsigned short
259 #define PERL_BITFIELD32 unsigned int
261 #ifdef _MSC_VER /* Microsoft Visual C++ */
265 typedef unsigned short mode_t;
268 #define isnan _isnan /* Defined already in VC++ 12.0 */
270 #define snprintf _snprintf
271 #define vsnprintf _vsnprintf
273 /* on VS2003, msvcrt.lib is missing these symbols */
274 #if _MSC_VER >= 1300 && _MSC_VER < 1400
275 # pragma intrinsic(_rotl64,_rotr64)
278 MSVC_DIAG_IGNORE(4756 4056)
280 double S_Infinity() {
281 /* this is a real C literal which can get further constant folded
282 unlike using HUGE_VAL/_HUGE which are data symbol imports from the CRT
283 and therefore can not by folded by VC, an example of constant
284 folding INF is creating -INF */
285 return (DBL_MAX+DBL_MAX);
289 #define NV_INF S_Infinity()
291 /* selectany allows duplicate and unused data symbols to be removed by
292 VC linker, if this were static, each translation unit will have its own,
293 usually unused __PL_nan_u, if this were plain extern it will cause link
294 to fail due to multiple definitions, since we dont know if we are being
295 compiled as static or DLL XS, selectany simply always works, the cost of
296 importing __PL_nan_u across DLL boundaries in size in the importing DLL
297 will be more than the 8 bytes it will take up being in each XS DLL if
298 that DLL actually uses __PL_nan_u */
299 extern const __declspec(selectany) union { unsigned __int64 __q; double __d; }
300 __PL_nan_u = { 0x7FF8000000000000UI64 };
301 #define NV_NAN ((NV)__PL_nan_u.__d)
303 /* The CRT was rewritten in VS2015. */
306 /* No longer declared in stdio.h */
307 EXTERN_C char *gets(char* buffer);
309 #define tzname _tzname
311 /* From corecrt_internal_stdio.h: */
327 CRITICAL_SECTION _lock;
328 } __crt_stdio_stream_data;
330 #define PERLIO_FILE_flag_RD 0x0001 /* _IOREAD */
331 #define PERLIO_FILE_flag_WR 0x0002 /* _IOWRITE */
332 #define PERLIO_FILE_flag_RW 0x0004 /* _IOUPDATE */
333 #define PERLIO_FILE_ptr(f) (((__crt_stdio_stream_data*)(f))->_ptr)
334 #define PERLIO_FILE_base(f) (((__crt_stdio_stream_data*)(f))->_base)
335 #define PERLIO_FILE_cnt(f) (((__crt_stdio_stream_data*)(f))->_cnt)
336 #define PERLIO_FILE_flag(f) ((int)(((__crt_stdio_stream_data*)(f))->_flags))
337 #define PERLIO_FILE_file(f) (*(int*)(&((__crt_stdio_stream_data*)(f))->_file))
341 #endif /* _MSC_VER */
343 #if (!defined(_MSC_VER)) || (defined(_MSC_VER) && _MSC_VER < 1900)
345 /* Note: PERLIO_FILE_ptr/base/cnt are not actually used for GCC or <VS2015
346 * since FILE_ptr/base/cnt do the same thing anyway but it doesn't hurt to
347 * define them all here for completeness. */
348 #define PERLIO_FILE_flag_RD _IOREAD /* 0x001 */
349 #define PERLIO_FILE_flag_WR _IOWRT /* 0x002 */
350 #define PERLIO_FILE_flag_RW _IORW /* 0x080 */
351 #define PERLIO_FILE_ptr(f) ((f)->_ptr)
352 #define PERLIO_FILE_base(f) ((f)->_base)
353 #define PERLIO_FILE_cnt(f) ((f)->_cnt)
354 #define PERLIO_FILE_flag(f) ((f)->_flag)
355 #define PERLIO_FILE_file(f) ((f)->_file)
359 #ifdef __MINGW32__ /* Minimal Gnu-Win32 */
364 #define _environ environ
366 #define flushall _flushall
367 #define fcloseall _fcloseall
369 #define isnan _isnan /* ...same libraries as MSVC */
373 # define _O_NOINHERIT 0x0080
374 # ifndef _NO_OLDNAMES
375 # define O_NOINHERIT _O_NOINHERIT
379 /* <stdint.h>, pulled in by <io.h> as of mingw-runtime-3.3, typedef's
380 * (u)intptr_t but doesn't set the _(U)INTPTR_T_DEFINED defines */
382 # ifndef _INTPTR_T_DEFINED
383 # define _INTPTR_T_DEFINED
385 # ifndef _UINTPTR_T_DEFINED
386 # define _UINTPTR_T_DEFINED
391 # define CP_UTF8 65001
394 #endif /* __MINGW32__ */
396 #ifndef _INTPTR_T_DEFINED
397 typedef int intptr_t;
398 # define _INTPTR_T_DEFINED
401 #ifndef _UINTPTR_T_DEFINED
402 typedef unsigned int uintptr_t;
403 # define _UINTPTR_T_DEFINED
408 /* For UNIX compatibility. */
411 extern uid_t getuid(void);
412 extern gid_t getgid(void);
413 extern uid_t geteuid(void);
414 extern gid_t getegid(void);
415 extern int setuid(uid_t uid);
416 extern int setgid(gid_t gid);
417 extern int kill(int pid, int sig);
418 #ifndef USE_PERL_SBRK
419 extern void *sbrk(ptrdiff_t need);
420 # define HAS_SBRK_PROTO
422 extern char * getlogin(void);
423 extern int chown(const char *p, uid_t o, gid_t g);
424 #if !defined(__MINGW64_VERSION_MAJOR) || __MINGW64_VERSION_MAJOR < 4
425 extern int mkstemp(const char *path);
430 #define Stat win32_stat
432 #undef init_os_extras
433 #define init_os_extras Perl_init_os_extras
435 DllExport void Perl_win32_init(int *argcp, char ***argvp);
436 DllExport void Perl_win32_term(void);
437 DllExport void Perl_init_os_extras(void);
438 DllExport void win32_str_os_error(void *sv, DWORD err);
439 DllExport int RunPerl(int argc, char **argv, char **env);
446 * the following correspond to the fields of the same name
447 * in the STARTUPINFO structure. Embedders can use these to
448 * control the spawning process' look.
449 * Example - to hide the window of the spawned process:
450 * dwFlags = STARTF_USESHOWWINDOW;
451 * wShowWindow = SW_HIDE;
460 DWORD dwFillAttribute;
464 DllExport void win32_get_child_IO(child_IO_table* ptr);
465 DllExport HWND win32_create_message_window(void);
466 DllExport int win32_async_check(pTHX);
468 extern int my_fclose(FILE *);
469 extern char * win32_get_privlib(WIN32_NO_REGISTRY_M_(const char *pl) STRLEN *const len);
470 extern char * win32_get_sitelib(const char *pl, STRLEN *const len);
471 extern char * win32_get_vendorlib(const char *pl, STRLEN *const len);
473 #ifdef PERL_IMPLICIT_SYS
474 extern void win32_delete_internal_host(void *h);
477 extern int win32_get_errno(int err);
479 extern const char * const staticlinkmodules[];
483 typedef char * caddr_t; /* In malloc.c (core address). */
486 * handle socket stuff, assuming socket is always available
488 #include <sys/socket.h>
492 #define EMBEDMYMALLOC /**/
493 /* #define USE_PERL_SBRK / **/
494 /* #define PERL_SBRK_VIA_MALLOC / **/
497 #ifdef PERL_TEXTMODE_SCRIPTS
498 # define PERL_SCRIPT_MODE "r"
500 # define PERL_SCRIPT_MODE "rb"
504 * Now Win32 specific per-thread data stuff
507 /* Leave the first couple ids after WM_USER unused because they
508 * might be used by an embedding application, and on Windows
509 * version before 2000 we might end up eating those messages
510 * if they were not meant for us.
512 #define WM_USER_MIN (WM_USER+30)
513 #define WM_USER_MESSAGE (WM_USER_MIN)
514 #define WM_USER_KILL (WM_USER_MIN+1)
515 #define WM_USER_MAX (WM_USER_MIN+1)
517 struct thread_intern {
518 /* XXX can probably use one buffer instead of several */
519 char Wstrerror_buffer[512];
520 struct servent Wservent;
521 char Wgetlogin_buffer[128];
523 char Wcrypt_buffer[30];
524 # ifdef USE_RTL_THREAD_API
525 void * retv; /* slot for thread return value */
527 BOOL Wuse_showwindow;
531 #define HAVE_INTERP_INTERN
534 DWORD pids[MAXIMUM_WAIT_OBJECTS];
535 HANDLE handles[MAXIMUM_WAIT_OBJECTS];
541 DWORD pids[MAXIMUM_WAIT_OBJECTS];
542 HANDLE handles[MAXIMUM_WAIT_OBJECTS];
543 HWND message_hwnds[MAXIMUM_WAIT_OBJECTS];
544 char sigterm[MAXIMUM_WAIT_OBJECTS];
549 typedef Signal_t (*Sighandler_t) (int);
550 #define Sighandler_t Sighandler_t
553 struct interp_intern {
554 char * perlshell_tokens;
555 char ** perlshell_vec;
556 long perlshell_items;
558 child_tab * children;
561 pseudo_child_tab * pseudo_children;
563 void * internal_host;
564 struct thread_intern thr_intern;
568 Sighandler_t sigtable[SIG_SIZE];
572 #define WIN32_POLL_INTERVAL 32768
573 #define PERL_ASYNC_CHECK() if (w32_do_async || PL_sig_pending) win32_async_check(aTHX)
575 #define w32_perlshell_tokens (PL_sys_intern.perlshell_tokens)
576 #define w32_perlshell_vec (PL_sys_intern.perlshell_vec)
577 #define w32_perlshell_items (PL_sys_intern.perlshell_items)
578 #define w32_fdpid (PL_sys_intern.fdpid)
579 #define w32_children (PL_sys_intern.children)
580 #define w32_num_children (w32_children->num)
581 #define w32_child_pids (w32_children->pids)
582 #define w32_child_handles (w32_children->handles)
583 #define w32_pseudo_id (PL_sys_intern.pseudo_id)
584 #define w32_pseudo_children (PL_sys_intern.pseudo_children)
585 #define w32_num_pseudo_children (w32_pseudo_children->num)
586 #define w32_pseudo_child_pids (w32_pseudo_children->pids)
587 #define w32_pseudo_child_handles (w32_pseudo_children->handles)
588 #define w32_pseudo_child_message_hwnds (w32_pseudo_children->message_hwnds)
589 #define w32_pseudo_child_sigterm (w32_pseudo_children->sigterm)
590 #define w32_internal_host (PL_sys_intern.internal_host)
591 #define w32_timerid (PL_sys_intern.timerid)
592 #define w32_message_hwnd (PL_sys_intern.message_hwnd)
593 #define w32_sighandler (PL_sys_intern.sigtable)
594 #define w32_poll_count (PL_sys_intern.poll_count)
595 #define w32_do_async (w32_poll_count++ > WIN32_POLL_INTERVAL)
596 #define w32_strerror_buffer (PL_sys_intern.thr_intern.Wstrerror_buffer)
597 #define w32_getlogin_buffer (PL_sys_intern.thr_intern.Wgetlogin_buffer)
598 #define w32_crypt_buffer (PL_sys_intern.thr_intern.Wcrypt_buffer)
599 #define w32_servent (PL_sys_intern.thr_intern.Wservent)
600 #define w32_init_socktype (PL_sys_intern.thr_intern.Winit_socktype)
601 #define w32_use_showwindow (PL_sys_intern.thr_intern.Wuse_showwindow)
602 #define w32_showwindow (PL_sys_intern.thr_intern.Wshowwindow)
603 #define w32_sloppystat (PL_sys_intern.sloppystat)
606 void win32_wait_for_children(pTHX);
607 # define PERL_WAIT_FOR_CHILDREN win32_wait_for_children(aTHX)
610 /* The following ioinfo struct manipulations had been removed but were
611 * reinstated to fix RT#120091/118059. However, they do not work with
612 * the rewritten CRT in VS2015 so they are removed once again for VS2015
613 * onwards, which will therefore suffer from the reintroduction of the
614 * close socket bug. */
615 #if (!defined(_MSC_VER)) || (defined(_MSC_VER) && _MSC_VER < 1900)
619 /* C doesn't like repeat struct definitions */
620 #if defined(__MINGW32__) && (__MINGW32_MAJOR_VERSION>=3)
624 # define _CRTIMP __declspec(dllimport)
628 /* VS2005 has multiple ioinfo struct definitions through VS2005's release life
629 * VS2008-2012 have been stable but do not assume future VSs will have the
630 * same ioinfo struct, just because past struct stability. If research is done
631 * on the CRTs of future VSs, the version check can be bumped up so the newer
632 * VS uses a fixed ioinfo size. (Actually, only VS2013 (_MSC_VER 1800) hasn't
633 * been looked at; after that we cannot use the ioinfo struct anyway (see the
636 #if ! (_MSC_VER < 1400 || (_MSC_VER >= 1500 && _MSC_VER <= 1700) \
637 || defined(__MINGW32__))
638 /* size of ioinfo struct is determined at runtime */
639 # define WIN32_DYN_IOINFO_SIZE
642 #ifndef WIN32_DYN_IOINFO_SIZE
644 * Control structure for lowio file handles
647 intptr_t osfhnd;/* underlying OS file HANDLE */
648 char osfile; /* attributes of file (e.g., open in text mode?) */
649 char pipech; /* one char buffer for handles opened on pipes */
651 CRITICAL_SECTION lock;
652 /* this struct definition breaks ABI compatibility with
653 * not using, cl.exe's native VS version specitfic CRT. */
654 # if _MSC_VER >= 1400 && _MSC_VER < 1500
655 # error "This ioinfo struct is incomplete for Visual C 2005"
657 /* VS2005 CRT has at least 3 different definitions of this struct based on the
658 * CRT DLL's build number. */
659 # if _MSC_VER >= 1500
660 # ifndef _SAFECRT_IMPL
661 /* Not used in the safecrt downlevel. We do not define them, so we cannot
662 * use them accidentally */
663 char textmode : 7;/* __IOINFO_TM_ANSI or __IOINFO_TM_UTF8 or __IOINFO_TM_UTF16LE */
664 char unicode : 1; /* Was the file opened as unicode? */
665 char pipech2[2]; /* 2 more peak ahead chars for UNICODE mode */
666 __int64 startpos; /* File position that matches buffer start */
667 BOOL utf8translations; /* Buffer contains translations other than CRLF*/
668 char dbcsBuffer; /* Buffer for the lead byte of dbcs when converting from dbcs to unicode */
669 BOOL dbcsBufferUsed; /* Bool for the lead byte buffer is used or not */
674 typedef intptr_t ioinfo;
678 * Array of arrays of control structures for lowio files.
680 EXTERN_C _CRTIMP ioinfo* __pioinfo[];
683 * Definition of IOINFO_L2E, the log base 2 of the number of elements in each
684 * array of ioinfo structs.
689 * Definition of IOINFO_ARRAY_ELTS, the number of elements in ioinfo array
691 #define IOINFO_ARRAY_ELTS (1 << IOINFO_L2E)
694 * Access macros for getting at an ioinfo struct and its fields from a
697 #ifdef WIN32_DYN_IOINFO_SIZE
698 # define _pioinfo(i) ((intptr_t *) \
699 (((Size_t)__pioinfo[(i) >> IOINFO_L2E])/* * to head of array ioinfo [] */\
700 /* offset to the head of a particular ioinfo struct */ \
701 + (((i) & (IOINFO_ARRAY_ELTS - 1)) * w32_ioinfo_size)) \
703 /* first slice of ioinfo is always the OS handle */
704 # define _osfhnd(i) (*(_pioinfo(i)))
706 # define _pioinfo(i) (__pioinfo[(i) >> IOINFO_L2E] + ((i) & (IOINFO_ARRAY_ELTS - 1)))
707 # define _osfhnd(i) (_pioinfo(i)->osfhnd)
710 /* since we are not doing a dup2(), this works fine */
711 #define _set_osfhnd(fh, osfh) (void)(_osfhnd(fh) = (intptr_t)osfh)
713 #endif /* PERL_CORE */
715 #endif /* !defined(_MSC_VER) || _MSC_VER<1900 */
717 /* IO.xs and POSIX.xs define PERLIO_NOT_STDIO to 1 */
718 #if defined(PERL_EXT_IO) || defined(PERL_EXT_POSIX)
719 #undef PERLIO_NOT_STDIO
721 #define PERLIO_NOT_STDIO 0
723 #define EXEC_ARGV_CAST(x) ((const char *const *) x)
725 DllExport void *win32_signal_context(void);
726 #define PERL_GET_SIG_CONTEXT win32_signal_context()
728 #define Win_GetModuleHandle GetModuleHandle
729 #define Win_GetProcAddress GetProcAddress
730 #define Win_GetModuleFileName GetModuleFileName
731 #define Win_CreateSemaphore CreateSemaphore
733 #if defined(PERL_CORE) && !defined(O_ACCMODE)
734 # define O_ACCMODE (O_RDWR | O_WRONLY | O_RDONLY)
737 #endif /* _INC_WIN32_PERL5 */