2 * Kernel32 undocumented and private functions definition
4 * Copyright 2003 Eric Pouech
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 #ifndef __WINE_KERNEL_PRIVATE_H
22 #define __WINE_KERNEL_PRIVATE_H
24 #include "wine/server.h"
28 struct kernel_thread_data
30 WORD stack_sel; /* 16-bit stack selector */
31 WORD htask16; /* Win16 task handle */
32 DWORD sys_count[4]; /* syslevel mutex entry counters */
33 struct tagSYSLEVEL *sys_mutex[4]; /* syslevel mutex pointers */
34 void *pad[45]; /* change this if you add fields! */
37 static inline struct kernel_thread_data *kernel_get_thread_data(void)
39 return (struct kernel_thread_data *)NtCurrentTeb()->SystemReserved1;
42 HANDLE WINAPI OpenConsoleW(LPCWSTR, DWORD, BOOL, DWORD);
43 BOOL WINAPI VerifyConsoleIoHandle(HANDLE);
44 HANDLE WINAPI DuplicateConsoleHandle(HANDLE, DWORD, BOOL, DWORD);
45 BOOL WINAPI CloseConsoleHandle(HANDLE handle);
46 HANDLE WINAPI GetConsoleInputWaitHandle(void);
48 static inline BOOL is_console_handle(HANDLE h)
50 return h != INVALID_HANDLE_VALUE && ((UINT_PTR)h & 3) == 3;
53 /* map a real wineserver handle onto a kernel32 console handle */
54 static inline HANDLE console_handle_map(HANDLE h)
56 return h != INVALID_HANDLE_VALUE ? (HANDLE)((UINT_PTR)h ^ 3) : INVALID_HANDLE_VALUE;
59 /* map a kernel32 console handle onto a real wineserver handle */
60 static inline obj_handle_t console_handle_unmap(HANDLE h)
62 return wine_server_obj_handle( h != INVALID_HANDLE_VALUE ? (HANDLE)((UINT_PTR)h ^ 3) : INVALID_HANDLE_VALUE );
65 extern HMODULE kernel32_handle;
67 extern const WCHAR *DIR_Windows;
68 extern const WCHAR *DIR_System;
69 extern const WCHAR *DIR_SysWow64;
71 extern VOID SYSLEVEL_CheckNotLevel( INT level );
73 extern void FILE_SetDosError(void);
74 extern WCHAR *FILE_name_AtoW( LPCSTR name, BOOL alloc );
75 extern DWORD FILE_name_WtoA( LPCWSTR src, INT srclen, LPSTR dest, INT destlen );
77 /* return values for MODULE_GetBinaryType */
89 #define BINARY_FLAG_DLL 0x01
90 #define BINARY_FLAG_64BIT 0x02
94 enum binary_type type;
101 extern WCHAR *MODULE_get_dll_load_path( LPCWSTR module );
102 extern void MODULE_get_binary_info( HANDLE hfile, struct binary_info *info );
104 extern BOOL NLS_IsUnicodeOnlyLcid(LCID);
107 typedef BOOL (WINAPI *DeviceIoProc)(DWORD, LPVOID, DWORD, LPVOID, DWORD, LPDWORD, LPOVERLAPPED);
108 extern DeviceIoProc VXD_get_proc( HANDLE handle );
109 extern HANDLE VXD_Open( LPCWSTR filename, DWORD access, LPSECURITY_ATTRIBUTES sa );
112 extern void ENV_CopyStartupInformation(void);
115 extern void COMPUTERNAME_Init(void);
118 extern void LOCALE_Init(void);
119 extern void LOCALE_InitRegistry(void);
122 extern void convert_old_config(void);
124 /* returns directory handle for named objects */
125 extern HANDLE get_BaseNamedObjects_handle(void);