+2002-10-23 Jakub Jelinek <jakub@redhat.com>
+
+ * config/i386/i386.c (local_symbolic_operand): Move LABEL_REF test
+ after CONST test.
+
2002-10-23 Steve Ellcey <sje@cup.hp.com>
* config/ia64/ia64.c (hfa_element_mode): Don't allow 128 bit floats
rtx op;
enum machine_mode mode ATTRIBUTE_UNUSED;
{
- if (GET_CODE (op) == LABEL_REF)
- return 1;
-
if (GET_CODE (op) == CONST
&& GET_CODE (XEXP (op, 0)) == PLUS
&& GET_CODE (XEXP (XEXP (op, 0), 1)) == CONST_INT
&& INTVAL (XEXP (XEXP (op, 0), 1)) < 16*1024*1024)))
op = XEXP (XEXP (op, 0), 0);
+ if (GET_CODE (op) == LABEL_REF)
+ return 1;
+
if (GET_CODE (op) != SYMBOL_REF)
return 0;
+2002-10-23 Jakub Jelinek <jakub@redhat.com>
+
+ * gcc.dg/20021023-1.c: New test.
+
2002-10-23 Mark Mitchell <mark@codesourcery.com>
PR c++/7679
--- /dev/null
+/* This testcase ICEd on x86-64 because LABEL_REF + small const was not
+ considered as local_symbolic_operand. */
+/* { dg-do compile } */
+/* { dg-options "-O2 -fpic" } */
+
+typedef __builtin_va_list va_list;
+
+static unsigned int
+foo (void *a, float b, const char *c, va_list d, void *e)
+{
+ return -1;
+}
+
+unsigned int
+bar (void *a, float b, const char *c, ...)
+{
+ va_list args;
+ unsigned int d;
+
+ __builtin_stdarg_start (args, c);
+ d = foo (a, b, c, args, a);
+ __builtin_va_end (args);
+ return d;
+}