[DBGHELP]
[reactos.git] / reactos / dll / win32 / dbghelp / dbghelp_private.h
index f4c88a0..2180fdd 100644 (file)
  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
  */
 
+#define WIN32_NO_STATUS
+#define _INC_WINDOWS
+#define COM_NO_WINDOWS_H
+
 #include <stdarg.h>
-#include "windef.h"
-#include "winbase.h"
-#include "winver.h"
-#include "dbghelp.h"
-#include "objbase.h"
-#include "oaidl.h"
-#include "winnls.h"
-#include "wine/list.h"
-#include "wine/unicode.h"
-
-#include "cvconst.h"
+
+#ifndef DBGHELP_STATIC_LIB
+#include <windef.h>
+#include <winbase.h>
+#include <winver.h>
+#include <dbghelp.h>
+#include <objbase.h>
+#include <cvconst.h>
+#include <wine/unicode.h>
+#else
+#include <string.h>
+#include "compat.h"
+#endif
+
+//#include "oaidl.h"
+//#include "winnls.h"
+#include <wine/list.h>
+#include <wine/rbtree.h>
+
 
 /* #define USE_STATS */
 
@@ -43,10 +55,10 @@ struct pool /* poor's man */
     size_t      arena_size;
 };
 
-void     pool_init(struct pool* a, size_t arena_size);
-void     pool_destroy(struct pool* a);
-void*    pool_alloc(struct pool* a, size_t len);
-char*    pool_strdup(struct pool* a, const char* str);
+void     pool_init(struct pool* a, size_t arena_size) DECLSPEC_HIDDEN;
+void     pool_destroy(struct pool* a) DECLSPEC_HIDDEN;
+void*    pool_alloc(struct pool* a, size_t len) DECLSPEC_HIDDEN;
+char*    pool_strdup(struct pool* a, const char* str) DECLSPEC_HIDDEN;
 
 struct vector
 {
@@ -58,10 +70,10 @@ struct vector
     unsigned    buckets_allocated;
 };
 
-void     vector_init(struct vector* v, unsigned elt_sz, unsigned bucket_sz);
-unsigned vector_length(const struct vector* v);
-void*    vector_at(const struct vector* v, unsigned pos);
-void*    vector_add(struct vector* v, struct pool* pool);
+void     vector_init(struct vector* v, unsigned elt_sz, unsigned bucket_sz) DECLSPEC_HIDDEN;
+unsigned vector_length(const struct vector* v) DECLSPEC_HIDDEN;
+void*    vector_at(const struct vector* v, unsigned pos) DECLSPEC_HIDDEN;
+void*    vector_add(struct vector* v, struct pool* pool) DECLSPEC_HIDDEN;
 
 struct sparse_array
 {
@@ -69,10 +81,10 @@ struct sparse_array
     struct vector               elements;
 };
 
-void     sparse_array_init(struct sparse_array* sa, unsigned elt_sz, unsigned bucket_sz);
-void*    sparse_array_find(const struct sparse_array* sa, unsigned long idx);
-void*    sparse_array_add(struct sparse_array* sa, unsigned long key, struct pool* pool);
-unsigned sparse_array_length(const struct sparse_array* sa);
+void     sparse_array_init(struct sparse_array* sa, unsigned elt_sz, unsigned bucket_sz) DECLSPEC_HIDDEN;
+void*    sparse_array_find(const struct sparse_array* sa, unsigned long idx) DECLSPEC_HIDDEN;
+void*    sparse_array_add(struct sparse_array* sa, unsigned long key, struct pool* pool) DECLSPEC_HIDDEN;
+unsigned sparse_array_length(const struct sparse_array* sa) DECLSPEC_HIDDEN;
 
 struct hash_table_elt
 {
@@ -95,9 +107,9 @@ struct hash_table
 };
 
 void     hash_table_init(struct pool* pool, struct hash_table* ht,
-                         unsigned num_buckets);
-void     hash_table_destroy(struct hash_table* ht);
-void     hash_table_add(struct hash_table* ht, struct hash_table_elt* elt);
+                         unsigned num_buckets) DECLSPEC_HIDDEN;
+void     hash_table_destroy(struct hash_table* ht) DECLSPEC_HIDDEN;
+void     hash_table_add(struct hash_table* ht, struct hash_table_elt* elt) DECLSPEC_HIDDEN;
 
 struct hash_table_iter
 {
@@ -108,14 +120,14 @@ struct hash_table_iter
 };
 
 void     hash_table_iter_init(const struct hash_table* ht,
-                              struct hash_table_iter* hti, const char* name);
-void*    hash_table_iter_up(struct hash_table_iter* hti);
+                              struct hash_table_iter* hti, const char* name) DECLSPEC_HIDDEN;
+void*    hash_table_iter_up(struct hash_table_iter* hti) DECLSPEC_HIDDEN;
 
 #define GET_ENTRY(__i, __t, __f) \
     ((__t*)((char*)(__i) - FIELD_OFFSET(__t,__f)))
 
 
