OSDN Git Service

2013-01-16 Richard Biener <rguenther@suse.de>
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 16 Jan 2013 09:26:05 +0000 (09:26 +0000)
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 16 Jan 2013 09:26:05 +0000 (09:26 +0000)
PR middle-end/55882
* emit-rtl.c (set_mem_attributes_minus_bitpos): Correctly
account for bitpos when computing alignment.

* gcc.dg/torture/pr55882.c: New testcase.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-4_7-branch@195232 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/emit-rtl.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/torture/pr55882.c [new file with mode: 0644]

index 045e47c..6ab7604 100644 (file)
@@ -1,3 +1,9 @@
+2013-01-16  Richard Biener  <rguenther@suse.de>
+
+       PR middle-end/55882
+       * emit-rtl.c (set_mem_attributes_minus_bitpos): Correctly
+       account for bitpos when computing alignment.
+
 2013-01-14  Georg-Johann Lay  <avr@gjlay.de>
 
        Backport from 2013-01-14 trunk r195169.
index a95c146..9d877a7 100644 (file)
@@ -1839,7 +1839,12 @@ set_mem_attributes_minus_bitpos (rtx ref, tree t, int objectp,
 
       if (!align_computed)
        {
-         unsigned int obj_align = get_object_alignment (t);
+         unsigned int obj_align;
+         unsigned HOST_WIDE_INT obj_bitpos;
+         obj_align = get_object_alignment_1 (t, &obj_bitpos);
+         obj_bitpos = (obj_bitpos - bitpos) & (obj_align - 1);
+         if (obj_bitpos != 0)
+           obj_align = (obj_bitpos & -obj_bitpos);
          attrs.align = MAX (attrs.align, obj_align);
        }
     }
index eaffd88..ac906b1 100644 (file)
@@ -1,3 +1,8 @@
+2013-01-16  Richard Biener  <rguenther@suse.de>
+
+       PR middle-end/55882
+       * gcc.dg/torture/pr55882.c: New testcase.
+
 2013-01-13  Janus Weil  <janus@gcc.gnu.org>
 
        PR fortran/55072
diff --git a/gcc/testsuite/gcc.dg/torture/pr55882.c b/gcc/testsuite/gcc.dg/torture/pr55882.c
new file mode 100644 (file)
index 0000000..fd2276e
--- /dev/null
@@ -0,0 +1,94 @@
+/* { dg-do run } */
+
+typedef enum
+{
+  PVT_A = 0,
+  PVT_B = 1,
+  PVT_CONFIG = 2,
+  PVT_RESERVED3 = 3,
+} T_CR_SELECT;
+
+typedef enum
+{
+  STD_ULOGIC_0 = 0,
+  STD_ULOGIC_1 = 1,
+} STD_ULOGIC;
+
+typedef struct
+{
+  unsigned char rtp : 3;
+  unsigned char rtn : 3;
+} C;
+
+typedef struct
+{
+  unsigned char nd;
+  unsigned char pd;
+  unsigned char rtn;
+  unsigned char rtp;
+} A;
+
+typedef struct
+{
+  unsigned short reserved : 14;
+  unsigned char Z_rx_enable : 2;
+  A pvt;
+} B;
+
+typedef struct
+{
+  B cr_dsclk_q3;
+  B cr_data_q3;
+  B cr_addr_q3;
+  B cr_cmd_q3;
+  B cr_pres_q3;
+  C cr_vref_q3[6];
+  unsigned char pres_disable;
+  unsigned char pres_drive_high;
+  unsigned char c_enab_120;
+  STD_ULOGIC clk_tximp;
+  STD_ULOGIC dqs_tximp;
+  STD_ULOGIC cmd_tximp;
+  STD_ULOGIC data_tximp;
+  STD_ULOGIC dqs_rxterm;
+  STD_ULOGIC data_rxterm;
+  T_CR_SELECT cr_clk_sel;
+  unsigned char cr_clk : 5;
+  T_CR_SELECT cr_dsclk_odd_sel;
+  unsigned char cr_dsclk_odd : 5;
+  T_CR_SELECT cr_dsclk_even_sel;
+  unsigned char cr_dsclk_even : 5;
+  T_CR_SELECT cr_data_sel;
+  unsigned char cr_data : 5;
+  T_CR_SELECT cr_vref_sel;
+  unsigned char cr_vref : 5;
+  T_CR_SELECT cr_others_sel;
+  unsigned char cr_others : 5;
+} CONFIG;
+
+typedef struct
+{
+  unsigned char enable_monitor;
+  unsigned short step_out_pointer : 12;
+  unsigned short hold_out_pointer : 12;
+  unsigned short enable_wr_dqs : 12;
+  unsigned short use_alt_rd_dqs : 12;
+  CONFIG io_buf;
+} mystruct;
+
+unsigned short __attribute__((noinline,noclone))
+testfunction(unsigned i)
+{
+  mystruct dmfe[8];
+  dmfe[0].use_alt_rd_dqs = 1;
+  dmfe[i].use_alt_rd_dqs = 0;
+  return dmfe[0].use_alt_rd_dqs;
+}
+
+extern void abort (void);
+int main ()
+{
+  if (testfunction(0) != 0) 
+    abort ();
+  return 0;
+}