]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
hppa: Fix LO_SUM DLTIND14R address support in PRINT_OPERAND_ADDRESS
authorJohn David Anglin <danglin@gcc.gnu.org>
Sat, 23 Mar 2024 13:47:31 +0000 (13:47 +0000)
committerJohn David Anglin <danglin@gcc.gnu.org>
Sat, 23 Mar 2024 13:47:31 +0000 (13:47 +0000)
This bug was hidden since LO_SUM DLTIND14R addresses are normally
handled by the A constraint in the move patterns.

2024-03-23  John David Anglin  <danglin@gcc.gnu.org>

gcc/ChangeLog:

* config/pa/pa.cc (pa_output_global_address): Handle
UNSPEC_DLTIND14R addresses.
* config/pa/pa.h (PRINT_OPERAND_ADDRESS): Output "RT'" for
UNSPEC_DLTIND14R address.

gcc/config/pa/pa.cc
gcc/config/pa/pa.h

index d7666103de8f3ccf4e14dc476fea70af7ad37b67..a7af6b8c121f7720ea73bf1297a4ee2c98719772 100644 (file)
@@ -5784,7 +5784,12 @@ pa_output_global_address (FILE *file, rtx x, int round_constant)
   if (GET_CODE (x) == HIGH)
     x = XEXP (x, 0);
 
-  if (GET_CODE (x) == SYMBOL_REF && read_only_operand (x, VOIDmode))
+  if (GET_CODE (x) == UNSPEC && XINT (x, 1) == UNSPEC_DLTIND14R)
+    {
+      x = XVECEXP (x, 0, 0);
+      output_addr_const (file, x);
+    }
+  else if (GET_CODE (x) == SYMBOL_REF && read_only_operand (x, VOIDmode))
     output_addr_const (file, x);
   else if (GET_CODE (x) == SYMBOL_REF && !flag_pic)
     {
index 403f16c5cb596f1f1cf22d78d86c54a7137db04a..127a0d1966d28a3f03400f98a1f54b6d83e03780 100644 (file)
@@ -1247,12 +1247,15 @@ do {                                                                         \
               reg_names [REGNO (XEXP (addr, 0))]);                     \
       break;                                                           \
     case LO_SUM:                                                       \
-      if (!symbolic_operand (XEXP (addr, 1), VOIDmode))                        \
+      if (GET_CODE (XEXP (addr, 1)) == UNSPEC                          \
+         && XINT (XEXP (addr, 1), 1) == UNSPEC_DLTIND14R)              \
+       fputs ("RT'", FILE);                                            \
+      else if (!symbolic_operand (XEXP (addr, 1), VOIDmode))           \
        fputs ("R'", FILE);                                             \
       else if (flag_pic == 0)                                          \
        fputs ("RR'", FILE);                                            \
       else                                                             \
-       fputs ("RT'", FILE);                                            \
+       gcc_unreachable ();                                             \
       pa_output_global_address (FILE, XEXP (addr, 1), 0);              \
       fputs ("(", FILE);                                               \
       output_operand (XEXP (addr, 0), 0);                              \