-extern unsigned dbghelp_options;
+extern unsigned dbghelp_options DECLSPEC_HIDDEN;
 /* some more Wine extensions */
 #define SYMOPT_WINE_WITH_NATIVE_MODULES 0x40000000
 
@@ -124,6 +136,7 @@ enum location_kind {loc_error,          /* reg is the error code */
                     loc_absolute,       /* offset is the location */
                     loc_register,       /* reg is the location */
                     loc_regrel,         /* [reg+offset] is the location */
+                    loc_tlsrel,         /* offset is the address of the TLS index */
                     loc_user,           /* value is debug information dependent,
                                            reg & offset can be used ad libidem */
 };
@@ -132,6 +145,7 @@ enum location_error {loc_err_internal = -1,     /* internal while computing */
                      loc_err_too_complex = -2,  /* couldn't compute location (even at runtime) */
                      loc_err_out_of_scope = -3, /* variable isn't available at current address */
                      loc_err_cant_read = -4,    /* couldn't read memory at given address */
+                     loc_err_no_location = -5,  /* likely optimized away (by compiler) */
 };
 
 struct location
@@ -180,8 +194,9 @@ struct symt_data
     union                                       /* depends on kind */
     {
         /* DataIs{Global, FileStatic}:
-         *      loc.kind is loc_absolute
-         *      loc.offset is address
+         *      with loc.kind
+         *              loc_absolute    loc.offset is address
+         *              loc_tlsrel      loc.offset is TLS index address
          * DataIs{Local,Param}:
          *      with loc.kind
          *              loc_absolute    not supported
@@ -285,6 +300,7 @@ struct symt_pointer
 {
     struct symt                 symt;
     struct symt*                pointsto;
+    unsigned long               size;
 };
 
 struct symt_typedef
@@ -325,6 +341,7 @@ enum format_info
     DFI_PE,
     DFI_MACHO,
     DFI_DWARF,
+    DFI_PDB,
     DFI_LAST
 };
 
@@ -342,15 +359,22 @@ struct module_format
         struct dwarf2_module_info_s*    dwarf2_info;
         struct pe_module_info*          pe_info;
         struct macho_module_info*      macho_info;
+        struct pdb_module_info*         pdb_info;
     } u;
 };
 
+struct symt_idx_to_ptr
+{
+    struct hash_table_elt hash_elt;
+    DWORD idx;
+    const struct symt *sym;
+};
+
+extern const struct wine_rb_functions source_rb_functions DECLSPEC_HIDDEN;
 struct module
 {
     struct process*             process;
     IMAGEHLP_MODULEW64          module;
-    /* ANSI copy of module.ModuleName for efficiency */
-    char                        module_name[MAX_PATH];
     struct module*              next;
     enum module_type           type : 16;
     unsigned short              is_virtual : 1;
@@ -370,6 +394,9 @@ struct module
     unsigned                    sorttab_size;
     struct symt_ht**            addr_sorttab;
     struct hash_table           ht_symbols;
+#ifdef __x86_64__
+    struct hash_table           ht_symaddr;
+#endif
 
     /* types */
     struct hash_table           ht_types;
@@ -379,6 +406,7 @@ struct module
     unsigned                    sources_used;
     unsigned                    sources_alloc;
     char*                       sources;
+    struct wine_rb_tree         sources_offsets_tree;
 };
 
 struct process 
