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
5ce195ae
Commit
5ce195ae
authored
Jan 08, 2011
by
Eric Pouech
Committed by
Alexandre Julliard
Jan 10, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dbghelp: Keep the mapping of any PDB file open until the module is unloaded.
parent
0693572e
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
40 additions
and
35 deletions
+40
-35
msc.c
dlls/dbghelp/msc.c
+40
-35
No files found.
dlls/dbghelp/msc.c
View file @
5ce195ae
...
@@ -66,6 +66,8 @@ struct pdb_file_info
...
@@ -66,6 +66,8 @@ struct pdb_file_info
{
{
enum
pdb_kind
kind
;
enum
pdb_kind
kind
;
DWORD
age
;
DWORD
age
;
HANDLE
hMap
;
const
char
*
image
;
union
union
{
{
struct
struct
...
@@ -2130,16 +2132,16 @@ static void* pdb_read_ds_file(const struct PDB_DS_HEADER* pdb,
...
@@ -2130,16 +2132,16 @@ static void* pdb_read_ds_file(const struct PDB_DS_HEADER* pdb,
return
pdb_ds_read
(
pdb
,
block_list
,
toc
->
file_size
[
file_nr
]);
return
pdb_ds_read
(
pdb
,
block_list
,
toc
->
file_size
[
file_nr
]);
}
}
static
void
*
pdb_read_file
(
const
char
*
image
,
const
struct
pdb_file_info
*
pdb_file
,
static
void
*
pdb_read_file
(
const
struct
pdb_file_info
*
pdb_file
,
DWORD
file_nr
)
DWORD
file_nr
)
{
{
switch
(
pdb_file
->
kind
)
switch
(
pdb_file
->
kind
)
{
{
case
PDB_JG
:
case
PDB_JG
:
return
pdb_read_jg_file
((
const
struct
PDB_JG_HEADER
*
)
image
,
return
pdb_read_jg_file
((
const
struct
PDB_JG_HEADER
*
)
pdb_file
->
image
,
pdb_file
->
u
.
jg
.
toc
,
file_nr
);
pdb_file
->
u
.
jg
.
toc
,
file_nr
);
case
PDB_DS
:
case
PDB_DS
:
return
pdb_read_ds_file
((
const
struct
PDB_DS_HEADER
*
)
image
,
return
pdb_read_ds_file
((
const
struct
PDB_DS_HEADER
*
)
pdb_file
->
image
,
pdb_file
->
u
.
ds
.
toc
,
file_nr
);
pdb_file
->
u
.
ds
.
toc
,
file_nr
);
}
}
return
NULL
;
return
NULL
;
...
@@ -2180,7 +2182,13 @@ static void pdb_module_remove(struct process* pcsn, struct module_format* modfmt
...
@@ -2180,7 +2182,13 @@ static void pdb_module_remove(struct process* pcsn, struct module_format* modfmt
unsigned
i
;
unsigned
i
;
for
(
i
=
0
;
i
<
modfmt
->
u
.
pdb_info
->
used_subfiles
;
i
++
)
for
(
i
=
0
;
i
<
modfmt
->
u
.
pdb_info
->
used_subfiles
;
i
++
)
{
pdb_free_file
(
&
modfmt
->
u
.
pdb_info
->
pdb_files
[
i
]);
pdb_free_file
(
&
modfmt
->
u
.
pdb_info
->
pdb_files
[
i
]);
if
(
modfmt
->
u
.
pdb_info
->
pdb_files
[
i
].
image
)
UnmapViewOfFile
(
modfmt
->
u
.
pdb_info
->
pdb_files
[
i
].
image
);
if
(
modfmt
->
u
.
pdb_info
->
pdb_files
[
i
].
hMap
)
CloseHandle
(
modfmt
->
u
.
pdb_info
->
pdb_files
[
i
].
hMap
);
}
HeapFree
(
GetProcessHeap
(),
0
,
modfmt
);
HeapFree
(
GetProcessHeap
(),
0
,
modfmt
);
}
}
...
@@ -2259,11 +2267,11 @@ static void pdb_convert_symbol_file(const PDB_SYMBOLS* symbols,
...
@@ -2259,11 +2267,11 @@ static void pdb_convert_symbol_file(const PDB_SYMBOLS* symbols,
}
}
}
}
static
HANDLE
open
_pdb_file
(
const
struct
process
*
pcs
,
static
HANDLE
map
_pdb_file
(
const
struct
process
*
pcs
,
const
struct
pdb_lookup
*
lookup
,
const
struct
pdb_lookup
*
lookup
,
struct
module
*
module
)
struct
module
*
module
)
{
{
HANDLE
h
;
HANDLE
h
File
,
hMap
=
NULL
;
char
dbg_file_path
[
MAX_PATH
];
char
dbg_file_path
[
MAX_PATH
];
BOOL
ret
=
FALSE
;
BOOL
ret
=
FALSE
;
...
@@ -2283,19 +2291,21 @@ static HANDLE open_pdb_file(const struct process* pcs,
...
@@ -2283,19 +2291,21 @@ static HANDLE open_pdb_file(const struct process* pcs,
WARN
(
"
\t
Couldn't find %s
\n
"
,
lookup
->
filename
);
WARN
(
"
\t
Couldn't find %s
\n
"
,
lookup
->
filename
);
return
NULL
;
return
NULL
;
}
}
h
=
CreateFileA
(
dbg_file_path
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
if
((
hFile
=
CreateFileA
(
dbg_file_path
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
OPEN_EXISTING
,
FILE_ATTRIBUTE_NORMAL
,
NULL
);
OPEN_EXISTING
,
FILE_ATTRIBUTE_NORMAL
,
NULL
))
!=
INVALID_HANDLE_VALUE
)
TRACE
(
"%s: %s returns %p
\n
"
,
lookup
->
filename
,
dbg_file_path
,
h
);
{
return
(
h
==
INVALID_HANDLE_VALUE
)
?
NULL
:
h
;
hMap
=
CreateFileMappingW
(
hFile
,
NULL
,
PAGE_READONLY
,
0
,
0
,
NULL
);
CloseHandle
(
hFile
);
}
return
hMap
;
}
}
static
void
pdb_process_types
(
const
struct
msc_debug_info
*
msc_dbg
,
static
void
pdb_process_types
(
const
struct
msc_debug_info
*
msc_dbg
,
const
char
*
image
,
const
struct
pdb_file_info
*
pdb_file
)
const
struct
pdb_file_info
*
pdb_file
)
{
{
BYTE
*
types_image
=
NULL
;
BYTE
*
types_image
=
NULL
;
types_image
=
pdb_read_file
(
image
,
pdb_file
,
2
);
types_image
=
pdb_read_file
(
pdb_file
,
2
);
if
(
types_image
)
if
(
types_image
)
{
{
PDB_TYPES
types
;
PDB_TYPES
types
;
...
@@ -2451,7 +2461,7 @@ static BOOL pdb_init(const struct pdb_lookup* pdb_lookup, struct pdb_file_info*
...
@@ -2451,7 +2461,7 @@ static BOOL pdb_init(const struct pdb_lookup* pdb_lookup, struct pdb_file_info*
for
(
i
=
1
;
i
<
num_files
;
i
++
)
for
(
i
=
1
;
i
<
num_files
;
i
++
)
{
{
unsigned
char
*
x
=
pdb_read_file
(
image
,
pdb_file
,
i
);
unsigned
char
*
x
=
pdb_read_file
(
pdb_file
,
i
);
FIXME
(
"********************** [%u]: size=%08x
\n
"
,
FIXME
(
"********************** [%u]: size=%08x
\n
"
,
i
,
pdb_get_file_size
(
pdb_file
,
i
));
i
,
pdb_get_file_size
(
pdb_file
,
i
));
dump
(
x
,
pdb_get_file_size
(
pdb_file
,
i
));
dump
(
x
,
pdb_get_file_size
(
pdb_file
,
i
));
...
@@ -2536,8 +2546,7 @@ static BOOL pdb_process_internal(const struct process* pcs,
...
@@ -2536,8 +2546,7 @@ static BOOL pdb_process_internal(const struct process* pcs,
struct
pdb_module_info
*
pdb_module_info
,
struct
pdb_module_info
*
pdb_module_info
,
unsigned
module_index
)
unsigned
module_index
)
{
{
BOOL
ret
=
FALSE
;
HANDLE
hMap
=
NULL
;
HANDLE
hFile
,
hMap
=
NULL
;
char
*
image
=
NULL
;
char
*
image
=
NULL
;
BYTE
*
symbols_image
=
NULL
;
BYTE
*
symbols_image
=
NULL
;
char
*
files_image
=
NULL
;
char
*
files_image
=
NULL
;
...
@@ -2549,19 +2558,23 @@ static BOOL pdb_process_internal(const struct process* pcs,
...
@@ -2549,19 +2558,23 @@ static BOOL pdb_process_internal(const struct process* pcs,
pdb_file
=
&
pdb_module_info
->
pdb_files
[
module_index
==
-
1
?
0
:
module_index
];
pdb_file
=
&
pdb_module_info
->
pdb_files
[
module_index
==
-
1
?
0
:
module_index
];
/* Open and map() .PDB file */
/* Open and map() .PDB file */
if
((
hFile
=
open_pdb_file
(
pcs
,
pdb_lookup
,
msc_dbg
->
module
))
==
NULL
||
if
((
hMap
=
map_pdb_file
(
pcs
,
pdb_lookup
,
msc_dbg
->
module
))
==
NULL
||
((
hMap
=
CreateFileMappingW
(
hFile
,
NULL
,
PAGE_READONLY
,
0
,
0
,
NULL
))
==
NULL
)
||
((
image
=
MapViewOfFile
(
hMap
,
FILE_MAP_READ
,
0
,
0
,
0
))
==
NULL
))
((
image
=
MapViewOfFile
(
hMap
,
FILE_MAP_READ
,
0
,
0
,
0
))
==
NULL
))
{
{
WARN
(
"Unable to open .PDB file: %s
\n
"
,
pdb_lookup
->
filename
);
WARN
(
"Unable to open .PDB file: %s
\n
"
,
pdb_lookup
->
filename
);
goto
leave
;
CloseHandle
(
hMap
);
return
FALSE
;
}
}
if
(
!
pdb_init
(
pdb_lookup
,
pdb_file
,
image
,
&
matched
)
||
matched
!=
2
)
if
(
!
pdb_init
(
pdb_lookup
,
pdb_file
,
image
,
&
matched
)
||
matched
!=
2
)
{
{
goto
leave
;
CloseHandle
(
hMap
);
UnmapViewOfFile
(
image
);
return
FALSE
;
}
}
symbols_image
=
pdb_read_file
(
image
,
pdb_file
,
3
);
pdb_file
->
hMap
=
hMap
;
pdb_file
->
image
=
image
;
symbols_image
=
pdb_read_file
(
pdb_file
,
3
);
if
(
symbols_image
)
if
(
symbols_image
)
{
{
PDB_SYMBOLS
symbols
;
PDB_SYMBOLS
symbols
;
...
@@ -2583,7 +2596,7 @@ static BOOL pdb_process_internal(const struct process* pcs,
...
@@ -2583,7 +2596,7 @@ static BOOL pdb_process_internal(const struct process* pcs,
symbols
.
version
,
symbols
.
version
);
symbols
.
version
,
symbols
.
version
);
}
}
files_image
=
pdb_read_file
(
image
,
pdb_file
,
12
);
/* FIXME: really fixed ??? */
files_image
=
pdb_read_file
(
pdb_file
,
12
);
/* FIXME: really fixed ??? */
if
(
files_image
)
if
(
files_image
)
{
{
if
(
*
(
const
DWORD
*
)
files_image
==
0xeffeeffe
)
if
(
*
(
const
DWORD
*
)
files_image
==
0xeffeeffe
)
...
@@ -2600,10 +2613,10 @@ static BOOL pdb_process_internal(const struct process* pcs,
...
@@ -2600,10 +2613,10 @@ static BOOL pdb_process_internal(const struct process* pcs,
pdb_process_symbol_imports
(
pcs
,
msc_dbg
,
&
symbols
,
symbols_image
,
image
,
pdb_process_symbol_imports
(
pcs
,
msc_dbg
,
&
symbols
,
symbols_image
,
image
,
pdb_lookup
,
pdb_module_info
,
module_index
);
pdb_lookup
,
pdb_module_info
,
module_index
);
pdb_process_types
(
msc_dbg
,
image
,
pdb_file
);
pdb_process_types
(
msc_dbg
,
pdb_file
);
/* Read global symbol table */
/* Read global symbol table */
globalimage
=
pdb_read_file
(
image
,
pdb_file
,
symbols
.
gsym_file
);
globalimage
=
pdb_read_file
(
pdb_file
,
symbols
.
gsym_file
);
if
(
globalimage
)
if
(
globalimage
)
{
{
codeview_snarf
(
msc_dbg
,
globalimage
,
0
,
codeview_snarf
(
msc_dbg
,
globalimage
,
0
,
...
@@ -2621,7 +2634,7 @@ static BOOL pdb_process_internal(const struct process* pcs,
...
@@ -2621,7 +2634,7 @@ static BOOL pdb_process_internal(const struct process* pcs,
HeapValidate
(
GetProcessHeap
(),
0
,
NULL
);
HeapValidate
(
GetProcessHeap
(),
0
,
NULL
);
pdb_convert_symbol_file
(
&
symbols
,
&
sfile
,
&
size
,
file
);
pdb_convert_symbol_file
(
&
symbols
,
&
sfile
,
&
size
,
file
);
modimage
=
pdb_read_file
(
image
,
pdb_file
,
sfile
.
file
);
modimage
=
pdb_read_file
(
pdb_file
,
sfile
.
file
);
if
(
modimage
)
if
(
modimage
)
{
{
if
(
sfile
.
symbol_size
)
if
(
sfile
.
symbol_size
)
...
@@ -2655,19 +2668,11 @@ static BOOL pdb_process_internal(const struct process* pcs,
...
@@ -2655,19 +2668,11 @@ static BOOL pdb_process_internal(const struct process* pcs,
else
else
pdb_process_symbol_imports
(
pcs
,
msc_dbg
,
NULL
,
NULL
,
image
,
pdb_process_symbol_imports
(
pcs
,
msc_dbg
,
NULL
,
NULL
,
image
,
pdb_lookup
,
pdb_module_info
,
module_index
);
pdb_lookup
,
pdb_module_info
,
module_index
);
ret
=
TRUE
;
leave:
/* Cleanup */
pdb_free
(
symbols_image
);
pdb_free
(
symbols_image
);
pdb_free
(
files_image
);
pdb_free
(
files_image
);
pdb_free_file
(
pdb_file
);
if
(
image
)
UnmapViewOfFile
(
image
);
return
TRUE
;
if
(
hMap
)
CloseHandle
(
hMap
);
if
(
hFile
)
CloseHandle
(
hFile
);
return
ret
;
}
}
static
BOOL
pdb_process_file
(
const
struct
process
*
pcs
,
static
BOOL
pdb_process_file
(
const
struct
process
*
pcs
,
...
@@ -2720,7 +2725,7 @@ BOOL pdb_fetch_file_info(const struct pdb_lookup* pdb_lookup, unsigned* matched)
...
@@ -2720,7 +2725,7 @@ BOOL pdb_fetch_file_info(const struct pdb_lookup* pdb_lookup, unsigned* matched)
{
{
HANDLE
hFile
,
hMap
=
NULL
;
HANDLE
hFile
,
hMap
=
NULL
;
char
*
image
=
NULL
;
char
*
image
=
NULL
;
BOOL
ret
=
TRUE
;
BOOL
ret
;
struct
pdb_file_info
pdb_file
;
struct
pdb_file_info
pdb_file
;
if
((
hFile
=
CreateFileA
(
pdb_lookup
->
filename
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
if
((
hFile
=
CreateFileA
(
pdb_lookup
->
filename
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
...
...
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