Import VBCC source snapshot (29/04/2022)
diff --git a/dwarf2.c b/dwarf2.c
new file mode 100644
index 0000000..281deb3
--- /dev/null
+++ b/dwarf2.c
@@ -0,0 +1,1294 @@
+/*  $VER: vbcc (dwarf2.c) $Revision: 1.5 $     */
+
+enum dwarf_tag
+{
+  DW_TAG_padding = 0x00,
+  DW_TAG_array_type = 0x01,
+  DW_TAG_class_type = 0x02,
+  DW_TAG_entry_point = 0x03,
+  DW_TAG_enumeration_type = 0x04,
+  DW_TAG_formal_parameter = 0x05,
+  DW_TAG_imported_declaration = 0x08,
+  DW_TAG_label = 0x0a,
+  DW_TAG_lexical_block = 0x0b,
+  DW_TAG_member = 0x0d,
+  DW_TAG_pointer_type = 0x0f,
+  DW_TAG_reference_type = 0x10,
+  DW_TAG_compile_unit = 0x11,
+  DW_TAG_string_type = 0x12,
+  DW_TAG_structure_type = 0x13,
+  DW_TAG_subroutine_type = 0x15,
+  DW_TAG_typedef = 0x16,
+  DW_TAG_union_type = 0x17,
+  DW_TAG_unspecified_parameters = 0x18,
+  DW_TAG_variant = 0x19,
+  DW_TAG_common_block = 0x1a,
+  DW_TAG_common_inclusion = 0x1b,
+  DW_TAG_inheritance = 0x1c,
+  DW_TAG_inlined_subroutine = 0x1d,
+  DW_TAG_module = 0x1e,
+  DW_TAG_ptr_to_member_type = 0x1f,
+  DW_TAG_set_type = 0x20,
+  DW_TAG_subrange_type = 0x21,
+  DW_TAG_with_stmt = 0x22,
+  DW_TAG_access_declaration = 0x23,
+  DW_TAG_base_type = 0x24,
+  DW_TAG_catch_block = 0x25,
+  DW_TAG_const_type = 0x26,
+  DW_TAG_constant = 0x27,
+  DW_TAG_enumerator = 0x28,
+  DW_TAG_file_type = 0x29,
+  DW_TAG_friend = 0x2a,
+  DW_TAG_namelist = 0x2b,
+  DW_TAG_namelist_item = 0x2c,
+  DW_TAG_packed_type = 0x2d,
+  DW_TAG_subprogram = 0x2e,
+  DW_TAG_template_type_param = 0x2f,
+  DW_TAG_template_value_param = 0x30,
+  DW_TAG_thrown_type = 0x31,
+  DW_TAG_try_block = 0x32,
+  DW_TAG_variant_part = 0x33,
+  DW_TAG_variable = 0x34,
+  DW_TAG_volatile_type = 0x35,
+  /* SGI/MIPS Extensions */
+  DW_TAG_MIPS_loop = 0x4081,
+  /* GNU extensions */
+  DW_TAG_format_label = 0x4101,
+  DW_TAG_function_template = 0x4102,
+  DW_TAG_class_template = 0x4103
+};
+
+enum dwarf_children
+{
+  DW_children_no = 0,
+  DW_children_yes = 1
+};
+
+enum dwarf_form
+{
+  DW_FORM_addr = 0x01,
+  DW_FORM_block2 = 0x03,
+  DW_FORM_block4 = 0x04,
+  DW_FORM_data2 = 0x05,
+  DW_FORM_data4 = 0x06,
+  DW_FORM_data8 = 0x07,
+  DW_FORM_string = 0x08,
+  DW_FORM_block = 0x09,
+  DW_FORM_block1 = 0x0a,
+  DW_FORM_data1 = 0x0b,
+  DW_FORM_flag = 0x0c,
+  DW_FORM_sdata = 0x0d,
+  DW_FORM_strp = 0x0e,
+  DW_FORM_udata = 0x0f,
+  DW_FORM_ref_addr = 0x10,
+  DW_FORM_ref1 = 0x11,
+  DW_FORM_ref2 = 0x12,
+  DW_FORM_ref4 = 0x13,
+  DW_FORM_ref8 = 0x14,
+  DW_FORM_ref_udata = 0x15,
+  DW_FORM_indirect = 0x16
+};
+
+enum dwarf_attribute
+{
+  DW_AT_sibling = 0x01,
+  DW_AT_location = 0x02,
+  DW_AT_name = 0x03,
+  DW_AT_ordering = 0x09,
+  DW_AT_subscr_data = 0x0a,
+  DW_AT_byte_size = 0x0b,
+  DW_AT_bit_offset = 0x0c,
+  DW_AT_bit_size = 0x0d,
+  DW_AT_element_list = 0x0f,
+  DW_AT_stmt_list = 0x10,
+  DW_AT_low_pc = 0x11,
+  DW_AT_high_pc = 0x12,
+  DW_AT_language = 0x13,
+  DW_AT_member = 0x14,
+  DW_AT_discr = 0x15,
+  DW_AT_discr_value = 0x16,
+  DW_AT_visibility = 0x17,
+  DW_AT_import = 0x18,
+  DW_AT_string_length = 0x19,
+  DW_AT_common_reference = 0x1a,
+  DW_AT_comp_dir = 0x1b,
+  DW_AT_const_value = 0x1c,
+  DW_AT_containing_type = 0x1d,
+  DW_AT_default_value = 0x1e,
+  DW_AT_inline = 0x20,
+  DW_AT_is_optional = 0x21,
+  DW_AT_lower_bound = 0x22,
+  DW_AT_producer = 0x25,
+  DW_AT_prototyped = 0x27,
+  DW_AT_return_addr = 0x2a,
+  DW_AT_start_scope = 0x2c,
+  DW_AT_stride_size = 0x2e,
+  DW_AT_upper_bound = 0x2f,
+  DW_AT_abstract_origin = 0x31,
+  DW_AT_accessibility = 0x32,
+  DW_AT_address_class = 0x33,
+  DW_AT_artificial = 0x34,
+  DW_AT_base_types = 0x35,
+  DW_AT_calling_convention = 0x36,
+  DW_AT_count = 0x37,
+  DW_AT_data_member_location = 0x38,
+  DW_AT_decl_column = 0x39,
+  DW_AT_decl_file = 0x3a,
+  DW_AT_decl_line = 0x3b,
+  DW_AT_declaration = 0x3c,
+  DW_AT_discr_list = 0x3d,
+  DW_AT_encoding = 0x3e,
+  DW_AT_external = 0x3f,
+  DW_AT_frame_base = 0x40,
+  DW_AT_friend = 0x41,
+  DW_AT_identifier_case = 0x42,
+  DW_AT_macro_info = 0x43,
+  DW_AT_namelist_items = 0x44,
+  DW_AT_priority = 0x45,
+  DW_AT_segment = 0x46,
+  DW_AT_specification = 0x47,
+  DW_AT_static_link = 0x48,
+  DW_AT_type = 0x49,
+  DW_AT_use_location = 0x4a,
+  DW_AT_variable_parameter = 0x4b,
+  DW_AT_virtuality = 0x4c,
+  DW_AT_vtable_elem_location = 0x4d,
+  DW_AT_MIPS_fde = 0x2001,
+  DW_AT_MIPS_loop_begin = 0x2002,
+  DW_AT_MIPS_tail_loop_begin = 0x2003,
+  DW_AT_MIPS_epilog_begin = 0x2004,
+  DW_AT_MIPS_loop_unroll_factor = 0x2005,
+  DW_AT_MIPS_software_pipeline_depth = 0x2006,
+  DW_AT_MIPS_linkage_name = 0x2007,
+  DW_AT_MIPS_stride = 0x2008,
+  DW_AT_MIPS_abstract_name = 0x2009,
+  DW_AT_MIPS_clone_origin = 0x200a,
+  DW_AT_MIPS_has_inlines = 0x200b,
+  /* GNU */
+  DW_AT_sf_names = 0x2101,
+  DW_AT_src_info = 0x2102,
+  DW_AT_mac_info = 0x2103,
+  DW_AT_src_coords = 0x2104,
+  DW_AT_body_begin = 0x2105,
+  DW_AT_body_end = 0x2106
+};
+
+enum dwarf_location_atom
+{
+  DW_OP_addr = 0x03,
+  DW_OP_deref = 0x06,
+  DW_OP_const1u = 0x08,
+  DW_OP_const1s = 0x09,
+  DW_OP_const2u = 0x0a,
+  DW_OP_const2s = 0x0b,
+  DW_OP_const4u = 0x0c,
+  DW_OP_const4s = 0x0d,
+  DW_OP_const8u = 0x0e,
+  DW_OP_const8s = 0x0f,
+  DW_OP_constu = 0x10,
+  DW_OP_consts = 0x11,
+  DW_OP_dup = 0x12,
+  DW_OP_drop = 0x13,
+  DW_OP_over = 0x14,
+  DW_OP_pick = 0x15,
+  DW_OP_swap = 0x16,
+  DW_OP_rot = 0x17,
+  DW_OP_xderef = 0x18,
+  DW_OP_abs = 0x19,
+  DW_OP_and = 0x1a,
+  DW_OP_div = 0x1b,
+  DW_OP_minus = 0x1c,
+  DW_OP_mod = 0x1d,
+  DW_OP_mul = 0x1e,
+  DW_OP_neg = 0x1f,
+  DW_OP_not = 0x20,
+  DW_OP_or = 0x21,
+  DW_OP_plus = 0x22,
+  DW_OP_plus_uconst = 0x23,
+  DW_OP_shl = 0x24,
+  DW_OP_shr = 0x25,
+  DW_OP_shra = 0x26,
+  DW_OP_xor = 0x27,
+  DW_OP_bra = 0x28,
+  DW_OP_eq = 0x29,
+  DW_OP_ge = 0x2a,
+  DW_OP_gt = 0x2b,
+  DW_OP_le = 0x2c,
+  DW_OP_lt = 0x2d,
+  DW_OP_ne = 0x2e,
+  DW_OP_skip = 0x2f,
+  DW_OP_lit0 = 0x30,
+  DW_OP_lit1 = 0x31,
+  DW_OP_lit2 = 0x32,
+  DW_OP_lit3 = 0x33,
+  DW_OP_lit4 = 0x34,
+  DW_OP_lit5 = 0x35,
+  DW_OP_lit6 = 0x36,
+  DW_OP_lit7 = 0x37,
+  DW_OP_lit8 = 0x38,
+  DW_OP_lit9 = 0x39,
+  DW_OP_lit10 = 0x3a,
+  DW_OP_lit11 = 0x3b,
+  DW_OP_lit12 = 0x3c,
+  DW_OP_lit13 = 0x3d,
+  DW_OP_lit14 = 0x3e,
+  DW_OP_lit15 = 0x3f,
+  DW_OP_lit16 = 0x40,
+  DW_OP_lit17 = 0x41,
+  DW_OP_lit18 = 0x42,
+  DW_OP_lit19 = 0x43,
+  DW_OP_lit20 = 0x44,
+  DW_OP_lit21 = 0x45,
+  DW_OP_lit22 = 0x46,
+  DW_OP_lit23 = 0x47,
+  DW_OP_lit24 = 0x48,
+  DW_OP_lit25 = 0x49,
+  DW_OP_lit26 = 0x4a,
+  DW_OP_lit27 = 0x4b,
+  DW_OP_lit28 = 0x4c,
+  DW_OP_lit29 = 0x4d,
+  DW_OP_lit30 = 0x4e,
+  DW_OP_lit31 = 0x4f,
+  DW_OP_reg0 = 0x50,
+  DW_OP_reg1 = 0x51,
+  DW_OP_reg2 = 0x52,
+  DW_OP_reg3 = 0x53,
+  DW_OP_reg4 = 0x54,
+  DW_OP_reg5 = 0x55,
+  DW_OP_reg6 = 0x56,
+  DW_OP_reg7 = 0x57,
+  DW_OP_reg8 = 0x58,
+  DW_OP_reg9 = 0x59,
+  DW_OP_reg10 = 0x5a,
+  DW_OP_reg11 = 0x5b,
+  DW_OP_reg12 = 0x5c,
+  DW_OP_reg13 = 0x5d,
+  DW_OP_reg14 = 0x5e,
+  DW_OP_reg15 = 0x5f,
+  DW_OP_reg16 = 0x60,
+  DW_OP_reg17 = 0x61,
+  DW_OP_reg18 = 0x62,
+  DW_OP_reg19 = 0x63,
+  DW_OP_reg20 = 0x64,
+  DW_OP_reg21 = 0x65,
+  DW_OP_reg22 = 0x66,
+  DW_OP_reg23 = 0x67,
+  DW_OP_reg24 = 0x68,
+  DW_OP_reg25 = 0x69,
+  DW_OP_reg26 = 0x6a,
+  DW_OP_reg27 = 0x6b,
+  DW_OP_reg28 = 0x6c,
+  DW_OP_reg29 = 0x6d,
+  DW_OP_reg30 = 0x6e,
+  DW_OP_reg31 = 0x6f,
+  DW_OP_breg0 = 0x70,
+  DW_OP_breg1 = 0x71,
+  DW_OP_breg2 = 0x72,
+  DW_OP_breg3 = 0x73,
+  DW_OP_breg4 = 0x74,
+  DW_OP_breg5 = 0x75,
+  DW_OP_breg6 = 0x76,
+  DW_OP_breg7 = 0x77,
+  DW_OP_breg8 = 0x78,
+  DW_OP_breg9 = 0x79,
+  DW_OP_breg10 = 0x7a,
+  DW_OP_breg11 = 0x7b,
+  DW_OP_breg12 = 0x7c,
+  DW_OP_breg13 = 0x7d,
+  DW_OP_breg14 = 0x7e,
+  DW_OP_breg15 = 0x7f,
+  DW_OP_breg16 = 0x80,
+  DW_OP_breg17 = 0x81,
+  DW_OP_breg18 = 0x82,
+  DW_OP_breg19 = 0x83,
+  DW_OP_breg20 = 0x84,
+  DW_OP_breg21 = 0x85,
+  DW_OP_breg22 = 0x86,
+  DW_OP_breg23 = 0x87,
+  DW_OP_breg24 = 0x88,
+  DW_OP_breg25 = 0x89,
+  DW_OP_breg26 = 0x8a,
+  DW_OP_breg27 = 0x8b,
+  DW_OP_breg28 = 0x8c,
+  DW_OP_breg29 = 0x8d,
+  DW_OP_breg30 = 0x8e,
+  DW_OP_breg31 = 0x8f,
+  DW_OP_regx = 0x90,
+  DW_OP_fbreg = 0x91,
+  DW_OP_bregx = 0x92,
+  DW_OP_piece = 0x93,
+  DW_OP_deref_size = 0x94,
+  DW_OP_xderef_size = 0x95,
+  DW_OP_nop = 0x96
+};
+
+enum dwarf_type
+{
+  DW_ATE_void = 0x0,
+  DW_ATE_address = 0x1,
+  DW_ATE_boolean = 0x2,
+  DW_ATE_complex_float = 0x3,
+  DW_ATE_float = 0x4,
+  DW_ATE_signed = 0x5,
+  DW_ATE_signed_char = 0x6,
+  DW_ATE_unsigned = 0x7,
+  DW_ATE_unsigned_char = 0x8
+};
+
+enum dwarf_array_dim_ordering
+{
+  DW_ORD_row_major = 0,
+  DW_ORD_col_major = 1
+};
+
+enum dwarf_access_attribute
+{
+  DW_ACCESS_public = 1,
+  DW_ACCESS_protected = 2,
+  DW_ACCESS_private = 3
+};
+
+enum dwarf_visibility_attribute
+{
+  DW_VIS_local = 1,
+  DW_VIS_exported = 2,
+  DW_VIS_qualified = 3
+};
+
+enum dwarf_virtuality_attribute
+{
+  DW_VIRTUALITY_none = 0,
+  DW_VIRTUALITY_virtual = 1,
+  DW_VIRTUALITY_pure_virtual = 2
+};
+
+enum dwarf_id_case
+{
+  DW_ID_case_sensitive = 0,
+  DW_ID_up_case = 1,
+  DW_ID_down_case = 2,
+  DW_ID_case_insensitive = 3
+};
+
+enum dwarf_calling_convention
+{
+  DW_CC_normal = 0x1,
+  DW_CC_program = 0x2,
+  DW_CC_nocall = 0x3
+};
+
+enum dwarf_inline_attribute
+{
+  DW_INL_not_inlined = 0,
+  DW_INL_inlined = 1,
+  DW_INL_declared_not_inlined = 2,
+  DW_INL_declared_inlined = 3
+};
+
+enum dwarf_descrim_list
+{
+  DW_DSC_label = 0,
+  DW_DSC_range = 1
+};
+
+enum dwarf_line_number_ops
+{
+  DW_LNS_extended_op = 0,
+  DW_LNS_copy = 1,
+  DW_LNS_advance_pc = 2,
+  DW_LNS_advance_line = 3,
+  DW_LNS_set_file = 4,
+  DW_LNS_set_column = 5,
+  DW_LNS_negate_stmt = 6,
+  DW_LNS_set_basic_block = 7,
+  DW_LNS_const_add_pc = 8,
+  DW_LNS_fixed_advance_pc = 9
+};
+
+enum dwarf_line_number_x_ops
+{
+  DW_LNE_end_sequence = 1,
+  DW_LNE_set_address = 2,
+  DW_LNE_define_file = 3
+};
+
+enum dwarf_call_frame_info
+{
+  DW_CFA_advance_loc = 0x40,
+  DW_CFA_offset = 0x80,
+  DW_CFA_restore = 0xc0,
+  DW_CFA_nop = 0x00,
+  DW_CFA_set_loc = 0x01,
+  DW_CFA_advance_loc1 = 0x02,
+  DW_CFA_advance_loc2 = 0x03,
+  DW_CFA_advance_loc4 = 0x04,
+  DW_CFA_offset_extended = 0x05,
+  DW_CFA_restore_extended = 0x06,
+  DW_CFA_undefined = 0x07,
+  DW_CFA_same_value = 0x08,
+  DW_CFA_register = 0x09,
+  DW_CFA_remember_state = 0x0a,
+  DW_CFA_restore_state = 0x0b,
+  DW_CFA_def_cfa = 0x0c,
+  DW_CFA_def_cfa_register = 0x0d,
+  DW_CFA_def_cfa_offset = 0x0e,
+  DW_CFA_MIPS_advance_loc8 = 0x1d
+};
+
+#define DW_CIE_ID	  0xffffffff
+#define DW_CIE_VERSION	  1
+
+#define DW_CFA_extended   0
+#define DW_CFA_low_user   0x1c
+#define DW_CFA_high_user  0x3f
+
+#define DW_CHILDREN_no		     0x00
+#define DW_CHILDREN_yes		     0x01
+
+#define DW_ADDR_none		0
+
+enum dwarf_source_language
+{
+  DW_LANG_C89 = 0x0001,
+  DW_LANG_C = 0x0002,
+  DW_LANG_Ada83 = 0x0003,
+  DW_LANG_C_plus_plus = 0x0004,
+  DW_LANG_Cobol74 = 0x0005,
+  DW_LANG_Cobol85 = 0x0006,
+  DW_LANG_Fortran77 = 0x0007,
+  DW_LANG_Fortran90 = 0x0008,
+  DW_LANG_Pascal83 = 0x0009,
+  DW_LANG_Modula2 = 0x000a,
+  DW_LANG_Mips_Assembler = 0x8001
+};
+
+
+enum dwarf_macinfo_record_type
+{
+  DW_MACINFO_define = 1,
+  DW_MACINFO_undef = 2,
+  DW_MACINFO_start_file = 3,
+  DW_MACINFO_end_file = 4,
+  DW_MACINFO_vendor_ext = 255
+};
+
+
+
+#define HAVE_LOCATION_LISTS 0
+
+/* provided by the code generator */
+static void dwarf2_print_frame_location(FILE *,Var *);
+static zmax dwarf2_fboffset(Var *);
+static int dwarf2_regnumber(int);
+
+static int abbrev_label,info_start,info_end,line_start,line_end;
+
+static int sizeof_addr;
+static char *dwarfd1,*dwarfd2,*dwarfd4,*da,*lp,*ip,*dsec;
+static int addr_form;
+static char **names;
+static int namecount;
+
+extern Var *merk_varf,*first_var[],*first_ext; /*FIXME: not nice */
+extern struct_declaration *first_sd[];
+
+#define COMP_UNIT 1UL
+#define SUBPROGRAM 2UL
+#define SUBPROGRAMVOID 3UL 
+#define BASETYPE 4UL
+#define POINTERTYPE 5UL
+#define CONSTTYPE 6UL
+#define VOLATILETYPE 7UL
+#define FORMALPARAMETER 8UL
+#define VARIABLE 9UL
+#define ARRAYTYPE 10UL
+#define ARRAYDIM 11UL
+#define STRUCTTYPE 12UL
+#define UNIONTYPE 13UL
+#define STRUCTTAG 14UL
+#define UNIONTAG 15UL
+#define TYPEDEFTYPE 16UL
+#define MEMBERTYPE 17UL
+#define FUNCTYPE 18UL
+#define VOIDFUNCTYPE 19UL
+#define PARMTYPE 20UL
+
+typedef struct dwarf2_line_info {
+  struct dwarf2_line_info *next;
+  char *id;
+  int file,line,label;
+} tdwarf2_line_info;
+
+static tdwarf2_line_info *dwarf2_first_li,*dwarf2_last_li;
+
+static void dwarf2_add_line(int file,int line,int label,char *id)
+{
+  tdwarf2_line_info *new,*p,*lp;
+  new=mymalloc(sizeof(*new));
+  new->file=file;
+  new->line=line;
+  new->label=label;
+  if(id){
+    new->id=mymalloc(strlen(id)+1);
+    strcpy(new->id,id);
+  }else{
+    new->id=0;
+  }
+  new->next=0;
+#if 0
+  for(lp=p=dwarf2_first_li;p;p=p->next){
+    if(p!=lp&&p->file==file&&p->line>=line){
+      new->next=lp->next;
+      lp->next=new;
+      return;
+    }
+    lp=p;
+  }
+#endif
+  if(dwarf2_last_li){
+    dwarf2_last_li->next=new;
+    dwarf2_last_li=new;
+  }else{
+    dwarf2_first_li=dwarf2_last_li=new;
+  }
+#if 0
+  printf("linfo:\n");
+  for(p=dwarf2_first_li;p;p=p->next)
+    printf("li: line=%d\n",p->line);
+#endif
+}
+
+static void dwarf2_setup(int sa,char *dwarfd1s,char *dwarfd2s,char *dwarfd4s,char *das,char *lps,char *ips,char *ds)
+{
+  sizeof_addr=sa;
+  dwarfd1=dwarfd1s;
+  dwarfd2=dwarfd2s;
+  dwarfd4=dwarfd4s;
+  da=das;
+  lp=lps;
+  ip=ips;
+  dsec=ds;
+  if(sizeof_addr==2)
+    addr_form=DW_FORM_data2;
+  else if(sizeof_addr==4)
+    addr_form=DW_FORM_data4;
+  else if(sizeof_addr==8)
+    addr_form=DW_FORM_data8;
+  else
+    ierror(0);
+}
+static int dwarf2_uleb128_size(zumax value)
+{
+  int size=0;
+  do{
+    value=zumrshift(value,ul2zum(7UL));
+    size++;
+  }while(!zmeqto(value,ul2zum(0UL)));
+  return size;
+}
+static void dwarf2_print_uleb128(FILE *f,zumax value)
+{
+  unsigned long byte;
+  emit(f,"\t%s\t",dwarfd1);
+  do{
+    byte=zum2ul(zumand(value,ul2zum(127UL)));
+    value=zumrshift(value,ul2zum(7UL));
+    if(!zumeqto(value,ul2zum(0UL)))
+      emit(f,"%lu,",byte|0x80);
+    else
+      emit(f,"%lu\n",byte);
+  }while(!zumeqto(value,ul2zum(0UL)));
+}
+static int dwarf2_sleb128_size(zmax value)
+{
+  int more=1,size=0;
+  long byte;
+  do{
+    byte=zm2l(zmand(value,l2zm(127L)));
+    value=zmrshift(value,l2zm(7L)); /*FIXME*/
+    if((zmeqto(value,l2zm(0L))&&!(byte&0x40))||
+       (zmeqto(value,l2zm(-1L))&&(byte&0x40)))
+      more=0;
+    size++;
+  }while(more);
+  return size;
+}
+static void dwarf2_print_sleb128(FILE *f,zmax value)
+{
+  int more=1;
+  long byte;
+  emit(f,"\t%s\t",dwarfd1);
+  do{
+    byte=zm2l(zmand(value,l2zm(127L)));
+    value=zmrshift(value,l2zm(7L)); /*FIXME*/
+    if((zmeqto(value,l2zm(0L))&&!(byte&0x40))||
+       (zmeqto(value,l2zm(-1L))&&(byte&0x40))){
+      more=0;
+      emit(f,"%ld\n",byte);
+    }else{
+      emit(f,"%ld,",byte|0x80);
+    }
+  }while(more);
+}
+static void dwarf2_print_location(FILE *f,obj *o)
+{
+  if(o->flags&(KONST|DREFOBJ)) ierror(0);
+  if(!(o->flags&(VAR|REG))) ierror(0);
+  if(o->flags&REG){
+    int r=dwarf2_regnumber(o->reg);
+    if(r<=31){
+      emit(f,"\t%s\t%d\n",dwarfd2,1);
+      emit(f,"\t%s\t%d\n",dwarfd1,DW_OP_reg0+r);
+    }else{
+      emit(f,"\t%s\t%d\n",dwarfd2,1+dwarf2_uleb128_size(ul2zum((unsigned long)r)));
+      emit(f,"\t%s\t%d\n",dwarfd1,DW_OP_regx);
+      dwarf2_print_uleb128(f,ul2zum(r));
+    }
+  }else{
+    if(o->v->storage_class==STATIC||o->v->storage_class==EXTERN){
+      if(cross_module&&!(o->v->flags&REFERENCED)){
+	emit(f,"\t%s\t0\n",dwarfd1);
+      }else{
+	emit(f,"\t%s\t%d\n",dwarfd2,(int)(1+sizeof_addr));
+	emit(f,"\t%s\t%d\n",dwarfd1,DW_OP_addr);
+	if(o->v->storage_class==STATIC)
+	  emit(f,"\t%s\t%s%ld\n",da,lp,zm2l(o->v->offset));
+	else
+	  emit(f,"\t%s\t%s%s\n",da,ip,o->v->identifier);
+      }
+    }else{
+      zmax of=dwarf2_fboffset(o->v);
+      emit(f,"\t%s\t%d\n",dwarfd2,1+dwarf2_sleb128_size(of));
+      emit(f,"\t%s\t%d\n",dwarfd1,DW_OP_fbreg);
+      dwarf2_print_sleb128(f,of);
+    }
+  }
+}
+static int dwarf2_file(const char *p)
+{
+  int i;
+  if(!p) ierror(0);
+  for(i=0;i<namecount;i++)
+    if(!strcmp(p,names[i]))
+      return i+1;
+  namecount++;
+  names=myrealloc(names,namecount*sizeof(*names));
+  names[namecount-1]=mymalloc(strlen(p)+1);
+  strcpy(names[namecount-1],p);
+  return namecount;
+}
+static int dwarf2_type(FILE *f,type *t)
+{
+  int l,lo;char *p;
+  if(ISPOINTER(t->flags)){
+    lo=dwarf2_type(f,t->next);
+    l=++label;
+    emit(f,"%s%d:\n",lp,l);
+    dwarf2_print_uleb128(f,ul2zum(POINTERTYPE));
+    emit(f,"\t%s\t%s%d\n",da,lp,lo);
+  }else if(ISINT(t->flags)||ISFLOAT(t->flags)||(t->flags&NQ)==VOID){
+    l=++label;
+    emit(f,"%s%d:\n",lp,l);
+    dwarf2_print_uleb128(f,ul2zum(BASETYPE));    
+    for(p=typname[t->flags&NQ];*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+    emit(f,"\t%s\t0\n",dwarfd1);
+    if(ISFLOAT(t->flags)){
+      lo=DW_ATE_float;
+    }else if((t->flags&NQ)==CHAR){
+      if(t->flags&UNSIGNED)
+	lo=DW_ATE_unsigned_char;
+      else
+	lo=DW_ATE_signed_char;
+    }else if((t->flags&NQ)==VOID){
+      lo=DW_ATE_unsigned_char;
+    }else{
+      if(!ISINT(t->flags)) ierror(0);
+      if(t->flags&UNSIGNED)
+	lo=DW_ATE_unsigned;
+      else
+	lo=DW_ATE_signed;
+    }
+    dwarf2_print_uleb128(f,ul2zum((unsigned long)lo));
+    dwarf2_print_uleb128(f,sizetab[t->flags&NQ]);
+  }else if(ISARRAY(t->flags)){
+    lo=dwarf2_type(f,t->next);
+    l=++label;
+    emit(f,"%s%d:\n",lp,l);
+    dwarf2_print_uleb128(f,ul2zum(ARRAYTYPE));
+    emit(f,"\t%s\t%s%d\n",da,lp,lo);
+    dwarf2_print_uleb128(f,ul2zum(ARRAYDIM));
+    dwarf2_print_uleb128(f,zumsub(t->size,ul2zum(1UL)));
+    emit(f,"\t%s\t0\n",dwarfd1);
+  }else if(ISSTRUCT(t->flags)||ISUNION(t->flags)){
+    if(t->exact->label>0){
+      l=t->exact->label;
+    }else{
+      int i,*tl;zmax offset=l2zm(0L),al;
+      type *tp;
+      l=++label;
+      t->exact->label=l;
+      tl=mymalloc(t->exact->count*sizeof(*tl));
+      for(i=0;i<t->exact->count;i++)
+	tl[i]=dwarf2_type(f,(*t->exact->sl)[i].styp);
+      emit(f,"%s%d:\n",lp,l);
+      if(t->exact->identifier){
+	if(ISSTRUCT(t->flags))
+	  dwarf2_print_uleb128(f,STRUCTTAG);
+	else
+	  dwarf2_print_uleb128(f,UNIONTAG);
+	dwarf2_print_uleb128(f,szof(t));
+	for(p=t->exact->identifier;*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+	emit(f,"\t%s\t0\n",dwarfd1);
+      }else{
+	if(ISSTRUCT(t->flags))
+	  dwarf2_print_uleb128(f,STRUCTTYPE);
+	else
+	  dwarf2_print_uleb128(f,UNIONTYPE);
+	dwarf2_print_uleb128(f,szof(t));
+      }
+      for(i=0;i<t->exact->count;i++){
+	dwarf2_print_uleb128(f,MEMBERTYPE);
+	for(p=(*t->exact->sl)[i].identifier;*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+	emit(f,"\t%s\t0\n",dwarfd1);
+	emit(f,"\t%s\t%s%d\n",da,lp,tl[i]);
+	dwarf2_print_uleb128(f,zumadd(dwarf2_uleb128_size(zm2zum(offset)),ul2zum(1L)));
+	tp=(*t->exact->sl)[i].styp;
+	al=falign(tp);
+	offset=zmmult(zmdiv(zmadd(offset,zmsub(al,l2zm(1L))),al),al);
+	emit(f,"\t%s\t%d\n",dwarfd1,DW_OP_plus_uconst);
+	dwarf2_print_uleb128(f,zm2zum(offset));
+	if(ISSTRUCT(t->flags))
+	  offset=zmadd(offset,szof(tp));   	
+      }
+      emit(f,"\t%s\t0\n",dwarfd1);
+      free(tl);
+    }
+  }else if(ISFUNC(t->flags)){
+    int *tl,i;
+    l=++label;
+    tl=mymalloc(t->exact->count*sizeof(*tl));
+    for(i=0;i<t->exact->count;i++){
+      if(((*t->exact->sl)[i].styp->flags&NQ)!=VOID)
+	tl[i]=dwarf2_type(f,(*t->exact->sl)[i].styp);
+    }
+    if((t->next->flags&NQ)==VOID){
+      emit(f,"%s%d:\n",lp,l);
+      dwarf2_print_uleb128(f,VOIDFUNCTYPE);
+    }else{
+      lo=dwarf2_type(f,t->next);
+      emit(f,"%s%d:\n",lp,l);
+      dwarf2_print_uleb128(f,FUNCTYPE);
+      emit(f,"\t%s\t%s%d\n",da,lp,lo);
+    }
+    for(i=0;i<t->exact->count;i++){
+      if(((*t->exact->sl)[i].styp->flags&NQ)!=VOID){
+	dwarf2_print_uleb128(f,PARMTYPE);
+	emit(f,"\t%s\t%s%d\n",da,lp,tl[i]);
+      }
+    }
+    emit(f,"\t%s\t0\n",dwarfd1);
+    free(tl);
+  }else{
+    printf("%d\n",t->flags);
+    ierror(0);
+  }
+  if(t->flags&VOLATILE){
+    lo=l;l=++label;
+    emit(f,"%s%d:\n",lp,l);
+    dwarf2_print_uleb128(f,ul2zum(VOLATILETYPE));
+    emit(f,"\t%s\t%s%d\n",da,lp,lo);
+  }
+  if(t->flags&CONST){
+    lo=l;l=++label;
+    emit(f,"%s%d:\n",lp,l);
+    dwarf2_print_uleb128(f,ul2zum(CONSTTYPE));
+    emit(f,"\t%s\t%s%d\n",da,lp,lo);
+  }
+  return l;
+}
+static void dwarf2_var(FILE *f,Var *v)
+{
+  char *p;int l;
+  if(!(v->flags&(DEFINED|TENTATIVE))) return;
+  if(v->storage_class==STATIC&&v->nesting>0&&!(v->flags&(USEDASSOURCE|USEDASDEST))) return;
+
+  if(ISFUNC(v->vtyp->flags)) return;
+  if(*v->identifier&&v->storage_class!=TYPEDEF){
+    l=dwarf2_type(f,v->vtyp);
+    if((v->storage_class==AUTO||v->storage_class==REGISTER)&&(!zmleq(l2zm(0L),v->offset)||v->reg)){
+      dwarf2_print_uleb128(f,ul2zum(FORMALPARAMETER));
+    }else{
+      dwarf2_print_uleb128(f,ul2zum(VARIABLE));
+    }
+    for(p=v->identifier;*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+    emit(f,"\t%s\t0\n",dwarfd1);
+    emit(f,"\t%s\t%s%d\n",da,lp,l);
+    if((v->storage_class==AUTO||v->storage_class==REGISTER)&&(!zmleq(l2zm(0L),v->offset)||v->reg)){
+      /* no external flag for formal-parameter */
+    }else{
+      emit(f,"\t%s\t%d\n",dwarfd1,(v->storage_class==EXTERN));
+    }
+    if((!v->dfilename||!v->dline)&&(!v->filename||!v->line)) ierror(0);
+    if(v->dfilename){
+      dwarf2_print_uleb128(f,ul2zum((unsigned long)dwarf2_file(v->dfilename)));
+      dwarf2_print_uleb128(f,ul2zum((unsigned long)v->dline));
+    }else{
+      dwarf2_print_uleb128(f,ul2zum((unsigned long)dwarf2_file(v->filename)));
+      dwarf2_print_uleb128(f,ul2zum((unsigned long)v->line));
+    }
+    {  /*FIXME!*/
+      obj o;
+      o.flags=VAR;
+      o.val.vmax=l2zm(0L);
+      o.v=v;
+#if HAVE_LOCATION_LISTS
+      emit(f,"\t%s\t\".debug_loc\"\n",dsec);
+      ++label;
+      emit(f,"%s%d:\n",lp,label);
+      emit(f,"\t%s\t0\n",da);
+      emit(f,"\t%s\t-1\n",da);
+      dwarf2_print_location(f,&o);
+      emit(f,"\t%s\t0\n",da);
+      emit(f,"\t%s\t0\n",da);      
+      emit(f,"\t%s\t\".debug_info\"\n",dsec);
+      emit(f,"\t%s\t%s%d\n",da,lp,label);
+#else
+      dwarf2_print_location(f,&o);
+#endif      
+    }
+  }
+}
+static void dwarf2_print_comp_unit_header(FILE *f)
+{
+  char *p;
+  extern char *copyright; /* not nice */
+  extern char *inname; /* not nice */
+  
+  abbrev_label=++label;
+  emit(f,"\t%s\t\".debug_abbrev\"\n",dsec);
+  emit(f,"%s%d:\n",lp,abbrev_label);
+
+  dwarf2_print_uleb128(f,ul2zum(COMP_UNIT));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_compile_unit));
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes)); 
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_language));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_stmt_list));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_producer));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_identifier_case));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(0UL));
+  dwarf2_print_uleb128(f,ul2zum(0UL));
+
+  dwarf2_print_uleb128(f,ul2zum(SUBPROGRAM));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_subprogram));
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_low_pc));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_high_pc));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_external));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_flag));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_decl_file));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_decl_line));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_frame_base));
+#if HAVE_LOCATION_LISTS
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+#else
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_block2));
+#endif
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(SUBPROGRAMVOID));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_subprogram));
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_low_pc));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_high_pc));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_external));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_flag));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_decl_file));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_decl_line));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_frame_base));
+#if HAVE_LOCATION_LISTS
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+#else
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_block2));
+#endif
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(FORMALPARAMETER));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_formal_parameter));
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_decl_file));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_decl_line));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_location));
+#if HAVE_LOCATION_LISTS
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+#else
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_block2));
+#endif
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(VARIABLE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_variable));
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_external));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_flag));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_decl_file));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_decl_line));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_location));
+#if HAVE_LOCATION_LISTS
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+#else
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_block2));
+#endif
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(BASETYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_base_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_encoding));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_byte_size));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(POINTERTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_pointer_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));  
+
+  dwarf2_print_uleb128(f,ul2zum(CONSTTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_const_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(VOLATILETYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_volatile_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(ARRAYTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_array_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(ARRAYDIM));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_subrange_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_upper_bound));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(STRUCTTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_structure_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_byte_size));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(UNIONTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_union_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_byte_size));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(STRUCTTAG));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_structure_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_byte_size));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(UNIONTAG));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_union_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_byte_size));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_udata));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(MEMBERTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_member));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_name));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_string));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_data_member_location));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_block));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(FUNCTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_subroutine_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(VOIDFUNCTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_subroutine_type));  
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_yes));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+  dwarf2_print_uleb128(f,ul2zum(PARMTYPE));
+  dwarf2_print_uleb128(f,ul2zum(DW_TAG_formal_parameter));
+  dwarf2_print_uleb128(f,ul2zum(DW_CHILDREN_no));
+  dwarf2_print_uleb128(f,ul2zum(DW_AT_type));
+  dwarf2_print_uleb128(f,ul2zum(DW_FORM_ref_addr));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+  dwarf2_print_uleb128(f,ul2zum(0L));
+
+
+  info_start=++label;info_end=++label;
+  emit(f,"\t%s\t\".debug_info\"\n",dsec);
+  
+  /* header */
+  emit(f,"%s%d:\n",lp,info_start);
+  emit(f,"\t%s\t%s%d-%s%d-4\n",dwarfd4,lp,info_end,lp,info_start);
+  emit(f,"\t%s\t2\n",dwarfd2); /* version */
+  emit(f,"\t%s\t%s%d\n",dwarfd4,lp,abbrev_label);
+  emit(f,"\t%s\t%d\n",dwarfd1,sizeof_addr);
+  
+  /* compile_unit */
+  dwarf2_print_uleb128(f,ul2zum(COMP_UNIT));
+  dwarf2_print_uleb128(f,ul2zum(DW_LANG_C89));
+  line_start=++label;line_end=++label;
+  emit(f,"\t%s\t%s%d\n",da,lp,line_start);
+  for(p=copyright;*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+  emit(f,"\t%s\t0\n",dwarfd1);
+  emit(f,"\t%s\t%d\n",dwarfd1,DW_ID_case_sensitive);
+  for(p=inname?inname:"<multiple>";*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+  emit(f,"\t%s\t0\n",dwarfd1);
+}
+static void dwarf2_cleanup(FILE *f)
+{
+  int i,line,file,label,length;char *p;
+  tdwarf2_line_info *li,*m;
+  Var *vl;
+  struct_declaration *sd;
+  emit(f,"\t%s\t\".debug_line\"\n",dsec);
+  /* line info */
+  emit(f,"%s%d:\n",lp,line_start);
+  emit(f,"\t%s\t%s%d-%s%d-4\n",dwarfd4,lp,line_end,lp,line_start); /* length */
+  emit(f,"\t%s\t2\n",dwarfd2); /* version */
+  length=16;
+  for(i=0;i<namecount;i++) length+=strlen(names[i])+4;
+  emit(f,"\t%s\t%d\n",dwarfd4,length); /* prologue length */
+  emit(f,"\t%s\t1\n",dwarfd1); /* instruction_length */
+  emit(f,"\t%s\t1\n",dwarfd1); /* is_stmt */
+  emit(f,"\t%s\t-10\n",dwarfd1); /* line_base */
+  emit(f,"\t%s\t245\n",dwarfd1); /* line_range */
+  emit(f,"\t%s\t10\n",dwarfd1); /* opcode_base */
+  emit(f,"\t%s\t0\n",dwarfd1); /* standard opcode arguments */
+  emit(f,"\t%s\t1\n",dwarfd1);
+  emit(f,"\t%s\t1\n",dwarfd1);
+  emit(f,"\t%s\t1\n",dwarfd1);
+  emit(f,"\t%s\t1\n",dwarfd1);
+  emit(f,"\t%s\t0\n",dwarfd1);
+  emit(f,"\t%s\t0\n",dwarfd1);
+  emit(f,"\t%s\t0\n",dwarfd1);
+  emit(f,"\t%s\t1\n",dwarfd1);
+  emit(f,"\t%s\t0\n",dwarfd1); /* include directories */
+  for(i=0;i<namecount;i++){
+    for(p=names[i];*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+    emit(f,"\t%s\t0\n",dwarfd1);
+    emit(f,"\t%s\t0\n",dwarfd1);
+    emit(f,"\t%s\t0\n",dwarfd1);
+    emit(f,"\t%s\t0\n",dwarfd1);
+  }
+  emit(f,"\t%s\t0\n",dwarfd1); /* file names */  
+  
+  file=-1;line=1;label=-1;
+  li=dwarf2_first_li;
+  while(li){
+    m=li->next;
+    if(li->file!=file){
+      file=li->file;
+      emit(f,"\t%s\t%d\n",dwarfd1,DW_LNS_set_file);
+      dwarf2_print_uleb128(f,ul2zum((long)file));
+    }
+    if(!li->id&&li->label!=label){
+      label=li->label;
+      emit(f,"\t%s\t0\n",dwarfd1); /* extended opcode */
+      emit(f,"\t%s\t%d\n",dwarfd1,1+sizeof_addr); /* length */
+      emit(f,"\t%s\t%d\n",dwarfd1,DW_LNE_set_address);
+      emit(f,"\t%s\t%s%d\n",da,lp,label);      
+    }
+    if(li->id){
+      emit(f,"\t%s\t0\n",dwarfd1); /* extended opcode */
+      emit(f,"\t%s\t%d\n",dwarfd1,1+sizeof_addr); /* length */
+      emit(f,"\t%s\t%d\n",dwarfd1,DW_LNE_set_address);
+      emit(f,"\t%s\t%s%s\n",da,ip,li->id);
+      free(li->id);
+    }      
+    if(li->line!=line){
+      emit(f,"\t%s\t%d\n",dwarfd1,DW_LNS_advance_line);
+      dwarf2_print_sleb128(f,l2zm((long)(li->line-line)));
+      line=li->line;
+    }
+    emit(f,"\t%s\t%d\n",dwarfd1,DW_LNS_copy);
+    free(li);
+    li=m;
+  }
+  emit(f,"\t%s\t0,1,1\n",dwarfd1); /* end_sequence */
+  emit(f,"%s%d:\n",lp,line_end);
+  emit(f,"\t%s\t\".debug_info\"\n",dsec);
+  for(sd=first_sd[0];sd;sd=sd->next){
+    if(sd->identifier){
+      static type styp;
+      styp.flags=sd->typ;
+      styp.exact=sd;
+      sd->label=0;
+      dwarf2_type(f,&styp);
+    }
+  }
+  for(vl=first_var[0];vl;vl=vl->next)
+    dwarf2_var(f,vl);
+  for(vl=first_ext;vl;vl=vl->next)
+    dwarf2_var(f,vl);
+  emit(f,"\t%s\t0\n",dwarfd1);
+  emit(f,"%s%d:\n",lp,info_end);
+  for(i=0;i<namecount;i++) free(names[i]);
+  free(names);
+}
+/* generate line info for IC p, return 0 if nothing had to be generated */
+static void dwarf2_line_info(FILE *f,IC *p)
+{
+  static int line,file,n;
+  tdwarf2_line_info *new;
+  if(!f) return;
+  if(p->line==0) return;
+  if(!p->file) ierror(0);
+  n=dwarf2_file(p->file);
+  if(n!=file||p->line!=line){
+    file=n;
+    line=p->line;
+    emit(f,"%s%d:\n",lp,++label);
+    dwarf2_add_line(file,line,label,0);
+  }
+}
+
+static void dwarf2_function(FILE *f,Var *v,int endlabel)
+{
+  char *p;int l;Var *vl;
+  struct struct_identifier *si;
+  /* subprogram */
+  if(!f) return;
+  emit(f,"\t%s\t\".debug_info\"\n",dsec);
+  if(!v->vtyp||!v->vtyp->next) ierror(0);
+  if((v->vtyp->next->flags&NQ)==VOID){
+    dwarf2_print_uleb128(f,ul2zum(SUBPROGRAMVOID));
+  }else{
+    l=dwarf2_type(f,v->vtyp->next);
+    dwarf2_print_uleb128(f,ul2zum(SUBPROGRAM));
+  }
+  for(p=ip;*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+  for(p=v->identifier;*p;p++) emit(f,"\t%s\t%d\n",dwarfd1,*p);
+  emit(f,"\t%s\t0\n",dwarfd1);
+  if(v->storage_class==EXTERN){
+    emit(f,"\t%s\t%s%s\n",da,ip,v->identifier);
+  }else{
+    emit(f,"\t%s\t%s%ld\n",da,lp,zm2l(v->offset));    
+  }
+  emit(f,"\t%s\t%s%d\n",da,lp,endlabel);
+  if((v->vtyp->next->flags&NQ)!=VOID)
+    emit(f,"\t%s\t%s%d\n",da,lp,l);
+  if(!v->dfilename||v->dline<=0) ierror(0);
+  emit(f,"\t%s\t%d\n",dwarfd1,(v->storage_class==EXTERN));
+  if(v->storage_class==EXTERN)
+    dwarf2_add_line(dwarf2_file(v->dfilename),v->dline,0,v->identifier);
+  else
+    dwarf2_add_line(dwarf2_file(v->dfilename),v->dline,(int)zm2l(v->offset),0);
+  dwarf2_print_uleb128(f,ul2zum((long)dwarf2_file(v->dfilename)));
+  dwarf2_print_uleb128(f,ul2zum((long)v->dline));
+#if HAVE_LOCATION_LISTS
+  emit(f,"\t%s\t\".debug_loc\"\n",dsec);
+  emit(f,"%s%d:\n",lp,++label);
+  emit(f,"\t%s\t0\n",da);
+  emit(f,"\t%s\t-1\n",da); 
+  dwarf2_print_frame_location(f,v);
+  emit(f,"\t%s\t0\n",da);
+  emit(f,"\t%s\t0\n",da);   
+  emit(f,"\t%s\t\".debug_info\"\n",dsec);
+  emit(f,"\t%s\t%s%d\n",da,lp,label);
+#else
+  dwarf2_print_frame_location(f,v);
+#endif
+
+  /* children */
+
+  /*FIXME: not nice */
+  if(cross_module){
+    if(!v->fi) ierror(0);
+    for(vl=v->fi->vars;vl;vl=vl->next)
+      dwarf2_var(f,vl);
+  }else{
+    for(vl=first_var[1];vl;vl=vl->next)
+      dwarf2_var(f,vl);
+    for(vl=merk_varf;vl;vl=vl->next)
+      dwarf2_var(f,vl);
+  }
+  
+  
+  emit(f,"\t%s\t0\n",dwarfd1);
+}