@@ -426,21 +454,10 @@ enum pdb_kind {PDB_JG, PDB_DS};
 struct pdb_lookup
 {
     const char*                 filename;
-    DWORD                       age;
     enum pdb_kind               kind;
-    union
-    {
-        struct
-        {
-            DWORD               timestamp;
-            struct PDB_JG_TOC*  toc;
-        } jg;
-        struct
-        {
-            GUID                guid;
-            struct PDB_DS_TOC*  toc;
-        } ds;
-    } u;
+    DWORD                       age;
+    DWORD                       timestamp;
+    GUID                        guid;
 };
 
 struct cpu_stack_walk
@@ -467,11 +484,62 @@ struct cpu_stack_walk
     } u;
 };
 
+struct dump_memory
+{
+    ULONG64                             base;
+    ULONG                               size;
+    ULONG                               rva;
+};
+
+struct dump_module
+{
+    unsigned                            is_elf;
+    ULONG64                             base;
+    ULONG                               size;
+    DWORD                               timestamp;
+    DWORD                               checksum;
+    WCHAR                               name[MAX_PATH];
+};
+
+struct dump_thread
+{
+    ULONG                               tid;
+    ULONG                               prio_class;
+    ULONG                               curr_prio;
+};
+
+struct dump_context
+{
+    /* process & thread information */
+    HANDLE                              hProcess;
+    DWORD                               pid;
+    unsigned                            flags_out;
+    /* thread information */
+    struct dump_thread*                 threads;
+    unsigned                            num_threads;
+    /* module information */
+    struct dump_module*                 modules;
+    unsigned                            num_modules;
+    unsigned                            alloc_modules;
+    /* exception information */
+    /* output information */
+    MINIDUMP_TYPE                       type;
+    HANDLE                              hFile;
+    RVA                                 rva;
+    struct dump_memory*                 mem;
+    unsigned                            num_mem;
+    unsigned                            alloc_mem;
+    /* callback information */
+    MINIDUMP_CALLBACK_INFORMATION*      cb;
+};
+
 enum cpu_addr {cpu_addr_pc, cpu_addr_stack, cpu_addr_frame};
 struct cpu
 {
     DWORD       machine;
     DWORD       word_size;
+    DWORD       frame_regno;
+
     /* address manipulation */
     unsigned    (*get_addr)(HANDLE hThread, const CONTEXT* ctx,
                             enum cpu_addr, ADDRESS64* addr);
@@ -485,110 +553,126 @@ struct cpu
     /* dwarf dedicated information */
     unsigned    (*map_dwarf_register)(unsigned regno);
 
-    /* context related maniputation */
+    /* context related manipulation */
     void*       (*fetch_context_reg)(CONTEXT* context, unsigned regno, unsigned* size);
     const char* (*fetch_regname)(unsigned regno);
+
+    /* minidump per CPU extension */
+    BOOL        (*fetch_minidump_thread)(struct dump_context* dc, unsigned index, unsigned flags, const CONTEXT* ctx);
+    BOOL        (*fetch_minidump_module)(struct dump_context* dc, unsigned index, unsigned flags);
 };
 
-extern struct cpu*      dbghelp_current_cpu;
+extern struct cpu*      dbghelp_current_cpu DECLSPEC_HIDDEN;
 
 /* dbghelp.c */
-extern struct process* process_find_by_handle(HANDLE hProcess);
-extern HANDLE hMsvcrt;
-extern BOOL         validate_addr64(DWORD64 addr);
-extern BOOL         pcs_callback(const struct process* pcs, ULONG action, void* data);
-extern void*        fetch_buffer(struct process* pcs, unsigned size);
-extern const char*  wine_dbgstr_addr(const ADDRESS64* addr);
-extern struct cpu*  cpu_find(DWORD);
+extern struct process* process_find_by_handle(HANDLE hProcess) DECLSPEC_HIDDEN;
+extern HANDLE hMsvcrt DECLSPEC_HIDDEN;
+extern BOOL         validate_addr64(DWORD64 addr) DECLSPEC_HIDDEN;
+extern BOOL         pcs_callback(const struct process* pcs, ULONG action, void* data) DECLSPEC_HIDDEN;
+extern void*        fetch_buffer(struct process* pcs, unsigned size) DECLSPEC_HIDDEN;
+extern const char*  wine_dbgstr_addr(const ADDRESS64* addr) DECLSPEC_HIDDEN;
+extern struct cpu*  cpu_find(DWORD) DECLSPEC_HIDDEN;
 
 /* crc32.c */
