mirror of the now-defunct rocklinux.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

47 lines
2.0 KiB

  1. copied from the crosstool project (0.38) - see http://kegel.com/crosstool/
  2. - stf
  3. See http://gcc.gnu.org/PR15068
  4. Fixes error
  5. ../sysdeps/generic/s_fmax.c: In function `__fmax':
  6. ../sysdeps/generic/s_fmax.c:28: internal compiler error: in elim_reg_cond, at flow.c:3257
  7. Please submit a full bug report,
  8. with preprocessed source if appropriate.
  9. See <URL:http://gcc.gnu.org/bugs.html> for instructions.
  10. make[2]: *** [/home/dank/wk/crosstool-0.28-rc35/build/arm-unknown-linux-gnu/gcc-3.4.1-glibc-20040822/build-glibc/math/s_fmax.o] Error 1
  11. make[2]: Leaving directory `/home/dank/wk/crosstool-0.28-rc35/build/arm-unknown-linux-gnu/gcc-3.4.1-glibc-20040822/glibc-20040822/math'
  12. make[1]: *** [math/others] Error 2
  13. make[1]: Leaving directory `/home/dank/wk/crosstool-0.28-rc35/build/arm-unknown-linux-gnu/gcc-3.4.1-glibc-20040822/glibc-20040822'
  14. make: *** [all] Error 2
  15. [ rediffed against gcc-3.4.1, with elbow grease, ending up with same thing as
  16. http://gcc.gnu.org/cgi-bin/cvsweb.cgi/gcc/gcc/flow.c.diff?cvsroot=gcc&only_with_tag=csl-arm-branch&r1=1.563.4.2&r2=1.563.4.3 ]
  17. --- gcc-3.4.1/gcc/flow.c.old 2004-02-27 19:39:19.000000000 -0800
  18. +++ gcc-3.4.1/gcc/flow.c 2004-08-26 07:29:46.000000000 -0700
  19. @@ -1878,6 +1878,7 @@
  20. rtx set_src = SET_SRC (pc_set (BB_END (bb)));
  21. rtx cond_true = XEXP (set_src, 0);
  22. rtx reg = XEXP (cond_true, 0);
  23. + enum rtx_code inv_cond;
  24. if (GET_CODE (reg) == SUBREG)
  25. reg = SUBREG_REG (reg);
  26. @@ -1886,11 +1887,13 @@
  27. in the form of a comparison of a register against zero.
  28. If the condition is more complex than that, then it is safe
  29. not to record any information. */
  30. - if (GET_CODE (reg) == REG
  31. + inv_cond = reversed_comparison_code (cond_true, BB_END (bb));
  32. + if (inv_cond != UNKNOWN
  33. + && GET_CODE (reg) == REG
  34. && XEXP (cond_true, 1) == const0_rtx)
  35. {
  36. rtx cond_false
  37. - = gen_rtx_fmt_ee (reverse_condition (GET_CODE (cond_true)),
  38. + = gen_rtx_fmt_ee (inv_cond,
  39. GET_MODE (cond_true), XEXP (cond_true, 0),
  40. XEXP (cond_true, 1));
  41. if (GET_CODE (XEXP (set_src, 1)) == PC)