From 88d03811f89e6e0b1f63bdc7f61d9380645b1adf Mon Sep 17 00:00:00 2001 From: Jan Hubicka <jh@suse.cz> Date: Thu, 13 Jul 2006 22:49:34 +0200 Subject: [PATCH] cgraphunit.c (cgraph_varpool_analyze_pending_decls): Call align_variable. * cgraphunit.c (cgraph_varpool_analyze_pending_decls): Call align_variable. * output.h (align_variable): Declare. * varasm.c (align_variable): Export. * value-prof.c (tree_value_profile_transformations): Recompute iterator when basic block changed. From-SVN: r115421 --- gcc/ChangeLog | 9 +++++++++ gcc/cgraphunit.c | 4 ++++ gcc/output.h | 4 ++++ gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/gcc.target/i386/memcpy-1.c | 16 ++++++++++++++++ gcc/value-prof.c | 6 +++++- gcc/varasm.c | 2 +- 7 files changed, 43 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/gcc.target/i386/memcpy-1.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index dd490fa8a054..72167faf510a 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,12 @@ +2006-07-13 Jan Hubicka <jh@suse.cz> + + * cgraphunit.c (cgraph_varpool_analyze_pending_decls): Call + align_variable. + * output.h (align_variable): Declare. + * varasm.c (align_variable): Export. + * value-prof.c (tree_value_profile_transformations): Recompute iterator + when basic block changed. + 2006-07-13 Nick Clifton <nickc@redhat.com> * config/sh/sh.c (sh_reorg): Ignore deleted insns whilst diff --git a/gcc/cgraphunit.c b/gcc/cgraphunit.c index 33028b2f331a..d02ead5fcff1 100644 --- a/gcc/cgraphunit.c +++ b/gcc/cgraphunit.c @@ -281,6 +281,10 @@ cgraph_varpool_analyze_pending_decls (void) cgraph_varpool_first_unanalyzed_node = cgraph_varpool_first_unanalyzed_node->next_needed; + /* Compute the alignment early so function body expanders are + already informed about increased alignment. */ + align_variable (decl, 0); + if (DECL_INITIAL (decl)) { visited_nodes = pointer_set_create (); diff --git a/gcc/output.h b/gcc/output.h index 69f8378a0bcd..6d518c45803e 100644 --- a/gcc/output.h +++ b/gcc/output.h @@ -200,6 +200,10 @@ extern void assemble_end_function (tree, const char *); initial value (that will be done by the caller). */ extern void assemble_variable (tree, int, int, int); +/* Compute the alignment of variable specified by DECL. + DONT_OUTPUT_DATA is from assemble_variable. */ +extern void align_variable (tree decl, bool dont_output_data); + /* Output something to declare an external symbol to the assembler. (Most assemblers don't need this, so we normally output nothing.) Do nothing if DECL is not external. */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 15484111c2d1..b133204f32cd 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2006-07-13 Jan Hubicka <jh@suse.cz> + + * gcc.target/i386/memcpy-1.c: New. + 2006-07-12 Geoffrey Keating <geoffk@apple.com> * g++.dg/ext/visibility/fvisibility-inlines-hidden-2.C: New. diff --git a/gcc/testsuite/gcc.target/i386/memcpy-1.c b/gcc/testsuite/gcc.target/i386/memcpy-1.c new file mode 100644 index 000000000000..edd0c7b49aaa --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/memcpy-1.c @@ -0,0 +1,16 @@ +/* { dg-do compile { target i?86-*-* } } */ +/* { dg-options "-O2 -march=pentiumpro -minline-all-stringops" } */ +/* { dg-final { scan-assembler "rep" } } */ +/* { dg-final { scan-assembler "movs" } } */ +/* { dg-final { scan-assembler-not "test" } } */ +/* { dg-final { scan-assembler "\.L?:" } } */ + +/* A and B are aligned, but we used to lose track of it. + Ensure that memcpy is inlined and alignment prologue is missing. */ + +char a[900]; +char b[900]; +t() +{ + __builtin_memcpy (a,b,900); +} diff --git a/gcc/value-prof.c b/gcc/value-prof.c index 59b0f351530b..e273a40f9c90 100644 --- a/gcc/value-prof.c +++ b/gcc/value-prof.c @@ -147,7 +147,11 @@ tree_value_profile_transformations (void) { changed = true; /* Original statement may no longer be in the same block. */ - bb = bb_for_stmt (stmt); + if (bb != bb_for_stmt (stmt)) + { + bb = bb_for_stmt (stmt); + bsi = bsi_for_stmt (stmt); + } } /* Free extra storage from compute_value_histograms. */ diff --git a/gcc/varasm.c b/gcc/varasm.c index a10d954d0c6e..9dcc3b442cf4 100644 --- a/gcc/varasm.c +++ b/gcc/varasm.c @@ -834,7 +834,7 @@ bss_initializer_p (tree decl) /* Compute the alignment of variable specified by DECL. DONT_OUTPUT_DATA is from assemble_variable. */ -static void +void align_variable (tree decl, bool dont_output_data) { unsigned int align = DECL_ALIGN (decl); -- GitLab