diff options
| author | sayle <sayle@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-09-18 01:54:33 +0000 |
|---|---|---|
| committer | sayle <sayle@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-09-18 01:54:33 +0000 |
| commit | 6dce7ee94db2a11359a6a9e149ff5fb80a851a0d (patch) | |
| tree | 75f098e9bc265156e2b16c0f13768b250a6693ea /gcc/testsuite/gcc.dg/prefetch-loop-arrays-1.c | |
| parent | 858e3ae14cf755272565ed548aa244c14997c8a1 (diff) | |
| download | ppe42-gcc-6dce7ee94db2a11359a6a9e149ff5fb80a851a0d.tar.gz ppe42-gcc-6dce7ee94db2a11359a6a9e149ff5fb80a851a0d.zip | |
2006-09-17 Zdenek Dvorak <dvorakz@suse.cz>
PR tree-optimization/28887
* tree-ssa-loop-prefetch.c (analyze_ref): Strip nonaddressable
component parts from the reference.
(gather_memory_references_ref): Record the reference without the
nonaddressable component parts.
* gcc.dg/prefetch-loop-arrays-1.c: New test case.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@117012 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/testsuite/gcc.dg/prefetch-loop-arrays-1.c')
| -rw-r--r-- | gcc/testsuite/gcc.dg/prefetch-loop-arrays-1.c | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.dg/prefetch-loop-arrays-1.c b/gcc/testsuite/gcc.dg/prefetch-loop-arrays-1.c new file mode 100644 index 00000000000..ba91d69650d --- /dev/null +++ b/gcc/testsuite/gcc.dg/prefetch-loop-arrays-1.c @@ -0,0 +1,36 @@ +/* PR tree-optimization/28887 */ +/* { dg-do compile } */ +/* { dg-options "-O2 -fprefetch-loop-arrays -w" } */ +/* { dg-options "-O2 -fprefetch-loop-arrays -march=i686 -msse -w" { target { { i?86-*-* x86_64-*-* } && ilp32 } } } */ + +typedef unsigned long size_t; + +struct re_pattern_buffer +{ + size_t re_nsub; +}; + +typedef enum +{ + start_memory, +} re_opcode_t; + +typedef union +{ + struct + { + unsigned matched_something:1; + } bits; +} byte_register_info_type; + +void byte_re_match_2_internal (struct re_pattern_buffer *bufp) +{ + int mcnt; + size_t num_regs = bufp->re_nsub + 1; + byte_register_info_type *reg_info; + for (mcnt = 1; (unsigned) mcnt < num_regs; mcnt++) + { + ((reg_info[mcnt]).bits.matched_something) = 0; + } +} + |

