|
@@ -160,7 +160,7 @@ static void *pdb_ds_read_file(struct pdb_reader* r, uint32_t file_number)
|
|
|
static int pdb_init_segments(struct pdb_reader *r)
|
|
|
{
|
|
|
char *segs;
|
|
|
- unsigned stream_idx = r->sidx.segments;
|
|
|
+ unsigned stream_idx = r->segments;
|
|
|
|
|
|
segs = pdb_ds_read_file(r, stream_idx);
|
|
|
if (!segs) {
|
|
@@ -177,9 +177,6 @@ static int pdb_init_symbols(struct pdb_reader *r)
|
|
|
{
|
|
|
int err = 0;
|
|
|
PDB_SYMBOLS *symbols;
|
|
|
- PDB_STREAM_INDEXES *sidx = &r->sidx;
|
|
|
-
|
|
|
- memset(sidx, -1, sizeof(*sidx));
|
|
|
|
|
|
symbols = pdb_ds_read_file(r, 3);
|
|
|
if (!symbols) {
|
|
@@ -188,15 +185,11 @@ static int pdb_init_symbols(struct pdb_reader *r)
|
|
|
|
|
|
r->symbols = symbols;
|
|
|
|
|
|
- if (symbols->stream_index_size != sizeof(PDB_STREAM_INDEXES)) {
|
|
|
- err = 1;
|
|
|
- goto out_symbols;
|
|
|
- }
|
|
|
-
|
|
|
- memcpy(sidx, (const char *)symbols + sizeof(PDB_SYMBOLS) +
|
|
|
+ r->segments = *(uint16_t *)((const char *)symbols + sizeof(PDB_SYMBOLS) +
|
|
|
symbols->module_size + symbols->offset_size +
|
|
|
symbols->hash_size + symbols->srcmodule_size +
|
|
|
- symbols->pdbimport_size + symbols->unknown2_size, sizeof(*sidx));
|
|
|
+ symbols->pdbimport_size + symbols->unknown2_size +
|
|
|
+ offsetof(PDB_STREAM_INDEXES, segments));
|
|
|
|
|
|
/* Read global symbol table */
|
|
|
r->modimage = pdb_ds_read_file(r, symbols->gsym_file);
|