From fd2c87bd741c8438951f403efd95e50ccf3d8eda Mon Sep 17 00:00:00 2001 From: Geoffrey Keating Date: Thu, 26 Apr 2001 20:56:08 +0000 Subject: [PATCH] sparc.md (movsf_no_f_insn): Add more alternatives common to other movsf patterns. * config/sparc/sparc.md (movsf_no_f_insn): Add more alternatives common to other movsf patterns. Move up so that in future people who change the other patterns will change it too. (movsf_lo_sum): Allow even for soft-float; add appropriate constraints. (movsf_high): Likewise. (movsf_high+1): Allow even for soft-float. From-SVN: r41613 --- gcc/ChangeLog | 10 ++++- gcc/config/sparc/sparc.md | 81 ++++++++++++++++++++++++++------------- 2 files changed, 63 insertions(+), 28 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 957f0471d52..6635036143c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,13 @@ 2001-04-26 Geoffrey Keating + * config/sparc/sparc.md (movsf_no_f_insn): Add more alternatives + common to other movsf patterns. Move up so that in future + people who change the other patterns will change it too. + (movsf_lo_sum): Allow even for soft-float; add appropriate + constraints. + (movsf_high): Likewise. + (movsf_high+1): Allow even for soft-float. + * function.c (expand_function_end): Always clobber the return registers, even if there is no return label. @@ -82,7 +90,6 @@ Thu Apr 26 19:20:28 CEST 2001 Jan Hubicka * config/i386/i386.h (CC1_CPU_SPEC): Fix deprecation warnings for -m386 and -m486. ->>>>>>> 1.9867 2001-04-26 Alexandre Oliva * configure.in (configargs.h): Define thread_model. @@ -167,7 +174,6 @@ Wed Apr 25 17:09:50 2001 J"orn Rennecke (get_exception_filter): New fn. (finish_eh_generation): Use it. ->>>>>>> 1.9859 2001-04-24 Nathan Sidwell * c-semantics.c (add_scope_stmt): Don't call diff --git a/gcc/config/sparc/sparc.md b/gcc/config/sparc/sparc.md index cf7ae098196..d0a3f40b482 100644 --- a/gcc/config/sparc/sparc.md +++ b/gcc/config/sparc/sparc.md @@ -3095,11 +3095,58 @@ [(set_attr "type" "fpmove,fpmove,move,move,move,*,load,fpload,fpstore,store") (set_attr "length" "1")]) +;; Exactly the same as above, except that all `f' cases are deleted. +;; This is necessary to prevent reload from ever trying to use a `f' reg +;; when -mno-fpu. + +(define_insn "*movsf_no_f_insn" + [(set (match_operand:SF 0 "nonimmediate_operand" "=r,r,r,r,r,m") + (match_operand:SF 1 "input_operand" "G,Q,rR,S,m,rG"))] + "! TARGET_FPU + && (register_operand (operands[0], SFmode) + || register_operand (operands[1], SFmode) + || fp_zero_operand (operands[1], SFmode))" + "* +{ + if (GET_CODE (operands[1]) == CONST_DOUBLE + && (which_alternative == 1 + || which_alternative == 2 + || which_alternative == 3)) + { + REAL_VALUE_TYPE r; + long i; + + REAL_VALUE_FROM_CONST_DOUBLE (r, operands[1]); + REAL_VALUE_TO_TARGET_SINGLE (r, i); + operands[1] = GEN_INT (i); + } + + switch (which_alternative) + { + case 0: + return \"clr\\t%0\"; + case 1: + return \"sethi\\t%%hi(%a1), %0\"; + case 2: + return \"mov\\t%1, %0\"; + case 3: + return \"#\"; + case 4: + return \"ld\\t%1, %0\"; + case 5: + return \"st\\t%r1, %0\"; + default: + abort(); + } +}" + [(set_attr "type" "move,move,move,*,load,store") + (set_attr "length" "1")]) + (define_insn "*movsf_lo_sum" - [(set (match_operand:SF 0 "register_operand" "") - (lo_sum:SF (match_operand:SF 1 "register_operand" "") - (match_operand:SF 2 "const_double_operand" "")))] - "TARGET_FPU && fp_high_losum_p (operands[2])" + [(set (match_operand:SF 0 "register_operand" "=r") + (lo_sum:SF (match_operand:SF 1 "register_operand" "r") + (match_operand:SF 2 "const_double_operand" "S")))] + "fp_high_losum_p (operands[2])" "* { REAL_VALUE_TYPE r; @@ -3114,9 +3161,9 @@ (set_attr "length" "1")]) (define_insn "*movsf_high" - [(set (match_operand:SF 0 "register_operand" "") - (high:SF (match_operand:SF 1 "const_double_operand" "")))] - "TARGET_FPU && fp_high_losum_p (operands[1])" + [(set (match_operand:SF 0 "register_operand" "=r") + (high:SF (match_operand:SF 1 "const_double_operand" "S")))] + "fp_high_losum_p (operands[1])" "* { REAL_VALUE_TYPE r; @@ -3133,30 +3180,12 @@ (define_split [(set (match_operand:SF 0 "register_operand" "") (match_operand:SF 1 "const_double_operand" ""))] - "TARGET_FPU - && fp_high_losum_p (operands[1]) + "fp_high_losum_p (operands[1]) && (GET_CODE (operands[0]) == REG && REGNO (operands[0]) < 32)" [(set (match_dup 0) (high:SF (match_dup 1))) (set (match_dup 0) (lo_sum:SF (match_dup 0) (match_dup 1)))]) -;; Exactly the same as above, except that all `f' cases are deleted. -;; This is necessary to prevent reload from ever trying to use a `f' reg -;; when -mno-fpu. - -(define_insn "*movsf_no_f_insn" - [(set (match_operand:SF 0 "nonimmediate_operand" "=r,r,m") - (match_operand:SF 1 "input_operand" "r,m,r"))] - "! TARGET_FPU - && (register_operand (operands[0], SFmode) - || register_operand (operands[1], SFmode))" - "@ - mov\\t%1, %0 - ld\\t%1, %0 - st\\t%1, %0" - [(set_attr "type" "move,load,store") - (set_attr "length" "1")]) - (define_expand "movsf" [(set (match_operand:SF 0 "general_operand" "") (match_operand:SF 1 "general_operand" ""))] -- 2.30.2