Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
1577fb6c
Commit
1577fb6c
authored
Dec 04, 2013
by
Ken Thomases
Committed by
Alexandre Julliard
Dec 05, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dbghelp: For Mach-O, get the address of the process's image info from its PEB.
parent
22cf68e1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
44 additions
and
13 deletions
+44
-13
macho_module.c
dlls/dbghelp/macho_module.c
+44
-13
No files found.
dlls/dbghelp/macho_module.c
View file @
1577fb6c
...
@@ -24,6 +24,8 @@
...
@@ -24,6 +24,8 @@
#include "config.h"
#include "config.h"
#include "wine/port.h"
#include "wine/port.h"
#include "ntstatus.h"
#define WIN32_NO_STATUS
#include "dbghelp_private.h"
#include "dbghelp_private.h"
#ifdef HAVE_MACH_O_LOADER_H
#ifdef HAVE_MACH_O_LOADER_H
...
@@ -964,23 +966,52 @@ static BOOL macho_load_file(struct process* pcs, const WCHAR* filename,
...
@@ -964,23 +966,52 @@ static BOOL macho_load_file(struct process* pcs, const WCHAR* filename,
*/
*/
if
(
macho_info
->
flags
&
MACHO_INFO_DEBUG_HEADER
)
if
(
macho_info
->
flags
&
MACHO_INFO_DEBUG_HEADER
)
{
{
static
void
*
dyld_all_image_infos_addr
;
PROCESS_BASIC_INFORMATION
pbi
;
NTSTATUS
status
;
/* This symbol should be in the same place in all processes. */
ret
=
FALSE
;
if
(
!
dyld_all_image_infos_addr
)
/* Get address of PEB */
status
=
NtQueryInformationProcess
(
pcs
->
handle
,
ProcessBasicInformation
,
&
pbi
,
sizeof
(
pbi
),
NULL
);
if
(
status
==
STATUS_SUCCESS
)
{
{
struct
nlist
nl
[
2
];
ULONG
dyld_image_info
;
memset
(
nl
,
0
,
sizeof
(
nl
));
nl
[
0
].
n_un
.
n_name
=
(
char
*
)
"_dyld_all_image_infos"
;
/* Read dyld image info address from PEB */
if
(
!
nlist
(
"/usr/lib/dyld"
,
nl
))
if
(
ReadProcessMemory
(
pcs
->
handle
,
&
pbi
.
PebBaseAddress
->
Reserved
,
dyld_all_image_infos_addr
=
(
void
*
)
nl
[
0
].
n_value
;
&
dyld_image_info
,
sizeof
(
dyld_image_info
),
NULL
))
{
TRACE
(
"got dyld_image_info 0x%08x from PEB %p MacDyldImageInfo %p
\n
"
,
dyld_image_info
,
pbi
.
PebBaseAddress
,
&
pbi
.
PebBaseAddress
->
Reserved
);
macho_info
->
dbg_hdr_addr
=
dyld_image_info
;
ret
=
TRUE
;
}
}
}
if
(
dyld_all_image_infos_addr
)
if
(
!
ret
)
macho_info
->
dbg_hdr_addr
=
(
unsigned
long
)
dyld_all_image_infos_addr
;
{
else
static
void
*
dyld_all_image_infos_addr
;
ret
=
FALSE
;
TRACE
(
"dbg_hdr_addr = 0x%08lx
\n
"
,
macho_info
->
dbg_hdr_addr
);
/* Our next best guess is that dyld was loaded at its base address
and we can find the dyld image infos address by looking up its symbol. */
if
(
!
dyld_all_image_infos_addr
)
{
struct
nlist
nl
[
2
];
memset
(
nl
,
0
,
sizeof
(
nl
));
nl
[
0
].
n_un
.
n_name
=
(
char
*
)
"_dyld_all_image_infos"
;
if
(
!
nlist
(
"/usr/lib/dyld"
,
nl
))
dyld_all_image_infos_addr
=
(
void
*
)
nl
[
0
].
n_value
;
}
if
(
dyld_all_image_infos_addr
)
{
TRACE
(
"got dyld_image_info %p from /usr/lib/dyld symbol table
\n
"
,
dyld_all_image_infos_addr
);
macho_info
->
dbg_hdr_addr
=
(
unsigned
long
)
dyld_all_image_infos_addr
;
ret
=
TRUE
;
}
}
}
}
if
(
macho_info
->
flags
&
MACHO_INFO_MODULE
)
if
(
macho_info
->
flags
&
MACHO_INFO_MODULE
)
...
...
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