-extern DWORD calc_crc32(int fd);
+extern DWORD calc_crc32(int fd) DECLSPEC_HIDDEN;
 
 typedef BOOL (*enum_modules_cb)(const WCHAR*, unsigned long addr, void* user);
 
 /* elf_module.c */
-extern BOOL         elf_enum_modules(HANDLE hProc, enum_modules_cb, void*);
-extern BOOL         elf_fetch_file_info(const WCHAR* name, DWORD* base, DWORD* size, DWORD* checksum);
+extern BOOL         elf_enum_modules(HANDLE hProc, enum_modules_cb, void*) DECLSPEC_HIDDEN;
+extern BOOL         elf_fetch_file_info(const WCHAR* name, DWORD_PTR* base, DWORD* size, DWORD* checksum) DECLSPEC_HIDDEN;
 struct image_file_map;
-extern BOOL         elf_load_debug_info(struct module* module, struct image_file_map* fmap);
+extern BOOL         elf_load_debug_info(struct module* module) DECLSPEC_HIDDEN;
 extern struct module*
-                    elf_load_module(struct process* pcs, const WCHAR* name, unsigned long);
-extern BOOL         elf_read_wine_loader_dbg_info(struct process* pcs);
-extern BOOL         elf_synchronize_module_list(struct process* pcs);
+                    elf_load_module(struct process* pcs, const WCHAR* name, unsigned long) DECLSPEC_HIDDEN;
+extern BOOL         elf_read_wine_loader_dbg_info(struct process* pcs) DECLSPEC_HIDDEN;
+extern BOOL         elf_synchronize_module_list(struct process* pcs) DECLSPEC_HIDDEN;
 struct elf_thunk_area;
-extern int          elf_is_in_thunk_area(unsigned long addr, const struct elf_thunk_area* thunks);
+extern int          elf_is_in_thunk_area(unsigned long addr, const struct elf_thunk_area* thunks) DECLSPEC_HIDDEN;
 
 /* macho_module.c */
 #define MACHO_NO_MAP    ((const void*)-1)
-extern BOOL         macho_enum_modules(HANDLE hProc, enum_modules_cb, void*);
-extern BOOL         macho_fetch_file_info(const WCHAR* name, DWORD* base, DWORD* size, DWORD* checksum);
+extern BOOL         macho_enum_modules(HANDLE hProc, enum_modules_cb, void*) DECLSPEC_HIDDEN;
+extern BOOL         macho_fetch_file_info(const WCHAR* name, DWORD_PTR* base, DWORD* size, DWORD* checksum) DECLSPEC_HIDDEN;
 struct macho_file_map;
-extern BOOL         macho_load_debug_info(struct module* module, struct macho_file_map* fmap);
+extern BOOL         macho_load_debug_info(struct module* module, struct macho_file_map* fmap) DECLSPEC_HIDDEN;
 extern struct module*
-                    macho_load_module(struct process* pcs, const WCHAR* name, unsigned long);
-extern BOOL         macho_read_wine_loader_dbg_info(struct process* pcs);
-extern BOOL         macho_synchronize_module_list(struct process* pcs);
+                    macho_load_module(struct process* pcs, const WCHAR* name, unsigned long) DECLSPEC_HIDDEN;
+extern BOOL         macho_read_wine_loader_dbg_info(struct process* pcs) DECLSPEC_HIDDEN;
+extern BOOL         macho_synchronize_module_list(struct process* pcs) DECLSPEC_HIDDEN;
+
+/* minidump.c */
+void minidump_add_memory_block(struct dump_context* dc, ULONG64 base, ULONG size, ULONG rva);
 
 /* module.c */
