From 69049ba07afa22a5686db85e7e9a1602be795d62 Mon Sep 17 00:00:00 2001 From: John David Anglin Date: Sun, 26 Sep 2004 19:37:56 +0000 Subject: [PATCH] pa.c (print_operand): Use non-trapping completers for UNLE... * pa.c (print_operand): Use non-trapping completers for UNLE, UNLT, UNGE, UNGT, UNEQ, UNORDERED and ORDERED comparisons. From-SVN: r88144 --- gcc/ChangeLog | 5 +++++ gcc/config/pa/pa.c | 19 +++++++++++-------- 2 files changed, 16 insertions(+), 8 deletions(-) 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 (); } -- 2.30.2