我是靠谱客的博主 欢喜帽子,最近开发中收集的这篇文章主要介绍gcc 中-g对应的源代码和gdb有关的flags和变量 write_symbols,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

flags.h 中有write_symbols的定义

/* 1 => write gdb debugging output (using symout.c).
   2 => write dbx debugging output (using dbxout.c).
   3 => write sdb debugging output (using sdbout.c).  */
enum debugger { NO_DEBUG = 0, GDB_DEBUG = 1, DBX_DEBUG = 2, SDB_DEBUG = 3,
        EXTENDED_DBX_DEBUG = 4 };

extern enum debugger write_symbols;


toplev.c   中有对-g的处理

    else if (!strcmp (str, "gg"))

      write_symbols = GDB_DEBUG;
#ifdef DBX_DEBUGGING_INFO
    else if (!strcmp (str, "g0"))
      write_symbols = DBX_DEBUG;
    else if (!strcmp (str, "G0"))
      write_symbols = DBX_DEBUG;
    else if (!strcmp (str, "g"))
      {
        write_symbols = DBX_DEBUG;
        use_gdb_dbx_extensions = 1;
      }
    else if (!strcmp (str, "G"))
      {
        write_symbols = DBX_DEBUG;
        use_gdb_dbx_extensions = 1;
      }
#endif
#ifdef SDB_DEBUGGING_INFO
    else if (!strcmp (str, "g"))
      write_symbols = SDB_DEBUG;
    else if (!strcmp (str, "G"))
      write_symbols = SDB_DEBUG;
    else if (!strcmp (str, "g0"))
      write_symbols = SDB_DEBUG;
    else if (!strcmp (str, "G0"))
      write_symbols = SDB_DEBUG;
#endif
    else if (!strcmp (str, "symout"))
      {
        if (write_symbols == NO_DEBUG)
          write_symbols = GDB_DEBUG;
        sym_file_name = argv[++i];
      }


stmt.c中出现了一次:

  /* Initialize the RTL mechanism.  */
  init_emit (write_symbols);

emit.c中的对应的函数

/* Initialize data structures and variables in this file
   before generating rtl for each function.
   WRITE_SYMBOLS is nonzero if any kind of debugging info
   is to be generated.  */

void
init_emit (write_symbols)
     int write_symbols;
{
  first_insn = NULL;
  last_insn = NULL;
  sequence_stack = NULL;
  cur_insn_uid = 1;
  reg_rtx_no = FIRST_PSEUDO_REGISTER;
  last_linenum = 0;
  last_filename = 0;
  first_label_num = label_num;

  no_line_numbers = ! write_symbols;
 
  /* Init the tables that describe all the pseudo regs.  */

  regno_pointer_flag_length = FIRST_PSEUDO_REGISTER + 100;

  regno_pointer_flag
    = (char *) oballoc (regno_pointer_flag_length);
  bzero (regno_pointer_flag, regno_pointer_flag_length);

  regno_reg_rtx
    = (rtx *) oballoc (regno_pointer_flag_length * sizeof (rtx));
  bzero (regno_reg_rtx, regno_pointer_flag_length * sizeof (rtx));
}

final.c中的好几处出现的地方



toplev.c中调用了final_start_function()函数

  TIMEVAR (final_time,
       {
         assemble_function (decl);
         final_start_function (insns, asm_out_file,
                   write_symbols, optimize);
         final (insns, asm_out_file,
            write_symbols, optimize, 0);
         final_end_function (insns, asm_out_file,
                 write_symbols, optimize);
         fflush (asm_out_file);
       });

filnal.c文件中有对write_symbols的使用

void
final_start_function (first, file, write_symbols, optimize)
     rtx first;
     FILE *file;
     enum debugger write_symbols;
     int optimize;
{
  block_depth = 0;

  this_is_asm_operands = 0;

  /* Record beginning of the symbol-block that's the entire function.  */

  if (write_symbols == GDB_DEBUG)
    {
      pending_blocks[block_depth++] = next_block_index;
      fprintf (file, "t.gdbbeg %dn", next_block_index++);
    }


最后

以上就是欢喜帽子为你收集整理的gcc 中-g对应的源代码和gdb有关的flags和变量 write_symbols的全部内容,希望文章能够帮你解决gcc 中-g对应的源代码和gdb有关的flags和变量 write_symbols所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(53)

评论列表共有 0 条评论

立即
投稿
返回
顶部