-extern const WCHAR      S_ElfW[];
-extern const WCHAR      S_WineLoaderW[];
-extern const WCHAR      S_WineW[];
-extern const WCHAR      S_SlashW[];
+extern const WCHAR      S_ElfW[] DECLSPEC_HIDDEN;
+extern const WCHAR      S_WineLoaderW[] DECLSPEC_HIDDEN;
+extern const WCHAR      S_SlashW[] DECLSPEC_HIDDEN;
 
 extern struct module*
-                    module_find_by_addr(const struct process* pcs, unsigned long addr,
-                                        enum module_type type);
+                    module_find_by_addr(const struct process* pcs, DWORD64 addr,
+                                        enum module_type type) DECLSPEC_HIDDEN;
+extern struct module*
+                    module_find_by_nameW(const struct process* pcs,
+                                         const WCHAR* name) DECLSPEC_HIDDEN;
 extern struct module*
                     module_find_by_nameA(const struct process* pcs,
-                                         const char* name);
+                                         const char* name) DECLSPEC_HIDDEN;
 extern struct module*
                     module_is_already_loaded(const struct process* pcs,
-                                             const WCHAR* imgname);
-extern BOOL         module_get_debug(struct module_pair*);
+                                             const WCHAR* imgname) DECLSPEC_HIDDEN;
+extern BOOL         module_get_debug(struct module_pair*) DECLSPEC_HIDDEN;
 extern struct module*
                     module_new(struct process* pcs, const WCHAR* name,
                                enum module_type type, BOOL virtual,
                                DWORD64 addr, DWORD64 size,
-                               unsigned long stamp, unsigned long checksum);
+                               unsigned long stamp, unsigned long checksum) DECLSPEC_HIDDEN;
 extern struct module*
                     module_get_containee(const struct process* pcs,
-                                         const struct module* inner);
+                                         const struct module* inner) DECLSPEC_HIDDEN;
 extern enum module_type
-                    module_get_type_by_name(const WCHAR* name);
-extern void         module_reset_debug_info(struct module* module);
+                    module_get_type_by_name(const WCHAR* name) DECLSPEC_HIDDEN;
+extern void         module_reset_debug_info(struct module* module) DECLSPEC_HIDDEN;
 extern BOOL         module_remove(struct process* pcs,
-                                  struct module* module);
-extern void         module_set_module(struct module* module, const WCHAR* name);
+                                  struct module* module) DECLSPEC_HIDDEN;
+extern void         module_set_module(struct module* module, const WCHAR* name) DECLSPEC_HIDDEN;
+extern const WCHAR *get_wine_loader_name(void) DECLSPEC_HIDDEN;
 
 /* msc.c */
 extern BOOL         pe_load_debug_directory(const struct process* pcs,
                                             struct module* module, 
                                             const BYTE* mapping,
                                             const IMAGE_SECTION_HEADER* sectp, DWORD nsect,
-                                            const IMAGE_DEBUG_DIRECTORY* dbg, int nDbg);
-extern BOOL         pdb_fetch_file_info(struct pdb_lookup* pdb_lookup);
+                                            const IMAGE_DEBUG_DIRECTORY* dbg, int nDbg) DECLSPEC_HIDDEN;
+extern BOOL         pdb_fetch_file_info(const struct pdb_lookup* pdb_lookup, unsigned* matched) DECLSPEC_HIDDEN;
+struct pdb_cmd_pair {
+    const char*         name;
+    DWORD*              pvalue;
+};
+extern BOOL         pdb_virtual_unwind(struct cpu_stack_walk* csw, DWORD_PTR ip,
+                                       CONTEXT* context, struct pdb_cmd_pair* cpair) DECLSPEC_HIDDEN;
 
 /* path.c */
 extern BOOL         path_find_symbol_file(const struct process* pcs, PCSTR full_path,
                                           const GUID* guid, DWORD dw1, DWORD dw2, PSTR buffer,
-                                          BOOL* is_unmatched);
+                                          BOOL* is_unmatched) DECLSPEC_HIDDEN;
 
 /* pe_module.c */
