Commit 171c6fad authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

dbghelp: Use elf_check_debug_link in elf_locate_build_id_target.

parent c1d867fa
...@@ -985,20 +985,25 @@ static BOOL elf_check_debug_link(const WCHAR* file, struct image_file_map* fmap, ...@@ -985,20 +985,25 @@ static BOOL elf_check_debug_link(const WCHAR* file, struct image_file_map* fmap,
{ {
HANDLE handle; HANDLE handle;
WCHAR *path; WCHAR *path;
DWORD crc; BOOL ret;
BOOL ret = FALSE;
path = get_dos_file_name(file); path = get_dos_file_name(file);
handle = CreateFileW(path, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0, NULL); handle = CreateFileW(path, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0, NULL);
heap_free(path); heap_free(path);
if (handle == INVALID_HANDLE_VALUE) return FALSE; if (handle == INVALID_HANDLE_VALUE) return FALSE;
crc = calc_crc32(handle); if (link_crc)
if (crc != link_crc) {
WARN("Bad CRC for file %s (got %08x while expecting %08x)\n", debugstr_w(file), crc, link_crc); DWORD crc = calc_crc32(handle);
else if (crc != link_crc)
ret = elf_map_handle(handle, fmap); {
WARN("Bad CRC for file %s (got %08x while expecting %08x)\n", debugstr_w(file), crc, link_crc);
CloseHandle(handle);
return FALSE;
}
}
ret = elf_map_handle(handle, fmap);
CloseHandle(handle); CloseHandle(handle);
return ret; return ret;
} }
...@@ -1094,7 +1099,6 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE* ...@@ -1094,7 +1099,6 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE*
WCHAR* p; WCHAR* p;
WCHAR* z; WCHAR* z;
const BYTE* idend = id + idlen; const BYTE* idend = id + idlen;
struct elf_map_file_data emfd;
fmap_link = HeapAlloc(GetProcessHeap(), 0, sizeof(*fmap_link)); fmap_link = HeapAlloc(GetProcessHeap(), 0, sizeof(*fmap_link));
if (!fmap_link) return FALSE; if (!fmap_link) return FALSE;
...@@ -1125,9 +1129,7 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE* ...@@ -1125,9 +1129,7 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE*
memcpy(z, dotDebug0W, sizeof(dotDebug0W)); memcpy(z, dotDebug0W, sizeof(dotDebug0W));
TRACE("checking %s\n", wine_dbgstr_w(p)); TRACE("checking %s\n", wine_dbgstr_w(p));
emfd.kind = from_file; if (elf_check_debug_link(p, fmap_link, 0))
emfd.u.file.filename = p;
if (elf_map_file(&emfd, fmap_link))
{ {
struct image_section_map buildid_sect; struct image_section_map buildid_sect;
if (image_find_section(fmap_link, ".note.gnu.build-id", &buildid_sect)) if (image_find_section(fmap_link, ".note.gnu.build-id", &buildid_sect))
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment