aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorUlrich Weigand <uweigand@de.ibm.com>2005-12-18 16:06:55 +0000
committerUlrich Weigand <uweigand@gcc.gnu.org>2005-12-18 16:06:55 +0000
commit5a575f77fde8efa894e6eefa20ca7e96881fe0e1 (patch)
tree3d046856da977e0859c1d1ed467582650d5b31e1 /gcc
parente75ea710dd6d61c9ed5b5200bd3d0f6132aa606a (diff)
downloadgcc-5a575f77fde8efa894e6eefa20ca7e96881fe0e1.zip
gcc-5a575f77fde8efa894e6eefa20ca7e96881fe0e1.tar.gz
gcc-5a575f77fde8efa894e6eefa20ca7e96881fe0e1.tar.bz2
re PR rtl-optimization/21041 (ICE: output_operand: Cannot decompose address)
PR rtl-optimization/21041 * reload.c (find_reloads_subreg_address): Replace paradoxical subreg of MEM by widened access only if the resulting memory is properly aligned, even on !STRICT_ALIGNMENT targets. PR rtl-optimization/21041 * gcc.dg/pr21041.c: New test. From-SVN: r108760
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/reload.c2
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/pr21041.c42
4 files changed, 55 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6e4f1ff..bf05ff9 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2005-12-18 Ulrich Weigand <uweigand@de.ibm.com>
+
+ PR rtl-optimization/21041
+ * reload.c (find_reloads_subreg_address): Replace paradoxical
+ subreg of MEM by widened access only if the resulting memory
+ is properly aligned, even on !STRICT_ALIGNMENT targets.
+
2005-12-18 Andreas Krebbel <krebbel1@de.ibm.com>
* tree-cfg.c (tree_flow_call_edges_add): Check for empty basic blocks.
diff --git a/gcc/reload.c b/gcc/reload.c
index 7066f7d..2b61a8e 100644
--- a/gcc/reload.c
+++ b/gcc/reload.c
@@ -5911,7 +5911,7 @@ find_reloads_subreg_address (rtx x, int force_replace, int opnum,
/* If this was a paradoxical subreg that we replaced, the
resulting memory must be sufficiently aligned to allow
us to widen the mode of the memory. */
- if (outer_size > inner_size && STRICT_ALIGNMENT)
+ if (outer_size > inner_size)
{
rtx base;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 87e1de6..4174961 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2005-12-18 Ulrich Weigand <uweigand@de.ibm.com>
+
+ PR rtl-optimization/21041
+ * gcc.dg/pr21041.c: New test.
+
2005-12-18 Andreas Krebbel <krebbel1@de.ibm.com>
* gcc.dg/20051201-1.c: New test.
diff --git a/gcc/testsuite/gcc.dg/pr21041.c b/gcc/testsuite/gcc.dg/pr21041.c
new file mode 100644
index 0000000..34ed14d
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr21041.c
@@ -0,0 +1,42 @@
+
+/* { dg-do compile { target fpic } } */
+/* { dg-options "-O2 -fPIC" } */
+
+struct args
+{
+ short int matrix[8][8];
+ char **current;
+};
+
+int test (struct args *args, char *init, int a, int b)
+{
+ int i, j, k;
+
+ if (!args || a > b || a < 0)
+ return -1;
+
+ for (i = 0; i < 2; i++)
+ {
+ char *dest = *args->current;
+ char *p = dest;
+
+ for (j = 0; j < 8; j++)
+ *p++ = *init++;
+
+ for (k = 0; k < 8; k++)
+ {
+ short int *blockvals = &args->matrix[k][0];
+ dest[0] += blockvals[0];
+ dest[1] += blockvals[1];
+ dest[2] += blockvals[2];
+ dest[3] += blockvals[3];
+ dest[4] += blockvals[4];
+ dest[5] += blockvals[5];
+ dest[6] += blockvals[6];
+ dest[7] += blockvals[7];
+ }
+ }
+
+ return 1;
+}
+