OSDN Git Service

PR debug/45003
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 20 Jul 2010 12:58:03 +0000 (12:58 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 20 Jul 2010 12:58:03 +0000 (12:58 +0000)
* cfgexpand.c (expand_debug_expr) <case NOP_EXPR>: Use ZERO_EXTEND
or SIGN_EXTEND depending on TYPE_UNSIGNED of the operand's type
instead of the result's type.

* gcc.dg/guality/pr45003-1.c: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@162336 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/cfgexpand.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/guality/pr45003-1.c [new file with mode: 0644]

index 2065af6..f7598eb 100644 (file)
@@ -1,3 +1,10 @@
+2010-07-20  Jakub Jelinek  <jakub@redhat.com>
+
+       PR debug/45003
+       * cfgexpand.c (expand_debug_expr) <case NOP_EXPR>: Use ZERO_EXTEND
+       or SIGN_EXTEND depending on TYPE_UNSIGNED of the operand's type
+       instead of the result's type.
+
 2010-07-20  Richard Guenther  <rguenther@suse.de>
 
        PR tree-optimization/44977
index d8378ee..3d7bdd0 100644 (file)
@@ -2427,7 +2427,7 @@ expand_debug_expr (tree exp)
          op0 = simplify_gen_subreg (mode, op0, inner_mode,
                                     subreg_lowpart_offset (mode,
                                                            inner_mode));
-       else if (unsignedp)
+       else if (TYPE_UNSIGNED (TREE_TYPE (TREE_OPERAND (exp, 0))))
          op0 = gen_rtx_ZERO_EXTEND (mode, op0);
        else
          op0 = gen_rtx_SIGN_EXTEND (mode, op0);
index ae38e84..391d88f 100644 (file)
@@ -1,3 +1,8 @@
+2010-07-20  Jakub Jelinek  <jakub@redhat.com>
+
+       PR debug/45003
+       * gcc.dg/guality/pr45003-1.c: New test.
+
 2010-07-20  Richard Guenther  <rguenther@suse.de>
 
        PR tree-optimization/44977
diff --git a/gcc/testsuite/gcc.dg/guality/pr45003-1.c b/gcc/testsuite/gcc.dg/guality/pr45003-1.c
new file mode 100644 (file)
index 0000000..7cef8f6
--- /dev/null
@@ -0,0 +1,31 @@
+/* PR debug/45003 */
+/* { dg-do run { target { x86_64-*-* && lp64 } } } */
+/* { dg-options "-g" } */
+
+int __attribute__((noinline))
+foo (unsigned short *p)
+{
+  int a = *p;
+  asm volatile ("nop");
+  asm volatile ("nop" : : "D" (a));    /* { dg-final { gdb-test 10 "a" "0x8078" } } */
+  return 0;
+}
+
+int __attribute__((noinline))
+bar (short *p)
+{
+  unsigned int a = *p;
+  asm volatile ("nop");
+  asm volatile ("nop" : : "D" (a));    /* { dg-final { gdb-test 19 "a" "0xffff8078" } } */
+  return 0;
+}
+
+int
+main ()
+{
+  unsigned short us = 0x8078;
+  foo (&us);
+  short s = -32648;
+  bar (&s);
+  return 0;
+}