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
1774db38
Commit
1774db38
authored
Feb 27, 2023
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winedbg: Use the Zydis library for disassembly.
parent
7bc94bc8
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
92 additions
and
20 deletions
+92
-20
Makefile.in
programs/winedbg/Makefile.in
+2
-3
be_i386.c
programs/winedbg/be_i386.c
+1
-4
be_x86_64.c
programs/winedbg/be_x86_64.c
+1
-3
db_disasm.c
programs/winedbg/db_disasm.c
+0
-0
db_disasm64.c
programs/winedbg/db_disasm64.c
+0
-0
debugger.h
programs/winedbg/debugger.h
+1
-0
memory.c
programs/winedbg/memory.c
+87
-10
No files found.
programs/winedbg/Makefile.in
View file @
1774db38
MODULE
=
winedbg.exe
IMPORTS
=
dbghelp advapi32
IMPORTS
=
$(ZYDIS_PE_LIBS)
dbghelp advapi32
EXTRAINCL
=
$(ZYDIS_PE_CFLAGS)
DELAYIMPORTS
=
comdlg32 shell32 comctl32 user32 gdi32 ws2_32
EXTRADLLFLAGS
=
-mconsole
...
...
@@ -11,8 +12,6 @@ C_SRCS = \
be_x86_64.c
\
break.c
\
crashdlg.c
\
db_disasm.c
\
db_disasm64.c
\
display.c
\
expr.c
\
gdbproxy.c
\
...
...
programs/winedbg/be_i386.c
View file @
1774db38
...
...
@@ -25,9 +25,6 @@
WINE_DEFAULT_DEBUG_CHANNEL
(
winedbg
);
/* db_disasm.c */
extern
void
be_i386_disasm_one_insn
(
ADDRESS64
*
addr
,
int
display
);
#define STEP_FLAG 0x00000100
/* single step flag */
#define V86_FLAG 0x00020000
...
...
@@ -852,7 +849,7 @@ struct backend_cpu be_i386 =
be_i386_is_break_insn
,
be_i386_is_func_call
,
be_i386_is_jump
,
be_i386_disasm_one
_insn
,
memory_disasm_one_x86
_insn
,
be_i386_insert_Xpoint
,
be_i386_remove_Xpoint
,
be_i386_is_watchpoint_set
,
...
...
programs/winedbg/be_x86_64.c
View file @
1774db38
...
...
@@ -539,8 +539,6 @@ static BOOL be_x86_64_is_jump(const void* insn, ADDRESS64* jumpee)
return
FALSE
;
}
extern
void
be_x86_64_disasm_one_insn
(
ADDRESS64
*
addr
,
int
display
);
#define DR7_CONTROL_SHIFT 16
#define DR7_CONTROL_SIZE 4
...
...
@@ -790,7 +788,7 @@ struct backend_cpu be_x86_64 =
be_x86_64_is_break_insn
,
be_x86_64_is_func_call
,
be_x86_64_is_jump
,
be_x86_64_disasm_one
_insn
,
memory_disasm_one_x86
_insn
,
be_x86_64_insert_Xpoint
,
be_x86_64_remove_Xpoint
,
be_x86_64_is_watchpoint_set
,
...
...
programs/winedbg/db_disasm.c
deleted
100644 → 0
View file @
7bc94bc8
This diff is collapsed.
Click to expand it.
programs/winedbg/db_disasm64.c
deleted
100644 → 0
View file @
7bc94bc8
This diff is collapsed.
Click to expand it.
programs/winedbg/debugger.h
View file @
1774db38
...
...
@@ -416,6 +416,7 @@ extern BOOL memory_get_string(struct dbg_process* pcs, void* addr, B
extern
BOOL
memory_get_string_indirect
(
struct
dbg_process
*
pcs
,
void
*
addr
,
BOOL
unicode
,
WCHAR
*
buffer
,
int
size
);
extern
BOOL
memory_get_register
(
DWORD
regno
,
struct
dbg_lvalue
*
value
,
char
*
buffer
,
int
len
);
extern
void
memory_disassemble
(
const
struct
dbg_lvalue
*
,
const
struct
dbg_lvalue
*
,
int
instruction_count
);
extern
void
memory_disasm_one_x86_insn
(
ADDRESS64
*
addr
,
int
display
);
extern
BOOL
memory_disasm_one_insn
(
ADDRESS64
*
addr
);
#define MAX_OFFSET_TO_STR_LEN 19
extern
char
*
memory_offset_to_string
(
char
*
str
,
DWORD64
offset
,
unsigned
mode
);
...
...
programs/winedbg/memory.c
View file @
1774db38
...
...
@@ -23,6 +23,7 @@
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <Zydis/Zydis.h>
#include "debugger.h"
#include "wine/debug.h"
...
...
@@ -696,12 +697,7 @@ void print_bare_address(const ADDRESS64* addr)
}
}
/***********************************************************************
* print_address
*
* Print an 16- or 32-bit address, with the nearest symbol if any.
*/
void
print_address
(
const
ADDRESS64
*
addr
,
BOOLEAN
with_line
)
static
void
print_address_symbol
(
const
ADDRESS64
*
addr
,
BOOL
with_line
,
const
char
*
sep
)
{
char
buffer
[
sizeof
(
SYMBOL_INFO
)
+
256
];
SYMBOL_INFO
*
si
=
(
SYMBOL_INFO
*
)
buffer
;
...
...
@@ -710,21 +706,19 @@ void print_address(const ADDRESS64* addr, BOOLEAN with_line)
DWORD
disp
;
IMAGEHLP_MODULE
im
;
print_bare_address
(
addr
);
si
->
SizeOfStruct
=
sizeof
(
*
si
);
si
->
MaxNameLen
=
256
;
im
.
SizeOfStruct
=
0
;
if
(
SymFromAddr
(
dbg_curr_process
->
handle
,
lin
,
&
disp64
,
si
)
&&
disp64
<
si
->
Size
)
{
dbg_printf
(
"
%s"
,
si
->
Name
);
dbg_printf
(
"
%s %s"
,
sep
,
si
->
Name
);
if
(
disp64
)
dbg_printf
(
"+0x%I64x"
,
disp64
);
}
else
{
im
.
SizeOfStruct
=
sizeof
(
im
);
if
(
!
SymGetModuleInfo
(
dbg_curr_process
->
handle
,
lin
,
&
im
))
return
;
dbg_printf
(
"
%s"
,
im
.
ModuleName
);
dbg_printf
(
"
%s %s"
,
sep
,
im
.
ModuleName
);
if
(
lin
>
im
.
BaseOfImage
)
dbg_printf
(
"+0x%Ix"
,
lin
-
(
DWORD_PTR
)
im
.
BaseOfImage
);
}
...
...
@@ -744,6 +738,89 @@ void print_address(const ADDRESS64* addr, BOOLEAN with_line)
}
}
/***********************************************************************
* print_address
*
* Print an 16- or 32-bit address, with the nearest symbol if any.
*/
void
print_address
(
const
ADDRESS64
*
addr
,
BOOLEAN
with_line
)
{
print_bare_address
(
addr
);
print_address_symbol
(
addr
,
with_line
,
""
);
}
void
memory_disasm_one_x86_insn
(
ADDRESS64
*
addr
,
int
display
)
{
ZydisDisassembledInstruction
instr
=
{
.
runtime_address
=
addr
->
Offset
};
ZydisDecoder
decoder
;
ZydisDecoderContext
ctx
;
unsigned
char
buffer
[
16
];
SIZE_T
len
;
int
i
;
if
(
!
dbg_curr_process
->
process_io
->
read
(
dbg_curr_process
->
handle
,
memory_to_linear_addr
(
addr
),
buffer
,
sizeof
(
buffer
),
&
len
))
return
;
switch
(
addr
->
Mode
)
{
case
AddrModeReal
:
case
AddrMode1616
:
ZydisDecoderInit
(
&
decoder
,
ZYDIS_MACHINE_MODE_LEGACY_16
,
ZYDIS_STACK_WIDTH_16
);
break
;
default:
if
(
ADDRSIZE
==
4
)
ZydisDecoderInit
(
&
decoder
,
ZYDIS_MACHINE_MODE_LEGACY_32
,
ZYDIS_STACK_WIDTH_32
);
else
ZydisDecoderInit
(
&
decoder
,
ZYDIS_MACHINE_MODE_LONG_64
,
ZYDIS_STACK_WIDTH_64
);
break
;
}
ZydisDecoderDecodeInstruction
(
&
decoder
,
&
ctx
,
buffer
,
len
,
&
instr
.
info
);
ZydisDecoderDecodeOperands
(
&
decoder
,
&
ctx
,
&
instr
.
info
,
instr
.
operands
,
instr
.
info
.
operand_count
);
if
(
display
)
{
ZydisFormatter
formatter
;
ZydisFormatterInit
(
&
formatter
,
ZYDIS_FORMATTER_STYLE_ATT
);
ZydisFormatterSetProperty
(
&
formatter
,
ZYDIS_FORMATTER_PROP_HEX_UPPERCASE
,
0
);
ZydisFormatterFormatInstruction
(
&
formatter
,
&
instr
.
info
,
instr
.
operands
,
instr
.
info
.
operand_count_visible
,
instr
.
text
,
sizeof
(
instr
.
text
),
instr
.
runtime_address
,
NULL
);
dbg_printf
(
"%s"
,
instr
.
text
);
for
(
i
=
0
;
i
<
instr
.
info
.
operand_count_visible
;
i
++
)
{
ADDRESS64
a
=
{
.
Mode
=
AddrModeFlat
};
ZyanU64
addr
;
if
(
!
ZYAN_SUCCESS
(
ZydisCalcAbsoluteAddress
(
&
instr
.
info
,
&
instr
.
operands
[
i
],
instr
.
runtime_address
,
&
addr
)))
continue
;
if
(
instr
.
info
.
meta
.
branch_type
==
ZYDIS_BRANCH_TYPE_NEAR
&&
instr
.
operands
[
i
].
type
==
ZYDIS_OPERAND_TYPE_MEMORY
&&
instr
.
operands
[
i
].
mem
.
disp
.
has_displacement
&&
instr
.
operands
[
i
].
mem
.
index
==
ZYDIS_REGISTER_NONE
&&
(
instr
.
operands
[
i
].
mem
.
base
==
ZYDIS_REGISTER_NONE
||
instr
.
operands
[
i
].
mem
.
base
==
ZYDIS_REGISTER_EIP
||
instr
.
operands
[
i
].
mem
.
base
==
ZYDIS_REGISTER_RIP
))
{
unsigned
char
dest
[
8
];
if
(
dbg_read_memory
(
(
void
*
)(
ULONG_PTR
)
addr
,
dest
,
ADDRSIZE
))
{
dbg_printf
(
" -> "
);
a
.
Offset
=
ADDRSIZE
==
4
?
*
(
DWORD
*
)
dest
:
*
(
DWORD64
*
)
dest
;
print_address
(
&
a
,
TRUE
);
break
;
}
}
a
.
Offset
=
addr
;
print_address_symbol
(
&
a
,
TRUE
,
instr
.
info
.
operand_count_visible
>
1
?
" ;"
:
""
);
break
;
}
}
addr
->
Offset
+=
instr
.
info
.
length
;
}
BOOL
memory_disasm_one_insn
(
ADDRESS64
*
addr
)
{
char
ch
;
...
...
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