ntdll: Fetch the debug channels from the PEB memory block on the PE side.

Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Alexandre Julliard 2021-05-24 21:35:12 +02:00
parent d389da0953
commit 1e5eee0fc3
3 changed files with 30 additions and 4 deletions

View File

@ -37,6 +37,16 @@ WINE_DECLARE_DEBUG_CHANNEL(thread);
struct _KUSER_SHARED_DATA *user_shared_data = (void *)0x7ffe0000; struct _KUSER_SHARED_DATA *user_shared_data = (void *)0x7ffe0000;
static int nb_debug_options;
static struct __wine_debug_channel *debug_options;
static void init_options(void)
{
unsigned int offset = page_size * (sizeof(void *) / 4);
debug_options = (struct __wine_debug_channel *)((char *)NtCurrentTeb()->Peb + offset);
while (debug_options[nb_debug_options].name[0]) nb_debug_options++;
}
/*********************************************************************** /***********************************************************************
* __wine_dbg_get_channel_flags (NTDLL.@) * __wine_dbg_get_channel_flags (NTDLL.@)
@ -45,7 +55,25 @@ struct _KUSER_SHARED_DATA *user_shared_data = (void *)0x7ffe0000;
*/ */
unsigned char __cdecl __wine_dbg_get_channel_flags( struct __wine_debug_channel *channel ) unsigned char __cdecl __wine_dbg_get_channel_flags( struct __wine_debug_channel *channel )
{ {
return unix_funcs->dbg_get_channel_flags( channel ); int min, max, pos, res;
unsigned char default_flags;
if (!debug_options) init_options();
min = 0;
max = nb_debug_options - 1;
while (min <= max)
{
pos = (min + max) / 2;
res = strcmp( channel->name, debug_options[pos].name );
if (!res) return debug_options[pos].flags;
if (res < 0) max = pos - 1;
else min = pos + 1;
}
/* no option for this channel */
default_flags = debug_options[nb_debug_options].flags;
if (channel->flags & (1 << __WINE_DBCL_INIT)) channel->flags = default_flags;
return default_flags;
} }
/*********************************************************************** /***********************************************************************

View File

@ -1840,7 +1840,6 @@ static struct unix_funcs unix_funcs =
init_builtin_dll, init_builtin_dll,
init_unix_lib, init_unix_lib,
unwind_builtin_dll, unwind_builtin_dll,
__wine_dbg_get_channel_flags,
__wine_dbg_strdup, __wine_dbg_strdup,
__wine_dbg_output, __wine_dbg_output,
__wine_dbg_header, __wine_dbg_header,

View File

@ -26,7 +26,7 @@
struct _DISPATCHER_CONTEXT; struct _DISPATCHER_CONTEXT;
/* increment this when you change the function table */ /* increment this when you change the function table */
#define NTDLL_UNIXLIB_VERSION 120 #define NTDLL_UNIXLIB_VERSION 121
struct unix_funcs struct unix_funcs
{ {
@ -80,7 +80,6 @@ struct unix_funcs
CONTEXT *context ); CONTEXT *context );
/* debugging functions */ /* debugging functions */
unsigned char (CDECL *dbg_get_channel_flags)( struct __wine_debug_channel *channel );
const char * (CDECL *dbg_strdup)( const char *str ); const char * (CDECL *dbg_strdup)( const char *str );
int (CDECL *dbg_output)( const char *str ); int (CDECL *dbg_output)( const char *str );
int (CDECL *dbg_header)( enum __wine_debug_class cls, struct __wine_debug_channel *channel, int (CDECL *dbg_header)( enum __wine_debug_class cls, struct __wine_debug_channel *channel,