From: danglin Date: Sun, 26 Sep 2004 19:37:56 +0000 (+0000) Subject: * pa.c (print_operand): Use non-trapping completers for UNLE, UNLT, X-Git-Url: http://git.sourceforge.jp/view?p=pf3gnuchains%2Fgcc-fork.git;a=commitdiff_plain;h=321c1598d3c14de50c9ff1966da91b4003fbf719 * pa.c (print_operand): Use non-trapping completers for UNLE, UNLT, UNGE, UNGT, UNEQ, UNORDERED and ORDERED comparisons. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@88144 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9c745f9e01b..4268e3809f3 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2004-09-26 John David Anglin + + * pa.c (print_operand): Use non-trapping completers for UNLE, UNLT, + UNGE, UNGT, UNEQ, UNORDERED and ORDERED comparisons. + 2004-09-26 Ulrich Weigand * builtins.c (expand_builtin_memcmp): Adjust MEM_SIZE to diff --git a/gcc/config/pa/pa.c b/gcc/config/pa/pa.c index a4edfeb19cb..5f21e175093 100644 --- a/gcc/config/pa/pa.c +++ b/gcc/config/pa/pa.c @@ -5102,7 +5102,10 @@ print_operand (FILE *file, rtx x, int code) } return; /* For floating point comparisons. Note that the output - predicates are the complement of the desired mode. */ + predicates are the complement of the desired mode. The + conditions for GT, GE, LT, LE and LTGT cause an invalid + operation exception if the result is unordered and this + exception is enabled in the floating-point status register. */ case 'Y': switch (GET_CODE (x)) { @@ -5121,19 +5124,19 @@ print_operand (FILE *file, rtx x, int code) case LTGT: fputs ("!<>", file); break; case UNLE: - fputs (">", file); break; + fputs ("!?<=", file); break; case UNLT: - fputs (">=", file); break; + fputs ("!?<", file); break; case UNGE: - fputs ("<", file); break; + fputs ("!?>=", file); break; case UNGT: - fputs ("<=", file); break; + fputs ("!?>", file); break; case UNEQ: - fputs ("<>", file); break; + fputs ("!?=", file); break; case UNORDERED: - fputs ("<=>", file); break; + fputs ("!?", file); break; case ORDERED: - fputs ("!<=>", file); break; + fputs ("?", file); break; default: abort (); }