Commit 3bc6b3e6 by Richard Henderson

Define target hook TARGET_UNWIND_EMIT_BEFORE_INSN.

From-SVN: r163961
parent aa229804
2010-09-07 Richard Henderson <rth@redhat.com>
* target.def (unwind_emit_before_insn): New hook.
* doc/tm.texi.in: Add @hook marker for it.
* doc/tm.texi: Rebuild.
* final.c (final_scan_insn): Respect unwind_emit_before_insn.
2010-09-07 Martin Jambor <mjambor@suse.cz> 2010-09-07 Martin Jambor <mjambor@suse.cz>
PR fortran/43665 PR fortran/43665
...@@ -6,8 +13,8 @@ ...@@ -6,8 +13,8 @@
2010-09-07 Jan Hubicka <jh@suse.cz> 2010-09-07 Jan Hubicka <jh@suse.cz>
* tree-ssa-ccp.c (fold_const_aggregate_ref): Fix handling of array_ref_low_bound * tree-ssa-ccp.c (fold_const_aggregate_ref): Fix handling of
in string access folding. array_ref_low_bound in string access folding.
2010-09-07 Uros Bizjak <ubizjak@gmail.com> 2010-09-07 Uros Bizjak <ubizjak@gmail.com>
......
...@@ -8749,6 +8749,10 @@ This target hook emits assembly directives required to unwind the ...@@ -8749,6 +8749,10 @@ This target hook emits assembly directives required to unwind the
given instruction. This is only used when TARGET_UNWIND_INFO is set. given instruction. This is only used when TARGET_UNWIND_INFO is set.
@end deftypefn @end deftypefn
@deftypevr {Target Hook} bool TARGET_ASM_UNWIND_EMIT_BEFORE_INSN
True if the @code{TARGET_ASM_UNWIND_EMIT} hook should be called before the assembly for @var{insn} has been emitted, false if the hook should be called afterward.
@end deftypevr
@node Exception Region Output @node Exception Region Output
@subsection Assembler Commands for Exception Regions @subsection Assembler Commands for Exception Regions
......
...@@ -8739,6 +8739,8 @@ This target hook emits assembly directives required to unwind the ...@@ -8739,6 +8739,8 @@ This target hook emits assembly directives required to unwind the
given instruction. This is only used when TARGET_UNWIND_INFO is set. given instruction. This is only used when TARGET_UNWIND_INFO is set.
@end deftypefn @end deftypefn
@hook TARGET_ASM_UNWIND_EMIT_BEFORE_INSN
@node Exception Region Output @node Exception Region Output
@subsection Assembler Commands for Exception Regions @subsection Assembler Commands for Exception Regions
......
...@@ -2655,7 +2655,8 @@ final_scan_insn (rtx insn, FILE *file, int optimize ATTRIBUTE_UNUSED, ...@@ -2655,7 +2655,8 @@ final_scan_insn (rtx insn, FILE *file, int optimize ATTRIBUTE_UNUSED,
/* ??? This will put the directives in the wrong place if /* ??? This will put the directives in the wrong place if
get_insn_template outputs assembly directly. However calling it get_insn_template outputs assembly directly. However calling it
before get_insn_template breaks if the insns is split. */ before get_insn_template breaks if the insns is split. */
if (targetm.asm_out.unwind_emit) if (targetm.asm_out.unwind_emit_before_insn
&& targetm.asm_out.unwind_emit)
targetm.asm_out.unwind_emit (asm_out_file, insn); targetm.asm_out.unwind_emit (asm_out_file, insn);
if (CALL_P (insn)) if (CALL_P (insn))
...@@ -2713,6 +2714,10 @@ final_scan_insn (rtx insn, FILE *file, int optimize ATTRIBUTE_UNUSED, ...@@ -2713,6 +2714,10 @@ final_scan_insn (rtx insn, FILE *file, int optimize ATTRIBUTE_UNUSED,
dwarf2out_frame_debug (insn, true); dwarf2out_frame_debug (insn, true);
#endif #endif
if (!targetm.asm_out.unwind_emit_before_insn
&& targetm.asm_out.unwind_emit)
targetm.asm_out.unwind_emit (asm_out_file, insn);
current_output_insn = debug_insn = 0; current_output_insn = debug_insn = 0;
} }
} }
......
...@@ -152,6 +152,13 @@ DEFHOOK ...@@ -152,6 +152,13 @@ DEFHOOK
void, (FILE *stream, rtx insn), void, (FILE *stream, rtx insn),
NULL) NULL)
DEFHOOKPOD
(unwind_emit_before_insn,
"True if the @code{TARGET_ASM_UNWIND_EMIT} hook should be called before\
the assembly for @var{insn} has been emitted, false if the hook should\
be called afterward.",
bool, true)
/* Output an internal label. */ /* Output an internal label. */
DEFHOOK DEFHOOK
(internal_label, (internal_label,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment