mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-04 19:31:14 +08:00
flags.h (flag_dump_rtl_in_asm): Declare.
* flags.h (flag_dump_rtl_in_asm): Declare. * toplev.c (flag_dump_rtl_in_asm): Define. (decode_d_option): Set flag_dump_rtl_in_asm and flag_print_asm_name if -dP is specified. * rtl.h (print_rtx_head): Declare. * print-rtl.c (print_rtx_head): Define. (print_rtx): Print the string pointed to by print_rtx_head at beginning of each dump line. (print_rtl): Likewise. (print_rtl_single): Likewise. * final.c (final_scan_insn): Dump the insn in the assembly file for debugging. * gcc.1: Document -dP option. * invoke.texi (Debugging Options): Likewise. From-SVN: r36394
This commit is contained in:
parent
2856c3e3f5
commit
c349e40b5b
@ -1,3 +1,20 @@
|
||||
2000-09-13 Stephane Carrez <Stephane.Carrez@worldnet.fr>
|
||||
|
||||
* flags.h (flag_dump_rtl_in_asm): Declare.
|
||||
* toplev.c (flag_dump_rtl_in_asm): Define.
|
||||
(decode_d_option): Set flag_dump_rtl_in_asm and flag_print_asm_name
|
||||
if -dP is specified.
|
||||
* rtl.h (print_rtx_head): Declare.
|
||||
* print-rtl.c (print_rtx_head): Define.
|
||||
(print_rtx): Print the string pointed to by print_rtx_head
|
||||
at beginning of each dump line.
|
||||
(print_rtl): Likewise.
|
||||
(print_rtl_single): Likewise.
|
||||
* final.c (final_scan_insn): Dump the insn in the assembly
|
||||
file for debugging.
|
||||
* gcc.1: Document -dP option.
|
||||
* invoke.texi (Debugging Options): Likewise.
|
||||
|
||||
2000-09-13 Stephane Carrez <Stephane.Carrez@worldnet.fr>
|
||||
|
||||
* md.texi (Machine Constraints): Document the 68HC11 constraints.
|
||||
|
@ -2922,6 +2922,14 @@ final_scan_insn (insn, file, optimize, prescan, nopeepholes)
|
||||
extract_insn (insn);
|
||||
cleanup_subreg_operands (insn);
|
||||
|
||||
/* Dump the insn in the assembly for debugging. */
|
||||
if (flag_dump_rtl_in_asm)
|
||||
{
|
||||
print_rtx_head = ASM_COMMENT_START;
|
||||
print_rtl_single (asm_out_file, insn);
|
||||
print_rtx_head = "";
|
||||
}
|
||||
|
||||
if (! constrain_operands (1))
|
||||
fatal_insn_not_found (insn);
|
||||
|
||||
|
@ -474,6 +474,8 @@ extern int flag_verbose_asm;
|
||||
|
||||
extern int flag_debug_asm;
|
||||
|
||||
extern int flag_dump_rtl_in_asm;
|
||||
|
||||
/* -fgnu-linker specifies use of the GNU linker for initializations.
|
||||
-fno-gnu-linker says that collect will be used. */
|
||||
extern int flag_gnu_linker;
|
||||
|
@ -20,7 +20,7 @@
|
||||
.if n .sp
|
||||
.if t .sp 0.4
|
||||
..
|
||||
.Id $Id: gcc.1,v 1.15 2000/05/17 08:15:25 cagney Exp $
|
||||
.Id $Id: gcc.1,v 1.16 2000/09/11 06:10:30 ciceron Exp $
|
||||
.TH GCC 1 "\*(Dt" "GNU Tools" "GNU Tools"
|
||||
.SH NAME
|
||||
gcc, g++ \- GNU project C and C++ Compiler (gcc-2.96)
|
||||
@ -2311,6 +2311,12 @@ standard error.
|
||||
Annotate the assembler output with a comment indicating which
|
||||
pattern and alternative was used.
|
||||
.TP
|
||||
.B \-dP
|
||||
Dump the RTL in the assembler output as a comment before each instruction.
|
||||
Also turns on
|
||||
.B \-dp
|
||||
annotation.
|
||||
.TP
|
||||
.B \-fpretend\-float
|
||||
When running a cross-compiler, pretend that the target machine uses the
|
||||
same floating point format as the host machine. This causes incorrect
|
||||
|
@ -55,6 +55,11 @@ static int indent;
|
||||
|
||||
static void print_rtx PARAMS ((rtx));
|
||||
|
||||
/* String printed at beginning of each RTL when it is dumped.
|
||||
This string is set to ASM_COMMENT_START when the RTL is dumped in
|
||||
the assembly output file. */
|
||||
char *print_rtx_head = "";
|
||||
|
||||
/* Nonzero means suppress output of instruction numbers and line number
|
||||
notes in debugging dumps.
|
||||
This must be defined here so that programs like gencodes can be linked. */
|
||||
@ -80,8 +85,9 @@ print_rtx (in_rtx)
|
||||
|
||||
if (sawclose)
|
||||
{
|
||||
fprintf (outfile, "\n%s",
|
||||
(xspaces + (sizeof xspaces - 1 - indent * 2)));
|
||||
fprintf (outfile, "\n%s%s",
|
||||
print_rtx_head,
|
||||
(xspaces + (sizeof xspaces - 1 - indent * 2)));
|
||||
sawclose = 0;
|
||||
}
|
||||
|
||||
@ -256,7 +262,8 @@ print_rtx (in_rtx)
|
||||
indent += 2;
|
||||
if (sawclose)
|
||||
{
|
||||
fprintf (outfile, "\n%s",
|
||||
fprintf (outfile, "\n%s%s",
|
||||
print_rtx_head,
|
||||
(xspaces + (sizeof xspaces - 1 - indent * 2)));
|
||||
sawclose = 0;
|
||||
}
|
||||
@ -273,7 +280,8 @@ print_rtx (in_rtx)
|
||||
indent -= 2;
|
||||
}
|
||||
if (sawclose)
|
||||
fprintf (outfile, "\n%s",
|
||||
fprintf (outfile, "\n%s%s",
|
||||
print_rtx_head,
|
||||
(xspaces + (sizeof xspaces - 1 - indent * 2)));
|
||||
|
||||
fputs ("] ", outfile);
|
||||
@ -600,7 +608,10 @@ print_rtl (outf, rtx_first)
|
||||
sawclose = 0;
|
||||
|
||||
if (rtx_first == 0)
|
||||
fputs ("(nil)\n", outf);
|
||||
{
|
||||
fputs (print_rtx_head, outf);
|
||||
fputs ("(nil)\n", outf);
|
||||
}
|
||||
else
|
||||
switch (GET_CODE (rtx_first))
|
||||
{
|
||||
@ -614,12 +625,14 @@ print_rtl (outf, rtx_first)
|
||||
if (! flag_dump_unnumbered
|
||||
|| GET_CODE (tmp_rtx) != NOTE || NOTE_LINE_NUMBER (tmp_rtx) < 0)
|
||||
{
|
||||
fputs (print_rtx_head, outfile);
|
||||
print_rtx (tmp_rtx);
|
||||
fprintf (outfile, "\n");
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
fputs (print_rtx_head, outfile);
|
||||
print_rtx (rtx_first);
|
||||
}
|
||||
}
|
||||
@ -637,6 +650,7 @@ print_rtl_single (outf, x)
|
||||
if (! flag_dump_unnumbered
|
||||
|| GET_CODE (x) != NOTE || NOTE_LINE_NUMBER (x) < 0)
|
||||
{
|
||||
fputs (print_rtx_head, outfile);
|
||||
print_rtx (x);
|
||||
putc ('\n', outf);
|
||||
return 1;
|
||||
|
@ -1747,6 +1747,7 @@ extern void schedule_insns PARAMS ((FILE *));
|
||||
extern void fix_sched_param PARAMS ((const char *, const char *));
|
||||
|
||||
/* In print-rtl.c */
|
||||
extern char *print_rtx_head;
|
||||
extern void debug_rtx PARAMS ((rtx));
|
||||
extern void debug_rtx_list PARAMS ((rtx, int));
|
||||
extern void debug_rtx_range PARAMS ((rtx, rtx));
|
||||
|
@ -795,6 +795,10 @@ int flag_verbose_asm = 0;
|
||||
|
||||
int flag_debug_asm = 0;
|
||||
|
||||
/* -dP causes the rtl to be emitted as a comment in assembly. */
|
||||
|
||||
int flag_dump_rtl_in_asm = 0;
|
||||
|
||||
/* -fgnu-linker specifies use of the GNU linker for initializations.
|
||||
(Or, more generally, a linker that handles initializations.)
|
||||
-fno-gnu-linker says that collect2 will be used. */
|
||||
@ -3970,6 +3974,10 @@ decode_d_option (arg)
|
||||
case 'p':
|
||||
flag_print_asm_name = 1;
|
||||
break;
|
||||
case 'P':
|
||||
flag_dump_rtl_in_asm = 1;
|
||||
flag_print_asm_name = 1;
|
||||
break;
|
||||
case 'v':
|
||||
graph_dump_format = vcg;
|
||||
break;
|
||||
|
Loading…
x
Reference in New Issue
Block a user