[MSI]
[reactos.git] / reactos / dll / win32 / dbghelp / dbghelp_private.h
1 /*
2 * File dbghelp_private.h - dbghelp internal definitions
3 *
4 * Copyright (C) 1995, Alexandre Julliard
5 * Copyright (C) 1996, Eric Youngdale.
6 * Copyright (C) 1999-2000, Ulrich Weigand.
7 * Copyright (C) 2004-2007, Eric Pouech.
8 *
9 * This library is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Lesser General Public
11 * License as published by the Free Software Foundation; either
12 * version 2.1 of the License, or (at your option) any later version.
13 *
14 * This library is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * Lesser General Public License for more details.
18 *
19 * You should have received a copy of the GNU Lesser General Public
20 * License along with this library; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
22 */
23
24 #include <stdarg.h>
25 #include "windef.h"
26 #include "winbase.h"
27 #include "winver.h"
28 #include "dbghelp.h"
29 #include "objbase.h"
30 #include "oaidl.h"
31 #include "winnls.h"
32 #include "wine/list.h"
33 #include "wine/unicode.h"
34
35 #include "cvconst.h"
36
37 /* #define USE_STATS */
38
39 struct pool /* poor's man */
40 {
41 struct list arena_list;
42 struct list arena_full;
43 size_t arena_size;
44 };
45
46 void pool_init(struct pool* a, size_t arena_size);
47 void pool_destroy(struct pool* a);
48 void* pool_alloc(struct pool* a, size_t len);
49 char* pool_strdup(struct pool* a, const char* str);
50
51 struct vector
52 {
53 void** buckets;
54 unsigned elt_size;
55 unsigned shift;
56 unsigned num_elts;
57 unsigned num_buckets;
58 unsigned buckets_allocated;
59 };
60
61 void vector_init(struct vector* v, unsigned elt_sz, unsigned bucket_sz);
62 unsigned vector_length(const struct vector* v);
63 void* vector_at(const struct vector* v, unsigned pos);
64 void* vector_add(struct vector* v, struct pool* pool);
65
66 struct sparse_array
67 {
68 struct vector key2index;
69 struct vector elements;
70 };
71
72 void sparse_array_init(struct sparse_array* sa, unsigned elt_sz, unsigned bucket_sz);
73 void* sparse_array_find(const struct sparse_array* sa, unsigned long idx);
74 void* sparse_array_add(struct sparse_array* sa, unsigned long key, struct pool* pool);
75 unsigned sparse_array_length(const struct sparse_array* sa);
76
77 struct hash_table_elt
78 {
79 const char* name;
80 struct hash_table_elt* next;
81 };
82
83 struct hash_table_bucket
84 {
85 struct hash_table_elt* first;
86 struct hash_table_elt* last;
87 };
88
89 struct hash_table
90 {
91 unsigned num_elts;
92 unsigned num_buckets;
93 struct hash_table_bucket* buckets;
94 struct pool* pool;
95 };
96
97 void hash_table_init(struct pool* pool, struct hash_table* ht,
98 unsigned num_buckets);
99 void hash_table_destroy(struct hash_table* ht);
100 void hash_table_add(struct hash_table* ht, struct hash_table_elt* elt);
101
102 struct hash_table_iter
103 {
104 const struct hash_table* ht;
105 struct hash_table_elt* element;
106 int index;
107 int last;
108 };
109
110 void hash_table_iter_init(const struct hash_table* ht,
111 struct hash_table_iter* hti, const char* name);
112 void* hash_table_iter_up(struct hash_table_iter* hti);
113
114 #define GET_ENTRY(__i, __t, __f) \
115 ((__t*)((char*)(__i) - FIELD_OFFSET(__t,__f)))
116
117
118 extern unsigned dbghelp_options;
119 /* some more Wine extensions */
120 #define SYMOPT_WINE_WITH_NATIVE_MODULES 0x40000000
121
122 enum location_kind {loc_error, /* reg is the error code */
123 loc_unavailable, /* location is not available */
124 loc_absolute, /* offset is the location */
125 loc_register, /* reg is the location */
126 loc_regrel, /* [reg+offset] is the location */
127 loc_user, /* value is debug information dependent,
128 reg & offset can be used ad libidem */
129 };
130
131 enum location_error {loc_err_internal = -1, /* internal while computing */
132 loc_err_too_complex = -2, /* couldn't compute location (even at runtime) */
133 loc_err_out_of_scope = -3, /* variable isn't available at current address */
134 loc_err_cant_read = -4, /* couldn't read memory at given address */
135 };
136
137 struct location
138 {
139 unsigned kind : 8,
140 reg;
141 unsigned long offset;
142 };
143
144 struct symt
145 {
146 enum SymTagEnum tag;
147 };
148
149 struct symt_ht
150 {
151 struct symt symt;
152 struct hash_table_elt hash_elt; /* if global symbol or type */
153 };
154
155 /* lexical tree */
156 struct symt_block
157 {
158 struct symt symt;
159 unsigned long address;
160 unsigned long size;
161 struct symt* container; /* block, or func */
162 struct vector vchildren; /* sub-blocks & local variables */
163 };
164
165 struct symt_compiland
166 {
167 struct symt symt;
168 unsigned long address;
169 unsigned source;
170 struct vector vchildren; /* global variables & functions */
171 };
172
173 struct symt_data
174 {
175 struct symt symt;
176 struct hash_table_elt hash_elt; /* if global symbol */
177 enum DataKind kind;
178 struct symt* container;
179 struct symt* type;
180 union /* depends on kind */
181 {
182 /* DataIs{Global, FileStatic}:
183 * loc.kind is loc_absolute
184 * loc.offset is address
185 * DataIs{Local,Param}:
186 * with loc.kind
187 * loc_absolute not supported
188 * loc_register location is in register loc.reg
189 * loc_regrel location is at address loc.reg + loc.offset
190 * >= loc_user ask debug info provider for resolution
191 */
192 struct location var;
193 /* DataIs{Member} (all values are in bits, not bytes) */
194 struct
195 {
196 long offset;
197 unsigned long length;
198 } member;
199 /* DataIsConstant */
200 VARIANT value;
201 } u;
202 };
203
204 struct symt_function
205 {
206 struct symt symt;
207 struct hash_table_elt hash_elt; /* if global symbol */
208 unsigned long address;
209 struct symt* container; /* compiland */
210 struct symt* type; /* points to function_signature */
211 unsigned long size;
212 struct vector vlines;
213 struct vector vchildren; /* locals, params, blocks, start/end, labels */
214 };
215
216 struct symt_hierarchy_point
217 {
218 struct symt symt; /* either SymTagFunctionDebugStart, SymTagFunctionDebugEnd, SymTagLabel */
219 struct hash_table_elt hash_elt; /* if label (and in compiland's hash table if global) */
220 struct symt* parent; /* symt_function or symt_compiland */
221 struct location loc;
222 };
223
224 struct symt_public
225 {
226 struct symt symt;
227 struct hash_table_elt hash_elt;
228 struct symt* container; /* compiland */
229 unsigned long address;
230 unsigned long size;
231 };
232
233 struct symt_thunk
234 {
235 struct symt symt;
236 struct hash_table_elt hash_elt;
237 struct symt* container; /* compiland */
238 unsigned long address;
239 unsigned long size;
240 THUNK_ORDINAL ordinal; /* FIXME: doesn't seem to be accessible */
241 };
242
243 /* class tree */
244 struct symt_array
245 {
246 struct symt symt;
247 int start;
248 int end; /* end index if > 0, or -array_len (in bytes) if < 0 */
249 struct symt* base_type;
250 struct symt* index_type;
251 };
252
253 struct symt_basic
254 {
255 struct symt symt;
256 struct hash_table_elt hash_elt;
257 enum BasicType bt;
258 unsigned long size;
259 };
260
261 struct symt_enum
262 {
263 struct symt symt;
264 struct symt* base_type;
265 const char* name;
266 struct vector vchildren;
267 };
268
269 struct symt_function_signature
270 {
271 struct symt symt;
272 struct symt* rettype;
273 struct vector vchildren;
274 enum CV_call_e call_conv;
275 };
276
277 struct symt_function_arg_type
278 {
279 struct symt symt;
280 struct symt* arg_type;
281 struct symt* container;
282 };
283
284 struct symt_pointer
285 {
286 struct symt symt;
287 struct symt* pointsto;
288 };
289
290 struct symt_typedef
291 {
292 struct symt symt;
293 struct hash_table_elt hash_elt;
294 struct symt* type;
295 };
296
297 struct symt_udt
298 {
299 struct symt symt;
300 struct hash_table_elt hash_elt;
301 enum UdtKind kind;
302 int size;
303 struct vector vchildren;
304 };
305
306 enum module_type
307 {
308 DMT_UNKNOWN, /* for lookup, not actually used for a module */
309 DMT_ELF, /* a real ELF shared module */
310 DMT_PE, /* a native or builtin PE module */
311 DMT_MACHO, /* a real Mach-O shared module */
312 DMT_PDB, /* .PDB file */
313 DMT_DBG, /* .DBG file */
314 };
315
316 struct process;
317 struct module;
318
319 /* a module can be made of several debug information formats, so we have to
320 * support them all
321 */
322 enum format_info
323 {
324 DFI_ELF,
325 DFI_PE,
326 DFI_MACHO,
327 DFI_DWARF,
328 DFI_LAST
329 };
330
331 struct module_format
332 {
333 struct module* module;
334 void (*remove)(struct process* pcs, struct module_format* modfmt);
335 void (*loc_compute)(struct process* pcs,
336 const struct module_format* modfmt,
337 const struct symt_function* func,
338 struct location* loc);
339 union
340 {
341 struct elf_module_info* elf_info;
342 struct dwarf2_module_info_s* dwarf2_info;
343 struct pe_module_info* pe_info;
344 struct macho_module_info* macho_info;
345 } u;
346 };
347
348 struct module
349 {
350 struct process* process;
351 IMAGEHLP_MODULEW64 module;
352 /* ANSI copy of module.ModuleName for efficiency */
353 char module_name[MAX_PATH];
354 struct module* next;
355 enum module_type type : 16;
356 unsigned short is_virtual : 1;
357 DWORD64 reloc_delta;
358
359 /* specific information for debug types */
360 struct module_format* format_info[DFI_LAST];
361
362 /* memory allocation pool */
363 struct pool pool;
364
365 /* symbols & symbol tables */
366 struct vector vsymt;
367 int sortlist_valid;
368 unsigned num_sorttab; /* number of symbols with addresses */
369 unsigned num_symbols;
370 unsigned sorttab_size;
371 struct symt_ht** addr_sorttab;
372 struct hash_table ht_symbols;
373
374 /* types */
375 struct hash_table ht_types;
376 struct vector vtypes;
377
378 /* source files */
379 unsigned sources_used;
380 unsigned sources_alloc;
381 char* sources;
382 };
383
384 struct process
385 {
386 struct process* next;
387 HANDLE handle;
388 WCHAR* search_path;
389
390 PSYMBOL_REGISTERED_CALLBACK64 reg_cb;
391 PSYMBOL_REGISTERED_CALLBACK reg_cb32;
392 BOOL reg_is_unicode;
393 DWORD64 reg_user;
394
395 struct module* lmodules;
396 unsigned long dbg_hdr_addr;
397
398 IMAGEHLP_STACK_FRAME ctx_frame;
399
400 unsigned buffer_size;
401 void* buffer;
402 };
403
404 struct line_info
405 {
406 unsigned long is_first : 1,
407 is_last : 1,
408 is_source_file : 1,
409 line_number;
410 union
411 {
412 unsigned long pc_offset; /* if is_source_file isn't set */
413 unsigned source_file; /* if is_source_file is set */
414 } u;
415 };
416
417 struct module_pair
418 {
419 struct process* pcs;
420 struct module* requested; /* in: to module_get_debug() */
421 struct module* effective; /* out: module with debug info */
422 };
423
424 enum pdb_kind {PDB_JG, PDB_DS};
425
426 struct pdb_lookup
427 {
428 const char* filename;
429 DWORD age;
430 enum pdb_kind kind;
431 union
432 {
433 struct
434 {
435 DWORD timestamp;
436 struct PDB_JG_TOC* toc;
437 } jg;
438 struct
439 {
440 GUID guid;
441 struct PDB_DS_TOC* toc;
442 } ds;
443 } u;
444 };
445
446 struct cpu_stack_walk
447 {
448 HANDLE hProcess;
449 HANDLE hThread;
450 BOOL is32;
451 union
452 {
453 struct
454 {
455 PREAD_PROCESS_MEMORY_ROUTINE f_read_mem;
456 PTRANSLATE_ADDRESS_ROUTINE f_xlat_adr;
457 PFUNCTION_TABLE_ACCESS_ROUTINE f_tabl_acs;
458 PGET_MODULE_BASE_ROUTINE f_modl_bas;
459 } s32;
460 struct
461 {
462 PREAD_PROCESS_MEMORY_ROUTINE64 f_read_mem;
463 PTRANSLATE_ADDRESS_ROUTINE64 f_xlat_adr;
464 PFUNCTION_TABLE_ACCESS_ROUTINE64 f_tabl_acs;
465 PGET_MODULE_BASE_ROUTINE64 f_modl_bas;
466 } s64;
467 } u;
468 };
469
470 enum cpu_addr {cpu_addr_pc, cpu_addr_stack, cpu_addr_frame};
471 struct cpu
472 {
473 DWORD machine;
474 DWORD word_size;
475 /* address manipulation */
476 unsigned (*get_addr)(HANDLE hThread, const CONTEXT* ctx,
477 enum cpu_addr, ADDRESS64* addr);
478
479 /* stack manipulation */
480 BOOL (*stack_walk)(struct cpu_stack_walk* csw, LPSTACKFRAME64 frame, CONTEXT* context);
481
482 /* module manipulation */
483 void* (*find_runtime_function)(struct module*, DWORD64 addr);
484
485 /* dwarf dedicated information */
486 unsigned (*map_dwarf_register)(unsigned regno);
487
488 /* context related maniputation */
489 void* (*fetch_context_reg)(CONTEXT* context, unsigned regno, unsigned* size);
490 const char* (*fetch_regname)(unsigned regno);
491 };
492
493 extern struct cpu* dbghelp_current_cpu;
494
495 /* dbghelp.c */
496 extern struct process* process_find_by_handle(HANDLE hProcess);
497 extern HANDLE hMsvcrt;
498 extern BOOL validate_addr64(DWORD64 addr);
499 extern BOOL pcs_callback(const struct process* pcs, ULONG action, void* data);
500 extern void* fetch_buffer(struct process* pcs, unsigned size);
501 extern const char* wine_dbgstr_addr(const ADDRESS64* addr);
502 extern struct cpu* cpu_find(DWORD);
503
504 /* crc32.c */
505 extern DWORD calc_crc32(int fd);
506
507 typedef BOOL (*enum_modules_cb)(const WCHAR*, unsigned long addr, void* user);
508
509 /* elf_module.c */
510 extern BOOL elf_enum_modules(HANDLE hProc, enum_modules_cb, void*);
511 extern BOOL elf_fetch_file_info(const WCHAR* name, DWORD* base, DWORD* size, DWORD* checksum);
512 struct image_file_map;
513 extern BOOL elf_load_debug_info(struct module* module, struct image_file_map* fmap);
514 extern struct module*
515 elf_load_module(struct process* pcs, const WCHAR* name, unsigned long);
516 extern BOOL elf_read_wine_loader_dbg_info(struct process* pcs);
517 extern BOOL elf_synchronize_module_list(struct process* pcs);
518 struct elf_thunk_area;
519 extern int elf_is_in_thunk_area(unsigned long addr, const struct elf_thunk_area* thunks);
520
521 /* macho_module.c */
522 #define MACHO_NO_MAP ((const void*)-1)
523 extern BOOL macho_enum_modules(HANDLE hProc, enum_modules_cb, void*);
524 extern BOOL macho_fetch_file_info(const WCHAR* name, DWORD* base, DWORD* size, DWORD* checksum);
525 struct macho_file_map;
526 extern BOOL macho_load_debug_info(struct module* module, struct macho_file_map* fmap);
527 extern struct module*
528 macho_load_module(struct process* pcs, const WCHAR* name, unsigned long);
529 extern BOOL macho_read_wine_loader_dbg_info(struct process* pcs);
530 extern BOOL macho_synchronize_module_list(struct process* pcs);
531
532 /* module.c */
533 extern const WCHAR S_ElfW[];
534 extern const WCHAR S_WineLoaderW[];
535 extern const WCHAR S_WineW[];
536 extern const WCHAR S_SlashW[];
537
538 extern struct module*
539 module_find_by_addr(const struct process* pcs, unsigned long addr,
540 enum module_type type);
541 extern struct module*
542 module_find_by_nameA(const struct process* pcs,
543 const char* name);
544 extern struct module*
545 module_is_already_loaded(const struct process* pcs,
546 const WCHAR* imgname);
547 extern BOOL module_get_debug(struct module_pair*);
548 extern struct module*
549 module_new(struct process* pcs, const WCHAR* name,
550 enum module_type type, BOOL virtual,
551 DWORD64 addr, DWORD64 size,
552 unsigned long stamp, unsigned long checksum);
553 extern struct module*
554 module_get_containee(const struct process* pcs,
555 const struct module* inner);
556 extern enum module_type
557 module_get_type_by_name(const WCHAR* name);
558 extern void module_reset_debug_info(struct module* module);
559 extern BOOL module_remove(struct process* pcs,
560 struct module* module);
561 extern void module_set_module(struct module* module, const WCHAR* name);
562
563 /* msc.c */
564 extern BOOL pe_load_debug_directory(const struct process* pcs,
565 struct module* module,
566 const BYTE* mapping,
567 const IMAGE_SECTION_HEADER* sectp, DWORD nsect,
568 const IMAGE_DEBUG_DIRECTORY* dbg, int nDbg);
569 extern BOOL pdb_fetch_file_info(struct pdb_lookup* pdb_lookup);
570
571 /* path.c */
572 extern BOOL path_find_symbol_file(const struct process* pcs, PCSTR full_path,
573 const GUID* guid, DWORD dw1, DWORD dw2, PSTR buffer,
574 BOOL* is_unmatched);
575
576 /* pe_module.c */
577 extern BOOL pe_load_nt_header(HANDLE hProc, DWORD64 base, IMAGE_NT_HEADERS* nth);
578 extern struct module*
579 pe_load_native_module(struct process* pcs, const WCHAR* name,
580 HANDLE hFile, DWORD base, DWORD size);
581 extern struct module*
582 pe_load_builtin_module(struct process* pcs, const WCHAR* name,
583 DWORD64 base, DWORD64 size);
584 extern BOOL pe_load_debug_info(const struct process* pcs,
585 struct module* module);
586 extern const char* pe_map_directory(struct module* module, int dirno, DWORD* size);
587 extern void pe_unmap_directoy(struct module* module, int dirno);
588
589 /* source.c */
590 extern unsigned source_new(struct module* module, const char* basedir, const char* source);
591 extern const char* source_get(const struct module* module, unsigned idx);
592
593 /* stabs.c */
594 typedef void (*stabs_def_cb)(struct module* module, unsigned long load_offset,
595 const char* name, unsigned long offset,
596 BOOL is_public, BOOL is_global, unsigned char other,
597 struct symt_compiland* compiland, void* user);
598 extern BOOL stabs_parse(struct module* module, unsigned long load_offset,
599 const void* stabs, int stablen,
600 const char* strs, int strtablen,
601 stabs_def_cb callback, void* user);
602
603 /* dwarf.c */
604 extern BOOL dwarf2_parse(struct module* module, unsigned long load_offset,
605 const struct elf_thunk_area* thunks,
606 struct image_file_map* fmap);
607 extern BOOL dwarf2_virtual_unwind(struct cpu_stack_walk* csw, DWORD_PTR ip,
608 CONTEXT* context, ULONG_PTR* cfa);
609
610 /* stack.c */
611 extern BOOL sw_read_mem(struct cpu_stack_walk* csw, DWORD64 addr, void* ptr, DWORD sz);
612 extern DWORD64 sw_xlat_addr(struct cpu_stack_walk* csw, ADDRESS64* addr);
613 extern void* sw_table_access(struct cpu_stack_walk* csw, DWORD64 addr);
614 extern DWORD64 sw_module_base(struct cpu_stack_walk* csw, DWORD64 addr);
615
616 /* symbol.c */
617 extern const char* symt_get_name(const struct symt* sym);
618 extern struct module* symt_cmp_addr_module;
619 extern int symt_cmp_addr(const void* p1, const void* p2);
620 extern void copy_symbolW(SYMBOL_INFOW* siw, const SYMBOL_INFO* si);
621 extern struct symt_ht*
622 symt_find_nearest(struct module* module, DWORD_PTR addr);
623 extern struct symt_compiland*
624 symt_new_compiland(struct module* module, unsigned long address,
625 unsigned src_idx);
626 extern struct symt_public*
627 symt_new_public(struct module* module,
628 struct symt_compiland* parent,
629 const char* typename,
630 unsigned long address, unsigned size);
631 extern struct symt_data*
632 symt_new_global_variable(struct module* module,
633 struct symt_compiland* parent,
634 const char* name, unsigned is_static,
635 unsigned long addr, unsigned long size,
636 struct symt* type);
637 extern struct symt_function*
638 symt_new_function(struct module* module,
639 struct symt_compiland* parent,
640 const char* name,
641 unsigned long addr, unsigned long size,
642 struct symt* type);
643 extern BOOL symt_normalize_function(struct module* module,
644 const struct symt_function* func);
645 extern void symt_add_func_line(struct module* module,
646 struct symt_function* func,
647 unsigned source_idx, int line_num,
648 unsigned long offset);
649 extern struct symt_data*
650 symt_add_func_local(struct module* module,
651 struct symt_function* func,
652 enum DataKind dt, const struct location* loc,
653 struct symt_block* block,
654 struct symt* type, const char* name);
655 extern struct symt_block*
656 symt_open_func_block(struct module* module,
657 struct symt_function* func,
658 struct symt_block* block,
659 unsigned pc, unsigned len);
660 extern struct symt_block*
661 symt_close_func_block(struct module* module,
662 const struct symt_function* func,
663 struct symt_block* block, unsigned pc);
664 extern struct symt_hierarchy_point*
665 symt_add_function_point(struct module* module,
666 struct symt_function* func,
667 enum SymTagEnum point,
668 const struct location* loc,
669 const char* name);
670 extern BOOL symt_fill_func_line_info(const struct module* module,
671 const struct symt_function* func,
672 DWORD64 addr, IMAGEHLP_LINE64* line);
673 extern BOOL symt_get_func_line_next(const struct module* module, PIMAGEHLP_LINE64 line);
674 extern struct symt_thunk*
675 symt_new_thunk(struct module* module,
676 struct symt_compiland* parent,
677 const char* name, THUNK_ORDINAL ord,
678 unsigned long addr, unsigned long size);
679 extern struct symt_data*
680 symt_new_constant(struct module* module,
681 struct symt_compiland* parent,
682 const char* name, struct symt* type,
683 const VARIANT* v);
684 extern struct symt_hierarchy_point*
685 symt_new_label(struct module* module,
686 struct symt_compiland* compiland,
687 const char* name, unsigned long address);
688 extern struct symt* symt_index2ptr(struct module* module, DWORD id);
689 extern DWORD symt_ptr2index(struct module* module, const struct symt* sym);
690
691 /* type.c */
692 extern void symt_init_basic(struct module* module);
693 extern BOOL symt_get_info(struct module* module, const struct symt* type,
694 IMAGEHLP_SYMBOL_TYPE_INFO req, void* pInfo);
695 extern struct symt_basic*
696 symt_new_basic(struct module* module, enum BasicType,
697 const char* typename, unsigned size);
698 extern struct symt_udt*
699 symt_new_udt(struct module* module, const char* typename,
700 unsigned size, enum UdtKind kind);
701 extern BOOL symt_set_udt_size(struct module* module,
702 struct symt_udt* type, unsigned size);
703 extern BOOL symt_add_udt_element(struct module* module,
704 struct symt_udt* udt_type,
705 const char* name,
706 struct symt* elt_type, unsigned offset,
707 unsigned size);
708 extern struct symt_enum*
709 symt_new_enum(struct module* module, const char* typename,
710 struct symt* basetype);
711 extern BOOL symt_add_enum_element(struct module* module,
712 struct symt_enum* enum_type,
713 const char* name, int value);
714 extern struct symt_array*
715 symt_new_array(struct module* module, int min, int max,
716 struct symt* base, struct symt* index);
717 extern struct symt_function_signature*
718 symt_new_function_signature(struct module* module,
719 struct symt* ret_type,
720 enum CV_call_e call_conv);
721 extern BOOL symt_add_function_signature_parameter(struct module* module,
722 struct symt_function_signature* sig,
723 struct symt* param);
724 extern struct symt_pointer*
725 symt_new_pointer(struct module* module,
726 struct symt* ref_type);
727 extern struct symt_typedef*
728 symt_new_typedef(struct module* module, struct symt* ref,
729 const char* name);