diff options
author | ebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-05-25 22:34:36 +0000 |
---|---|---|
committer | ebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-05-25 22:34:36 +0000 |
commit | cbeb677e2ce01e4bae1d9af26ac91d9eb839507d (patch) | |
tree | 68704a635c87543f5b0b6647ea71731266f962b4 /gcc/config/rx/rx.md | |
parent | 28ca4cf5973b4a38dd922a6007bcd27c457ed2fa (diff) | |
download | gcc-cbeb677e2ce01e4bae1d9af26ac91d9eb839507d.tar.gz |
* function.h (struct function): Add can_throw_non_call_exceptions bit.
* lto-streamer-in.c (input_function): Stream it in.
* lto-streamer-out.c (output_function): Stream it out.
* function.c (allocate_struct_function): Set it.
(expand_function_end): Substitute cfun->can_throw_non_call_exceptions
for flag_non_call_exceptions.
* cfgbuild.c (control_flow_insn_p): Likewise.
(make_edges): Likewise.
* cfgexpand.c (expand_stack_alignment): Likewise.
* combine.c (distribute_notes): Likewise.
* cse.c (cse_extended_basic_block): Likewise.
* except.c (insn_could_throw_p): Likewise.
* gcse.c (simple_mem): Likewise.
* ipa-pure-const.c (check_call): Likewise.
(check_stmt ): Likewise.
* lower-subreg.c (lower-subreg.c): Likewise.
* optabs.c (emit_libcall_block): Likewise.
(prepare_cmp_insn): Likewise.
* postreload-gcse.c (eliminate_partially_redundant_loads): Likewise.
* postreload.c (rest_of_handle_postreload): Likewise.
* reload1.c (reload_as_needed): Likewise.
(emit_input_reload_insns): Likewise.
(emit_output_reload_insns): Likewise.
(fixup_abnormal_edges): Likewise.
* sel-sched-ir.c (init_global_and_expr_for_insn): Likewise.
* store-motion.c (find_moveable_store): Likewise.
* tree-eh.c (stmt_could_throw_p): Likewise.
(tree_could_throw_p): Likewise.
* tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Likewise.
* config/arm/arm.c (arm_expand_prologue): Likewise.
(thumb1_expand_prologue): Likewise.
* config/rx/rx.md (cbranchsf4): Likewise.
(cmpsf): Likewise.
* config/s390/s390.c (s390_emit_prologue): Likewise.
* tree-inline.c (initialize_cfun): Copy can_throw_non_call_exceptions.
(inline_forbidden_into_p): New predicate.
(expand_call_inline): Use it to forbid inlining.
(tree_can_inline_p): Likewise.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@159847 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config/rx/rx.md')
-rw-r--r-- | gcc/config/rx/rx.md | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/gcc/config/rx/rx.md b/gcc/config/rx/rx.md index 0e76a5e6412..274ce6f3c66 100644 --- a/gcc/config/rx/rx.md +++ b/gcc/config/rx/rx.md @@ -176,7 +176,7 @@ [(cc0) (const_int 0)]) (label_ref (match_operand 3 "")) (pc)))] - "ALLOW_RX_FPU_INSNS && ! flag_non_call_exceptions" + "ALLOW_RX_FPU_INSNS && !cfun->can_throw_non_call_exceptions" "" ) @@ -211,7 +211,7 @@ (set_attr "length" "2,2,3,4,5,6,5")] ) -;; This pattern is disabled when -fnon-call-exceptions is active because +;; This pattern is disabled if the function can throw non-call exceptions, ;; it could generate a floating point exception, which would introduce an ;; edge into the flow graph between this insn and the conditional branch ;; insn to follow, thus breaking the cc0 relationship. Run the g++ test @@ -220,7 +220,7 @@ [(set (cc0) (compare:CC (match_operand:SF 0 "register_operand" "r,r,r") (match_operand:SF 1 "rx_source_operand" "r,i,Q")))] - "ALLOW_RX_FPU_INSNS && ! flag_non_call_exceptions" + "ALLOW_RX_FPU_INSNS && !cfun->can_throw_non_call_exceptions" { rx_float_compare_mode = true; return "fcmp\t%1, %0"; |