2 * Helper functions for ntdll
4 * Copyright 2000 Juergen Schmied
5 * Copyright 2010 Marcus Meissner
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
26 #ifdef HAVE_SYS_UTSNAME_H
27 #include <sys/utsname.h>
31 #define WIN32_NO_STATUS
32 #include "wine/library.h"
33 #include "wine/debug.h"
34 #include "ntdll_misc.h"
39 WINE_DEFAULT_DEBUG_CHANNEL(ntdll
);
41 LPCSTR
debugstr_ObjectAttributes(const OBJECT_ATTRIBUTES
*oa
)
43 if (!oa
) return "<null>";
44 return wine_dbg_sprintf( "{name=%s, attr=0x%08x, hRoot=%p, sd=%p}\n",
45 debugstr_us(oa
->ObjectName
), oa
->Attributes
,
46 oa
->RootDirectory
, oa
->SecurityDescriptor
);
49 LPCSTR
debugstr_us( const UNICODE_STRING
*us
)
51 if (!us
) return "<null>";
52 return debugstr_wn(us
->Buffer
, us
->Length
/ sizeof(WCHAR
));
55 /*********************************************************************
56 * wine_get_version (NTDLL.@)
58 const char * CDECL
NTDLL_wine_get_version(void)
60 return wine_get_version();
63 /*********************************************************************
64 * wine_get_build_id (NTDLL.@)
66 const char * CDECL
NTDLL_wine_get_build_id(void)
68 return wine_get_build_id();
71 /*********************************************************************
72 * wine_get_host_version (NTDLL.@)
74 void CDECL
NTDLL_wine_get_host_version( const char **sysname
, const char **release
)
76 #ifdef HAVE_SYS_UTSNAME_H
77 static struct utsname buf
;
78 static BOOL init_done
;
85 if (sysname
) *sysname
= buf
.sysname
;
86 if (release
) *release
= buf
.release
;
88 if (sysname
) *sysname
= "";
89 if (release
) *release
= "";
93 /*********************************************************************
96 int CDECL
NTDLL_abs( int i
)
101 /*********************************************************************
104 LONG CDECL
NTDLL_labs( LONG i
)
109 /*********************************************************************
112 double CDECL
NTDLL_atan( double d
)
117 /*********************************************************************
120 double CDECL
NTDLL_ceil( double d
)
125 /*********************************************************************
128 double CDECL
NTDLL_cos( double d
)
133 /*********************************************************************
136 double CDECL
NTDLL_fabs( double d
)
141 /*********************************************************************
144 double CDECL
NTDLL_floor( double d
)
149 /*********************************************************************
152 double CDECL
NTDLL_log( double d
)
157 /*********************************************************************
160 double CDECL
NTDLL_pow( double x
, double y
)
165 /*********************************************************************
168 double CDECL
NTDLL_sin( double d
)
173 /*********************************************************************
176 double CDECL
NTDLL_sqrt( double d
)
181 /*********************************************************************
184 double CDECL
NTDLL_tan( double d
)
189 #if defined(__GNUC__) && defined(__i386__)
191 #define FPU_DOUBLE(var) double var; \
192 __asm__ __volatile__( "fstpl %0;fwait" : "=m" (var) : )
193 #define FPU_DOUBLES(var1,var2) double var1,var2; \
194 __asm__ __volatile__( "fstpl %0;fwait" : "=m" (var2) : ); \
195 __asm__ __volatile__( "fstpl %0;fwait" : "=m" (var1) : )
197 /*********************************************************************
200 double CDECL
NTDLL__CIcos(void)
206 /*********************************************************************
209 double CDECL
NTDLL__CIlog(void)
215 /*********************************************************************
218 double CDECL
NTDLL__CIpow(void)
221 return NTDLL_pow(x
,y
);
224 /*********************************************************************
227 double CDECL
NTDLL__CIsin(void)
233 /*********************************************************************
236 double CDECL
NTDLL__CIsqrt(void)
239 return NTDLL_sqrt(x
);
242 /*********************************************************************
245 LONGLONG CDECL
NTDLL__ftol(void)
251 #endif /* defined(__GNUC__) && defined(__i386__) */
254 NTDLL_mergesort( void *arr
, void *barr
, size_t elemsize
, int(__cdecl
*compar
)(const void *, const void *),
255 size_t left
, size_t right
)
259 m
=left
+(right
-left
)/2;
260 NTDLL_mergesort( arr
, barr
, elemsize
, compar
, left
, m
);
261 NTDLL_mergesort( arr
, barr
, elemsize
, compar
, m
+1, right
);
263 #define X(a,i) ((char*)a+elemsize*(i))
264 for (k
=left
, i
=left
, j
=m
+1; i
<=m
&& j
<=right
; k
++) {
265 if (compar(X(arr
, i
), X(arr
,j
)) <= 0) {
266 memcpy(X(barr
,k
), X(arr
, i
), elemsize
);
269 memcpy(X(barr
,k
), X(arr
, j
), elemsize
);
274 memcpy(X(barr
,k
), X(arr
,i
), (m
-i
+1)*elemsize
);
276 memcpy(X(barr
,k
), X(arr
,j
), (right
-j
+1)*elemsize
);
278 memcpy(X(arr
, left
), X(barr
, left
), (right
-left
+1)*elemsize
);
283 /*********************************************************************
286 void __cdecl
NTDLL_qsort( void *base
, size_t nmemb
, size_t size
,
287 int(__cdecl
*compar
)(const void *, const void *) )
290 if (nmemb
< 2 || size
== 0) return;
291 secondarr
= RtlAllocateHeap (GetProcessHeap(), 0, nmemb
*size
);
292 NTDLL_mergesort( base
, secondarr
, size
, compar
, 0, nmemb
-1 );
293 RtlFreeHeap (GetProcessHeap(),0, secondarr
);
296 /*********************************************************************
300 NTDLL_bsearch( const void *key
, const void *base
, size_t nmemb
,
301 size_t size
, int (__cdecl
*compar
)(const void *, const void *) )
304 ssize_t max
= nmemb
- 1;
308 ssize_t cursor
= min
+ (max
- min
) / 2;
309 int ret
= compar(key
,(const char *)base
+(cursor
*size
));
311 return (char*)base
+(cursor
*size
);
321 /*********************************************************************
324 void * __cdecl
_lfind( const void *key
, const void *base
, unsigned int *nmemb
,
325 size_t size
, int(__cdecl
*compar
)(const void *, const void *) )
327 size_t i
, n
= *nmemb
;
330 if (!compar(key
,(char*)base
+(size
*i
)))
331 return (char*)base
+(size
*i
);
335 /******************************************************************************
336 * WinSqmEndSession (NTDLL.@)
338 NTSTATUS WINAPI
WinSqmEndSession(HANDLE session
)
340 FIXME("(%p): stub\n", session
);
341 return STATUS_NOT_IMPLEMENTED
;
344 /*********************************************************************
345 * WinSqmIncrementDWORD (NTDLL.@)
347 void WINAPI
WinSqmIncrementDWORD(DWORD unk1
, DWORD unk2
, DWORD unk3
)
349 FIXME("(%d, %d, %d): stub\n", unk1
, unk2
, unk3
);
352 /*********************************************************************
353 * WinSqmIsOptedIn (NTDLL.@)
355 BOOL WINAPI
WinSqmIsOptedIn(void)
361 /******************************************************************************
362 * WinSqmStartSession (NTDLL.@)
364 HANDLE WINAPI
WinSqmStartSession(GUID
*sessionguid
, DWORD sessionid
, DWORD unknown1
)
366 FIXME("(%p, 0x%x, 0x%x): stub\n", sessionguid
, sessionid
, unknown1
);
367 return INVALID_HANDLE_VALUE
;
370 /***********************************************************************
371 * WinSqmSetDWORD (NTDLL.@)
373 void WINAPI
WinSqmSetDWORD(HANDLE session
, DWORD datapoint_id
, DWORD datapoint_value
)
375 FIXME("(%p, %d, %d): stub\n", session
, datapoint_id
, datapoint_value
);
378 /******************************************************************************
379 * EtwEventRegister (NTDLL.@)
381 ULONG WINAPI
EtwEventRegister( LPCGUID provider
, PENABLECALLBACK callback
, PVOID context
,
384 FIXME("(%s, %p, %p, %p) stub.\n", debugstr_guid(provider
), callback
, context
, handle
);
386 *handle
= 0xdeadbeef;
387 return ERROR_SUCCESS
;
390 /******************************************************************************
391 * EtwEventUnregister (NTDLL.@)
393 ULONG WINAPI
EtwEventUnregister( REGHANDLE handle
)
395 FIXME("(%s) stub.\n", wine_dbgstr_longlong(handle
));
396 return ERROR_SUCCESS
;
399 /*********************************************************************
400 * EtwEventSetInformation (NTDLL.@)
402 ULONG WINAPI
EtwEventSetInformation( REGHANDLE handle
, EVENT_INFO_CLASS
class, void *info
,
405 FIXME("(%s, %u, %p, %u) stub\n", wine_dbgstr_longlong(handle
), class, info
, length
);
406 return ERROR_SUCCESS
;
409 /******************************************************************************
410 * EtwRegisterTraceGuidsW (NTDLL.@)
412 * Register an event trace provider and the event trace classes that it uses
413 * to generate events.
416 * RequestAddress [I] ControlCallback function
417 * RequestContext [I] Optional provider-defined context
418 * ControlGuid [I] GUID of the registering provider
419 * GuidCount [I] Number of elements in the TraceGuidReg array
420 * TraceGuidReg [I/O] Array of TRACE_GUID_REGISTRATION structures
421 * MofImagePath [I] not supported, set to NULL
422 * MofResourceName [I] not supported, set to NULL
423 * RegistrationHandle [O] Provider's registration handle
426 * Success: ERROR_SUCCESS
427 * Failure: System error code
429 ULONG WINAPI
EtwRegisterTraceGuidsW( WMIDPREQUEST RequestAddress
,
430 void *RequestContext
, const GUID
*ControlGuid
, ULONG GuidCount
,
431 TRACE_GUID_REGISTRATION
*TraceGuidReg
, const WCHAR
*MofImagePath
,
432 const WCHAR
*MofResourceName
, TRACEHANDLE
*RegistrationHandle
)
434 FIXME("(%p, %p, %s, %u, %p, %s, %s, %p): stub\n", RequestAddress
, RequestContext
,
435 debugstr_guid(ControlGuid
), GuidCount
, TraceGuidReg
, debugstr_w(MofImagePath
),
436 debugstr_w(MofResourceName
), RegistrationHandle
);
441 for (i
= 0; i
< GuidCount
; i
++)
443 FIXME(" register trace class %s\n", debugstr_guid(TraceGuidReg
[i
].Guid
));
444 TraceGuidReg
[i
].RegHandle
= (HANDLE
)0xdeadbeef;
447 *RegistrationHandle
= (TRACEHANDLE
)0xdeadbeef;
448 return ERROR_SUCCESS
;
451 /******************************************************************************
452 * EtwRegisterTraceGuidsA (NTDLL.@)
454 ULONG WINAPI
EtwRegisterTraceGuidsA( WMIDPREQUEST RequestAddress
,
455 void *RequestContext
, const GUID
*ControlGuid
, ULONG GuidCount
,
456 TRACE_GUID_REGISTRATION
*TraceGuidReg
, const char *MofImagePath
,
457 const char *MofResourceName
, TRACEHANDLE
*RegistrationHandle
)
459 FIXME("(%p, %p, %s, %u, %p, %s, %s, %p): stub\n", RequestAddress
, RequestContext
,
460 debugstr_guid(ControlGuid
), GuidCount
, TraceGuidReg
, debugstr_a(MofImagePath
),
461 debugstr_a(MofResourceName
), RegistrationHandle
);
462 return ERROR_SUCCESS
;
465 /******************************************************************************
466 * EtwUnregisterTraceGuids (NTDLL.@)
468 ULONG WINAPI
EtwUnregisterTraceGuids( TRACEHANDLE RegistrationHandle
)
470 if (!RegistrationHandle
)
471 return ERROR_INVALID_PARAMETER
;
473 FIXME("%s: stub\n", wine_dbgstr_longlong(RegistrationHandle
));
474 return ERROR_SUCCESS
;
477 /******************************************************************************
478 * EtwEventEnabled (NTDLL.@)
480 BOOLEAN WINAPI
EtwEventEnabled( REGHANDLE handle
, const EVENT_DESCRIPTOR
*descriptor
)
482 FIXME("(%s, %p): stub\n", wine_dbgstr_longlong(handle
), descriptor
);
486 /******************************************************************************
487 * EtwEventWrite (NTDLL.@)
489 ULONG WINAPI
EtwEventWrite( REGHANDLE handle
, const EVENT_DESCRIPTOR
*descriptor
, ULONG count
,
490 EVENT_DATA_DESCRIPTOR
*data
)
492 FIXME("(%s, %p, %u, %p): stub\n", wine_dbgstr_longlong(handle
), descriptor
, count
, data
);
493 return ERROR_SUCCESS
;
496 /***********************************************************************
497 * DbgUiRemoteBreakin (NTDLL.@)
499 void WINAPI
DbgUiRemoteBreakin( void *arg
)
504 NTSTATUS WINAPI
NtCreateLowBoxToken(HANDLE
*token_handle
, HANDLE existing_token_handle
, ACCESS_MASK desired_access
,
505 OBJECT_ATTRIBUTES
*object_attributes
, SID
*package_sid
, ULONG capability_count
,
506 SID_AND_ATTRIBUTES
*capabilities
, ULONG handle_count
, HANDLE
*handle
)
508 FIXME("(%p, %p, %x, %p, %p, %u, %p, %u, %p): stub\n", token_handle
, existing_token_handle
, desired_access
,
509 object_attributes
, package_sid
, capability_count
, capabilities
, handle_count
, handle
);
511 /* We need to return a NULL handle since later it will be passed to CloseHandle and that must not fail */
512 *token_handle
= NULL
;
513 return STATUS_SUCCESS
;
516 /*********************************************************************
517 * ApiSetQueryApiSetPresence (NTDLL.@)
519 BOOL WINAPI
ApiSetQueryApiSetPresence(const UNICODE_STRING
*namespace, BOOLEAN
*present
)
521 FIXME("(%s, %p) stub!\n", debugstr_us(namespace), present
);