-extern BOOL         pe_load_nt_header(HANDLE hProc, DWORD64 base, IMAGE_NT_HEADERS* nth);
+extern BOOL         pe_load_nt_header(HANDLE hProc, DWORD64 base, IMAGE_NT_HEADERS* nth) DECLSPEC_HIDDEN;
 extern struct module*
                     pe_load_native_module(struct process* pcs, const WCHAR* name,
-                                          HANDLE hFile, DWORD base, DWORD size);
+                                          HANDLE hFile, DWORD64 base, DWORD size) DECLSPEC_HIDDEN;
 extern struct module*
                     pe_load_builtin_module(struct process* pcs, const WCHAR* name,
-                                           DWORD64 base, DWORD64 size);
+                                           DWORD64 base, DWORD64 size) DECLSPEC_HIDDEN;
 extern BOOL         pe_load_debug_info(const struct process* pcs,
-                                       struct module* module);
-extern const char*  pe_map_directory(struct module* module, int dirno, DWORD* size);
-extern void         pe_unmap_directoy(struct module* module, int dirno);
+                                       struct module* module) DECLSPEC_HIDDEN;
+extern const char*  pe_map_directory(struct module* module, int dirno, DWORD* size) DECLSPEC_HIDDEN;
+extern void         pe_unmap_directoy(struct module* module, int dirno) DECLSPEC_HIDDEN;
 
 /* source.c */
-extern unsigned     source_new(struct module* module, const char* basedir, const char* source);
-extern const char*  source_get(const struct module* module, unsigned idx);
+extern unsigned     source_new(struct module* module, const char* basedir, const char* source) DECLSPEC_HIDDEN;
+extern const char*  source_get(const struct module* module, unsigned idx) DECLSPEC_HIDDEN;
 
 /* stabs.c */
 typedef void (*stabs_def_cb)(struct module* module, unsigned long load_offset,
@@ -598,132 +682,136 @@ typedef void (*stabs_def_cb)(struct module* module, unsigned long load_offset,
 extern BOOL         stabs_parse(struct module* module, unsigned long load_offset,
                                 const void* stabs, int stablen,
                                 const char* strs, int strtablen,
-                                stabs_def_cb callback, void* user);
+                                stabs_def_cb callback, void* user) DECLSPEC_HIDDEN;
 
 /* dwarf.c */
 extern BOOL         dwarf2_parse(struct module* module, unsigned long load_offset,
                                  const struct elf_thunk_area* thunks,
-                                 struct image_file_map* fmap);
+                                 struct image_file_map* fmap) DECLSPEC_HIDDEN;
 extern BOOL         dwarf2_virtual_unwind(struct cpu_stack_walk* csw, DWORD_PTR ip,
-                                          CONTEXT* context, ULONG_PTR* cfa);
+                                          CONTEXT* context, ULONG_PTR* cfa) DECLSPEC_HIDDEN;
 
 /* stack.c */
-extern BOOL         sw_read_mem(struct cpu_stack_walk* csw, DWORD64 addr, void* ptr, DWORD sz);
-extern DWORD64      sw_xlat_addr(struct cpu_stack_walk* csw, ADDRESS64* addr);
-extern void*        sw_table_access(struct cpu_stack_walk* csw, DWORD64 addr);
-extern DWORD64      sw_module_base(struct cpu_stack_walk* csw, DWORD64 addr);
+#ifndef DBGHELP_STATIC_LIB
+extern BOOL         sw_read_mem(struct cpu_stack_walk* csw, DWORD64 addr, void* ptr, DWORD sz) DECLSPEC_HIDDEN;
+#endif
+extern DWORD64      sw_xlat_addr(struct cpu_stack_walk* csw, ADDRESS64* addr) DECLSPEC_HIDDEN;
+extern void*        sw_table_access(struct cpu_stack_walk* csw, DWORD64 addr) DECLSPEC_HIDDEN;
+extern DWORD64      sw_module_base(struct cpu_stack_walk* csw, DWORD64 addr) DECLSPEC_HIDDEN;
 
 /* symbol.c */
