Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
224b33c2
Commit
224b33c2
authored
Jan 16, 2023
by
Eric Pouech
Committed by
Alexandre Julliard
Jan 26, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winedbg: Track loaded modules.
Co-authored-by:
Evan Tang
<
etang@codeweavers.com
>
parent
0f6dcbbb
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
72 additions
and
16 deletions
+72
-16
debugger.h
programs/winedbg/debugger.h
+11
-1
tgt_active.c
programs/winedbg/tgt_active.c
+1
-2
types.c
programs/winedbg/types.c
+6
-6
winedbg.c
programs/winedbg/winedbg.c
+54
-7
No files found.
programs/winedbg/debugger.h
View file @
224b33c2
...
@@ -246,6 +246,12 @@ struct dbg_thread
...
@@ -246,6 +246,12 @@ struct dbg_thread
BOOL
suspended
;
BOOL
suspended
;
};
};
struct
dbg_module
{
struct
list
entry
;
DWORD_PTR
base
;
};
struct
dbg_delayed_bp
struct
dbg_delayed_bp
{
{
BOOL
is_symbol
;
BOOL
is_symbol
;
...
@@ -271,6 +277,7 @@ struct dbg_process
...
@@ -271,6 +277,7 @@ struct dbg_process
void
*
pio_data
;
void
*
pio_data
;
const
WCHAR
*
imageName
;
const
WCHAR
*
imageName
;
struct
list
threads
;
struct
list
threads
;
struct
list
modules
;
struct
backend_cpu
*
be_cpu
;
struct
backend_cpu
*
be_cpu
;
HANDLE
event_on_first_exception
;
HANDLE
event_on_first_exception
;
BOOL
active_debuggee
;
BOOL
active_debuggee
;
...
@@ -503,7 +510,7 @@ extern BOOL types_is_integral_type(const struct dbg_lvalue*);
...
@@ -503,7 +510,7 @@ extern BOOL types_is_integral_type(const struct dbg_lvalue*);
extern
BOOL
types_is_float_type
(
const
struct
dbg_lvalue
*
);
extern
BOOL
types_is_float_type
(
const
struct
dbg_lvalue
*
);
extern
BOOL
types_is_pointer_type
(
const
struct
dbg_lvalue
*
);
extern
BOOL
types_is_pointer_type
(
const
struct
dbg_lvalue
*
);
extern
BOOL
types_find_basic
(
const
WCHAR
*
,
const
char
*
,
struct
dbg_type
*
type
);
extern
BOOL
types_find_basic
(
const
WCHAR
*
,
const
char
*
,
struct
dbg_type
*
type
);
extern
BOOL
types_unload_module
(
DWORD_PTR
linear
);
extern
BOOL
types_unload_module
(
struct
dbg_process
*
pcs
,
DWORD_PTR
linear
);
/* winedbg.c */
/* winedbg.c */
#ifdef __GNUC__
#ifdef __GNUC__
...
@@ -524,6 +531,9 @@ extern struct dbg_thread* dbg_get_thread(struct dbg_process* p, DWORD tid);
...
@@ -524,6 +531,9 @@ extern struct dbg_thread* dbg_get_thread(struct dbg_process* p, DWORD tid);
extern
void
dbg_del_thread
(
struct
dbg_thread
*
t
);
extern
void
dbg_del_thread
(
struct
dbg_thread
*
t
);
extern
BOOL
dbg_init
(
HANDLE
hProc
,
const
WCHAR
*
in
,
BOOL
invade
);
extern
BOOL
dbg_init
(
HANDLE
hProc
,
const
WCHAR
*
in
,
BOOL
invade
);
extern
BOOL
dbg_load_module
(
HANDLE
hProc
,
HANDLE
hFile
,
const
WCHAR
*
name
,
DWORD_PTR
base
,
DWORD
size
);
extern
BOOL
dbg_load_module
(
HANDLE
hProc
,
HANDLE
hFile
,
const
WCHAR
*
name
,
DWORD_PTR
base
,
DWORD
size
);
extern
struct
dbg_module
*
dbg_get_module
(
struct
dbg_process
*
pcs
,
DWORD_PTR
base
);
extern
void
dbg_del_module
(
struct
dbg_module
*
mod
);
extern
BOOL
dbg_unload_module
(
struct
dbg_process
*
pcs
,
DWORD_PTR
base
);
extern
void
dbg_set_option
(
const
char
*
,
const
char
*
);
extern
void
dbg_set_option
(
const
char
*
,
const
char
*
);
extern
void
dbg_start_interactive
(
const
char
*
,
HANDLE
hFile
);
extern
void
dbg_start_interactive
(
const
char
*
,
HANDLE
hFile
);
extern
void
dbg_init_console
(
void
);
extern
void
dbg_init_console
(
void
);
...
...
programs/winedbg/tgt_active.c
View file @
224b33c2
...
@@ -501,8 +501,7 @@ static unsigned dbg_handle_debug_event(DEBUG_EVENT* de)
...
@@ -501,8 +501,7 @@ static unsigned dbg_handle_debug_event(DEBUG_EVENT* de)
de
->
dwProcessId
,
de
->
dwThreadId
,
de
->
dwProcessId
,
de
->
dwThreadId
,
de
->
u
.
UnloadDll
.
lpBaseOfDll
);
de
->
u
.
UnloadDll
.
lpBaseOfDll
);
break_delete_xpoints_from_module
((
DWORD_PTR
)
de
->
u
.
UnloadDll
.
lpBaseOfDll
);
break_delete_xpoints_from_module
((
DWORD_PTR
)
de
->
u
.
UnloadDll
.
lpBaseOfDll
);
types_unload_module
((
DWORD_PTR
)
de
->
u
.
UnloadDll
.
lpBaseOfDll
);
dbg_unload_module
(
dbg_curr_process
,
(
DWORD_PTR
)
de
->
u
.
UnloadDll
.
lpBaseOfDll
);
SymUnloadModule64
(
dbg_curr_process
->
handle
,
(
DWORD_PTR
)
de
->
u
.
UnloadDll
.
lpBaseOfDll
);
break
;
break
;
case
OUTPUT_DEBUG_STRING_EVENT
:
case
OUTPUT_DEBUG_STRING_EVENT
:
...
...
programs/winedbg/types.c
View file @
224b33c2
...
@@ -1205,16 +1205,16 @@ BOOL types_get_info(const struct dbg_type* type, IMAGEHLP_SYMBOL_TYPE_INFO ti, v
...
@@ -1205,16 +1205,16 @@ BOOL types_get_info(const struct dbg_type* type, IMAGEHLP_SYMBOL_TYPE_INFO ti, v
return
TRUE
;
return
TRUE
;
}
}
BOOL
types_unload_module
(
DWORD_PTR
linear
)
BOOL
types_unload_module
(
struct
dbg_process
*
pcs
,
DWORD_PTR
linear
)
{
{
unsigned
i
;
unsigned
i
;
if
(
!
dbg_curr_proces
s
)
return
FALSE
;
if
(
!
pc
s
)
return
FALSE
;
for
(
i
=
0
;
i
<
dbg_curr_proces
s
->
num_synthetized_types
;
i
++
)
for
(
i
=
0
;
i
<
pc
s
->
num_synthetized_types
;
i
++
)
{
{
if
(
dbg_curr_proces
s
->
synthetized_types
[
i
].
module
==
linear
)
if
(
pc
s
->
synthetized_types
[
i
].
module
==
linear
)
{
{
dbg_curr_proces
s
->
synthetized_types
[
i
].
module
=
0
;
pc
s
->
synthetized_types
[
i
].
module
=
0
;
dbg_curr_proces
s
->
synthetized_types
[
i
].
id
=
dbg_itype_none
;
pc
s
->
synthetized_types
[
i
].
id
=
dbg_itype_none
;
}
}
}
}
return
TRUE
;
return
TRUE
;
...
...
programs/winedbg/winedbg.c
View file @
224b33c2
...
@@ -273,6 +273,7 @@ struct dbg_process* dbg_add_process(const struct be_process_io* pio, DWORD pid,
...
@@ -273,6 +273,7 @@ struct dbg_process* dbg_add_process(const struct be_process_io* pio, DWORD pid,
p
->
pio_data
=
NULL
;
p
->
pio_data
=
NULL
;
p
->
imageName
=
NULL
;
p
->
imageName
=
NULL
;
list_init
(
&
p
->
threads
);
list_init
(
&
p
->
threads
);
list_init
(
&
p
->
modules
);
p
->
event_on_first_exception
=
NULL
;
p
->
event_on_first_exception
=
NULL
;
p
->
active_debuggee
=
FALSE
;
p
->
active_debuggee
=
FALSE
;
p
->
next_bp
=
1
;
/* breakpoint 0 is reserved for step-over */
p
->
next_bp
=
1
;
/* breakpoint 0 is reserved for step-over */
...
@@ -316,11 +317,16 @@ void dbg_del_process(struct dbg_process* p)
...
@@ -316,11 +317,16 @@ void dbg_del_process(struct dbg_process* p)
{
{
struct
dbg_thread
*
t
;
struct
dbg_thread
*
t
;
struct
dbg_thread
*
t2
;
struct
dbg_thread
*
t2
;
struct
dbg_module
*
mod
;
struct
dbg_module
*
mod2
;
int
i
;
int
i
;
LIST_FOR_EACH_ENTRY_SAFE
(
t
,
t2
,
&
p
->
threads
,
struct
dbg_thread
,
entry
)
LIST_FOR_EACH_ENTRY_SAFE
(
t
,
t2
,
&
p
->
threads
,
struct
dbg_thread
,
entry
)
dbg_del_thread
(
t
);
dbg_del_thread
(
t
);
LIST_FOR_EACH_ENTRY_SAFE
(
mod
,
mod2
,
&
p
->
modules
,
struct
dbg_module
,
entry
)
dbg_del_module
(
mod
);
for
(
i
=
0
;
i
<
p
->
num_delayed_bp
;
i
++
)
for
(
i
=
0
;
i
<
p
->
num_delayed_bp
;
i
++
)
if
(
p
->
delayed_bp
[
i
].
is_symbol
)
if
(
p
->
delayed_bp
[
i
].
is_symbol
)
free
(
p
->
delayed_bp
[
i
].
u
.
symbol
.
name
);
free
(
p
->
delayed_bp
[
i
].
u
.
symbol
.
name
);
...
@@ -377,15 +383,56 @@ BOOL dbg_init(HANDLE hProc, const WCHAR* in, BOOL invade)
...
@@ -377,15 +383,56 @@ BOOL dbg_init(HANDLE hProc, const WCHAR* in, BOOL invade)
BOOL
dbg_load_module
(
HANDLE
hProc
,
HANDLE
hFile
,
const
WCHAR
*
name
,
DWORD_PTR
base
,
DWORD
size
)
BOOL
dbg_load_module
(
HANDLE
hProc
,
HANDLE
hFile
,
const
WCHAR
*
name
,
DWORD_PTR
base
,
DWORD
size
)
{
{
BOOL
ret
=
SymLoadModuleExW
(
hProc
,
hFile
,
name
,
NULL
,
base
,
size
,
NULL
,
0
);
struct
dbg_process
*
pcs
=
dbg_get_process_h
(
hProc
);
if
(
ret
)
struct
dbg_module
*
mod
;
IMAGEHLP_MODULEW64
info
;
if
(
!
pcs
)
return
FALSE
;
mod
=
malloc
(
sizeof
(
struct
dbg_module
));
if
(
!
mod
)
return
FALSE
;
if
(
!
SymLoadModuleExW
(
hProc
,
hFile
,
name
,
NULL
,
base
,
size
,
NULL
,
0
))
{
{
IMAGEHLP_MODULEW64
ihm
;
free
(
mod
);
ihm
.
SizeOfStruct
=
sizeof
(
ihm
);
return
FALSE
;
if
(
SymGetModuleInfoW64
(
hProc
,
base
,
&
ihm
)
&&
(
ihm
.
PdbUnmatched
||
ihm
.
DbgUnmatched
))
dbg_printf
(
"Loaded unmatched debug information for %s
\n
"
,
wine_dbgstr_w
(
name
));
}
}
return
ret
;
mod
->
base
=
base
;
list_add_head
(
&
pcs
->
modules
,
&
mod
->
entry
);
info
.
SizeOfStruct
=
sizeof
(
info
);
if
(
SymGetModuleInfoW64
(
hProc
,
base
,
&
info
))
if
(
info
.
PdbUnmatched
||
info
.
DbgUnmatched
)
dbg_printf
(
"Loaded unmatched debug information for %s
\n
"
,
wine_dbgstr_w
(
name
));
return
TRUE
;
}
void
dbg_del_module
(
struct
dbg_module
*
mod
)
{
list_remove
(
&
mod
->
entry
);
free
(
mod
);
}
struct
dbg_module
*
dbg_get_module
(
struct
dbg_process
*
pcs
,
DWORD_PTR
base
)
{
struct
dbg_module
*
mod
;
if
(
!
pcs
)
return
NULL
;
LIST_FOR_EACH_ENTRY
(
mod
,
&
pcs
->
modules
,
struct
dbg_module
,
entry
)
if
(
mod
->
base
==
base
)
return
mod
;
return
NULL
;
}
BOOL
dbg_unload_module
(
struct
dbg_process
*
pcs
,
DWORD_PTR
base
)
{
struct
dbg_module
*
mod
=
dbg_get_module
(
pcs
,
base
);
types_unload_module
(
pcs
,
base
);
SymUnloadModule64
(
pcs
->
handle
,
base
);
dbg_del_module
(
mod
);
return
!!
mod
;
}
}
struct
dbg_thread
*
dbg_get_thread
(
struct
dbg_process
*
p
,
DWORD
tid
)
struct
dbg_thread
*
dbg_get_thread
(
struct
dbg_process
*
p
,
DWORD
tid
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment