- {
- register int value = XINT (in_rtx, i);
-
- if (GET_CODE (in_rtx) == REG && value < FIRST_PSEUDO_REGISTER)
- {
- fputc (' ', outfile);
- DEBUG_PRINT_REG (in_rtx, 0, outfile);
- }
- else if (GET_CODE (in_rtx) == REG && value <= LAST_VIRTUAL_REGISTER)
- {
- if (value == VIRTUAL_INCOMING_ARGS_REGNUM)
- fprintf (outfile, " %d virtual-incoming-args", value);
- else if (value == VIRTUAL_STACK_VARS_REGNUM)
- fprintf (outfile, " %d virtual-stack-vars", value);
- else if (value == VIRTUAL_STACK_DYNAMIC_REGNUM)
- fprintf (outfile, " %d virtual-stack-dynamic", value);
- else if (value == VIRTUAL_OUTGOING_ARGS_REGNUM)
- fprintf (outfile, " %d virtual-outgoing-args", value);
- else if (value == VIRTUAL_CFA_REGNUM)
- fprintf (outfile, " %d virtual-cfa", value);
- else
- fprintf (outfile, " %d virtual-reg-%d", value,
- value-FIRST_VIRTUAL_REGISTER);
- }
- else if (flag_dump_unnumbered
- && (is_insn || GET_CODE (in_rtx) == NOTE))
- fputc ('#', outfile);
- else
- fprintf (outfile, " %d", value);
- }
- if (is_insn && &INSN_CODE (in_rtx) == &XINT (in_rtx, i)
- && insn_name_ptr
- && XINT (in_rtx, i) >= 0)
- fprintf (outfile, " {%s}", insn_name_ptr[XINT (in_rtx, i)]);
- sawclose = 0;
+ if (i == 4 && INSN_P (in_rtx))
+ {
+#ifndef GENERATOR_FILE
+ /* Pretty-print insn locators. Ignore scoping as it is mostly
+ redundant with line number information and do not print anything
+ when there is no location information available. */
+ if (INSN_LOCATOR (in_rtx) && insn_file (in_rtx))
+ fprintf(outfile, " %s:%i", insn_file (in_rtx), insn_line (in_rtx));
+#endif
+ }
+ else if (i == 6 && NOTE_P (in_rtx))
+ {
+ /* This field is only used for NOTE_INSN_DELETED_LABEL, and
+ other times often contains garbage from INSN->NOTE death. */
+ if (NOTE_KIND (in_rtx) == NOTE_INSN_DELETED_LABEL)
+ fprintf (outfile, " %d", XINT (in_rtx, i));
+ }
+ else
+ {
+ int value = XINT (in_rtx, i);
+ const char *name;
+
+#ifndef GENERATOR_FILE
+ if (REG_P (in_rtx) && value < FIRST_PSEUDO_REGISTER)
+ fprintf (outfile, " %d %s", REGNO (in_rtx),
+ reg_names[REGNO (in_rtx)]);
+ else if (REG_P (in_rtx)
+ && value <= LAST_VIRTUAL_REGISTER)
+ {
+ if (value == VIRTUAL_INCOMING_ARGS_REGNUM)
+ fprintf (outfile, " %d virtual-incoming-args", value);
+ else if (value == VIRTUAL_STACK_VARS_REGNUM)
+ fprintf (outfile, " %d virtual-stack-vars", value);
+ else if (value == VIRTUAL_STACK_DYNAMIC_REGNUM)
+ fprintf (outfile, " %d virtual-stack-dynamic", value);
+ else if (value == VIRTUAL_OUTGOING_ARGS_REGNUM)
+ fprintf (outfile, " %d virtual-outgoing-args", value);
+ else if (value == VIRTUAL_CFA_REGNUM)
+ fprintf (outfile, " %d virtual-cfa", value);
+ else
+ fprintf (outfile, " %d virtual-reg-%d", value,
+ value-FIRST_VIRTUAL_REGISTER);
+ }
+ else
+#endif
+ if (flag_dump_unnumbered
+ && (is_insn || NOTE_P (in_rtx)))
+ fputc ('#', outfile);
+ else
+ fprintf (outfile, " %d", value);
+
+#ifndef GENERATOR_FILE
+ if (REG_P (in_rtx) && REG_ATTRS (in_rtx))
+ {
+ fputs (" [", outfile);
+ if (ORIGINAL_REGNO (in_rtx) != REGNO (in_rtx))
+ fprintf (outfile, "orig:%i", ORIGINAL_REGNO (in_rtx));
+ if (REG_EXPR (in_rtx))
+ print_mem_expr (outfile, REG_EXPR (in_rtx));
+
+ if (REG_OFFSET (in_rtx))
+ fprintf (outfile, "+" HOST_WIDE_INT_PRINT_DEC,
+ REG_OFFSET (in_rtx));
+ fputs (" ]", outfile);
+ }
+#endif
+
+ if (is_insn && &INSN_CODE (in_rtx) == &XINT (in_rtx, i)
+ && XINT (in_rtx, i) >= 0
+ && (name = get_insn_name (XINT (in_rtx, i))) != NULL)
+ fprintf (outfile, " {%s}", name);
+ sawclose = 0;
+ }