-extern const char*  symt_get_name(const struct symt* sym);
-extern struct module* symt_cmp_addr_module;
-extern int          symt_cmp_addr(const void* p1, const void* p2);
-extern void         copy_symbolW(SYMBOL_INFOW* siw, const SYMBOL_INFO* si);
+extern const char*  symt_get_name(const struct symt* sym) DECLSPEC_HIDDEN;
+extern WCHAR*       symt_get_nameW(const struct symt* sym) DECLSPEC_HIDDEN;
+extern BOOL         symt_get_address(const struct symt* type, ULONG64* addr) DECLSPEC_HIDDEN;
+extern int          symt_cmp_addr(const void* p1, const void* p2) DECLSPEC_HIDDEN;
+extern void         copy_symbolW(SYMBOL_INFOW* siw, const SYMBOL_INFO* si) DECLSPEC_HIDDEN;
 extern struct symt_ht*
-                    symt_find_nearest(struct module* module, DWORD_PTR addr);
+                    symt_find_nearest(struct module* module, DWORD_PTR addr) DECLSPEC_HIDDEN;
 extern struct symt_compiland*
                     symt_new_compiland(struct module* module, unsigned long address,
-                                       unsigned src_idx);
+                                       unsigned src_idx) DECLSPEC_HIDDEN;
 extern struct symt_public*
                     symt_new_public(struct module* module, 
                                     struct symt_compiland* parent, 
                                     const char* typename,
-                                    unsigned long address, unsigned size);
+                                    unsigned long address, unsigned size) DECLSPEC_HIDDEN;
 extern struct symt_data*
                     symt_new_global_variable(struct module* module, 
                                              struct symt_compiland* parent,
                                              const char* name, unsigned is_static,
-                                             unsigned long addr, unsigned long size, 
-                                             struct symt* type);
+                                             struct location loc, unsigned long size,
+                                             struct symt* type) DECLSPEC_HIDDEN;
 extern struct symt_function*
                     symt_new_function(struct module* module,
                                       struct symt_compiland* parent,
                                       const char* name,
                                       unsigned long addr, unsigned long size,
-                                      struct symt* type);
+                                      struct symt* type) DECLSPEC_HIDDEN;
 extern BOOL         symt_normalize_function(struct module* module, 
-                                            const struct symt_function* func);
+                                            const struct symt_function* func) DECLSPEC_HIDDEN;
 extern void         symt_add_func_line(struct module* module,
                                        struct symt_function* func, 
                                        unsigned source_idx, int line_num, 
-                                       unsigned long offset);
+                                       unsigned long offset) DECLSPEC_HIDDEN;
 extern struct symt_data*
                     symt_add_func_local(struct module* module, 
                                         struct symt_function* func, 
                                         enum DataKind dt, const struct location* loc,
                                         struct symt_block* block,
-                                        struct symt* type, const char* name);
+                                        struct symt* type, const char* name) DECLSPEC_HIDDEN;
 extern struct symt_block*
                     symt_open_func_block(struct module* module, 
                                          struct symt_function* func,
                                          struct symt_block* block, 
-                                         unsigned pc, unsigned len);
+                                         unsigned pc, unsigned len) DECLSPEC_HIDDEN;
 extern struct symt_block*
                     symt_close_func_block(struct module* module, 
                                           const struct symt_function* func,
-                                          struct symt_block* block, unsigned pc);
+                                          struct symt_block* block, unsigned pc) DECLSPEC_HIDDEN;
 extern struct symt_hierarchy_point*
                     symt_add_function_point(struct module* module, 
                                             struct symt_function* func,
                                             enum SymTagEnum point, 
                                             const struct location* loc,
-                                            const char* name);
+                                            const char* name) DECLSPEC_HIDDEN;
 extern BOOL         symt_fill_func_line_info(const struct module* module,
                                              const struct symt_function* func,
-                                             DWORD64 addr, IMAGEHLP_LINE64* line);
-extern BOOL         symt_get_func_line_next(const struct module* module, PIMAGEHLP_LINE64 line);
+                                             DWORD64 addr, IMAGEHLP_LINE64* line) DECLSPEC_HIDDEN;
+extern BOOL         symt_get_func_line_next(const struct module* module, PIMAGEHLP_LINE64 line) DECLSPEC_HIDDEN;
 extern struct symt_thunk*
                     symt_new_thunk(struct module* module, 
                                    struct symt_compiland* parent,
                                    const char* name, THUNK_ORDINAL ord,
-                                   unsigned long addr, unsigned long size);
+                                   unsigned long addr, unsigned long size) DECLSPEC_HIDDEN;
 extern struct symt_data*
                     symt_new_constant(struct module* module,
                                       struct symt_compiland* parent,
                                       const char* name, struct symt* type,
-                                      const VARIANT* v);
+                                      const VARIANT* v) DECLSPEC_HIDDEN;
 extern struct symt_hierarchy_point*
                     symt_new_label(struct module* module,
                                    struct symt_compiland* compiland,
-                                   const char* name, unsigned long address);
-extern struct symt* symt_index2ptr(struct module* module, DWORD id);
-extern DWORD        symt_ptr2index(struct module* module, const struct symt* sym);
+                                   const char* name, unsigned long address) DECLSPEC_HIDDEN;
+extern struct symt* symt_index2ptr(struct module* module, DWORD id) DECLSPEC_HIDDEN;
+extern DWORD        symt_ptr2index(struct module* module, const struct symt* sym) DECLSPEC_HIDDEN;
 
 /* type.c */
