[Lldb-commits] [PATCH] PECOFF: Export symbols
Greg Clayton
gclayton at apple.com
Fri Aug 23 10:51:03 PDT 2013
Feel free to do whatever you want with ObjectFilePECOFF, no reviews are necessary.
Looks good.
On Aug 23, 2013, at 10:19 AM, Virgile Bello <virgile.bello at gmail.com> wrote:
> Add support for export symbols in PECOFF (useful for stacktrace).
> Import table still not yet supported.
>
> http://llvm-reviews.chandlerc.com/D1489
>
> Files:
> source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp
> source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h
>
> Index: source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp
> ===================================================================
> --- source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp
> +++ source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp
> @@ -593,6 +593,54 @@
> }
>
> }
> +
> + // Export header?
> + if (m_coff_header_opt.data_dirs[0].vmsize > 0 && m_coff_header_opt.data_dirs[0].vmaddr > 0)
> + {
> + export_directory_entry export_table;
> + uint32_t data_start = m_coff_header_opt.data_dirs[0].vmaddr;
> + Address address(m_coff_header_opt.image_base + data_start, sect_list);
> + DataBufferSP symtab_data_sp(m_file.ReadFileContents(address.GetSection()->GetFileOffset() + address.GetOffset(), m_coff_header_opt.data_dirs[0].vmsize));
> + DataExtractor symtab_data (symtab_data_sp, GetByteOrder(), GetAddressByteSize());
> + lldb::offset_t offset = 0;
> + export_table.characteristics = symtab_data.GetU32(&offset);
> + export_table.time_date_stamp = symtab_data.GetU32(&offset);
> + export_table.major_version = symtab_data.GetU16(&offset);
> + export_table.minor_version = symtab_data.GetU16(&offset);
> + export_table.name = symtab_data.GetU32(&offset);
> + export_table.base = symtab_data.GetU32(&offset);
> + export_table.number_of_functions = symtab_data.GetU32(&offset);
> + export_table.number_of_names = symtab_data.GetU32(&offset);
> + export_table.address_of_functions = symtab_data.GetU32(&offset);
> + export_table.address_of_names = symtab_data.GetU32(&offset);
> + export_table.address_of_name_ordinals = symtab_data.GetU32(&offset);
> +
> + bool has_ordinal = export_table.address_of_name_ordinals != 0;
> +
> + lldb::offset_t name_offset = export_table.address_of_names - data_start;
> + lldb::offset_t name_ordinal_offset = export_table.address_of_name_ordinals - data_start;
> +
> + Symbol *symbols = m_symtab_ap->Resize(export_table.number_of_names);
> +
> + std::string symbol_name;
> +
> + for (size_t i = 0; i < export_table.number_of_names; ++i)
> + {
> + uint32_t name_ordinal = has_ordinal ? symtab_data.GetU16(&name_ordinal_offset) : i;
> + uint32_t name_address = symtab_data.GetU32(&name_offset);
> + const char* symbol_name_cstr = symtab_data.PeekCStr(name_address - data_start);
> + symbol_name.assign(symbol_name_cstr);
> +
> + lldb::offset_t function_offset = export_table.address_of_functions - data_start + sizeof(uint32_t) * name_ordinal;
> + uint32_t function_rva = symtab_data.GetU32(&function_offset);
> +
> + Address symbol_addr(m_coff_header_opt.image_base + function_rva, sect_list);
> + symbols[i].GetMangled().SetValue(ConstString(symbol_name.c_str()));
> + symbols[i].GetAddress() = symbol_addr;
> + symbols[i].SetType(lldb::eSymbolTypeCode);
> + symbols[i].SetDebug(true);
> + }
> + }
> }
> }
> return m_symtab_ap.get();
> Index: source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h
> ===================================================================
> --- source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h
> +++ source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h
> @@ -221,6 +221,20 @@
> uint8_t storage;
> uint8_t naux;
> } coff_symbol_t;
> +
> + typedef struct export_directory_entry {
> + uint32_t characteristics;
> + uint32_t time_date_stamp;
> + uint16_t major_version;
> + uint16_t minor_version;
> + uint32_t name;
> + uint32_t base;
> + uint32_t number_of_functions;
> + uint32_t number_of_names;
> + uint32_t address_of_functions;
> + uint32_t address_of_names;
> + uint32_t address_of_name_ordinals;
> + };
>
> bool ParseDOSHeader ();
> bool ParseCOFFHeader (lldb::offset_t *offset_ptr);
> <D1489.1.patch>_______________________________________________
> lldb-commits mailing list
> lldb-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/lldb-commits
More information about the lldb-commits
mailing list