-extern void         symt_init_basic(struct module* module);
+extern void         symt_init_basic(struct module* module) DECLSPEC_HIDDEN;
 extern BOOL         symt_get_info(struct module* module, const struct symt* type,
-                                  IMAGEHLP_SYMBOL_TYPE_INFO req, void* pInfo);
+                                  IMAGEHLP_SYMBOL_TYPE_INFO req, void* pInfo) DECLSPEC_HIDDEN;
 extern struct symt_basic*
                     symt_new_basic(struct module* module, enum BasicType, 
-                                   const char* typename, unsigned size);
+                                   const char* typename, unsigned size) DECLSPEC_HIDDEN;
 extern struct symt_udt*
                     symt_new_udt(struct module* module, const char* typename,
-                                 unsigned size, enum UdtKind kind);
+                                 unsigned size, enum UdtKind kind) DECLSPEC_HIDDEN;
 extern BOOL         symt_set_udt_size(struct module* module,
-                                      struct symt_udt* type, unsigned size);
+                                      struct symt_udt* type, unsigned size) DECLSPEC_HIDDEN;
 extern BOOL         symt_add_udt_element(struct module* module, 
                                          struct symt_udt* udt_type, 
                                          const char* name,
                                          struct symt* elt_type, unsigned offset, 
-                                         unsigned size);
+                                         unsigned size) DECLSPEC_HIDDEN;
 extern struct symt_enum*
                     symt_new_enum(struct module* module, const char* typename,
-                                  struct symt* basetype);
+                                  struct symt* basetype) DECLSPEC_HIDDEN;
 extern BOOL         symt_add_enum_element(struct module* module, 
                                           struct symt_enum* enum_type, 
-                                          const char* name, int value);
+                                          const char* name, int value) DECLSPEC_HIDDEN;
 extern struct symt_array*
                     symt_new_array(struct module* module, int min, int max, 
-                                   struct symt* base, struct symt* index);
+                                   struct symt* base, struct symt* index) DECLSPEC_HIDDEN;
 extern struct symt_function_signature*
                     symt_new_function_signature(struct module* module, 
                                                 struct symt* ret_type,
-                                                enum CV_call_e call_conv);
+                                                enum CV_call_e call_conv) DECLSPEC_HIDDEN;
 extern BOOL         symt_add_function_signature_parameter(struct module* module,
                                                           struct symt_function_signature* sig,
-                                                          struct symt* param);
+                                                          struct symt* param) DECLSPEC_HIDDEN;
 extern struct symt_pointer*
                     symt_new_pointer(struct module* module, 
-                                     struct symt* ref_type);
+                                     struct symt* ref_type,
+                                     unsigned long size) DECLSPEC_HIDDEN;
 extern struct symt_typedef*
                     symt_new_typedef(struct module* module, struct symt* ref, 
-                                     const char* name);
+                                     const char* name) DECLSPEC_HIDDEN;