diff options
author | jconner <jconner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-02-13 18:12:17 +0000 |
---|---|---|
committer | jconner <jconner@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-02-13 18:12:17 +0000 |
commit | 6d7204c30d64abffbf54530960ebec6d2b222355 (patch) | |
tree | 6029d89fb50bcba47971911b85b26ad5671431a7 | |
parent | 733bd71a11fc45d69bf9639979336fb5364a3c7e (diff) | |
download | gcc-6d7204c30d64abffbf54530960ebec6d2b222355.tar.gz |
PR target/25376
* varasm.c (function_section): Check for section name before
calling select_section on targets that define
USE_SELECT_SECTION_FOR_FUNCTIONS. On other targets, use
unlikely_text_section instead of hot_function_section if
first_function_block_is_cold.
* gcc.dg/pr25376.c: New test.
* gcc.c-torture/compile/pr23237.c: Only compile test -- don't
assemble.
* lib/target-supports.exp (check_named_sections_available):
Only compile named-sections test -- don't assemble.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@110917 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 9 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 10 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/compile/pr23237.c | 4 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/pr25376.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/lib/target-supports.exp | 2 | ||||
-rw-r--r-- | gcc/varasm.c | 21 |
6 files changed, 49 insertions, 6 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 30cea158738..2c8fe9527c9 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,12 @@ +2006-02-13 Josh Conner <jconner@apple.com> + + PR target/25376 + * varasm.c (function_section): Check for section name before + calling select_section on targets that define + USE_SELECT_SECTION_FOR_FUNCTIONS. On other targets, use + unlikely_text_section instead of hot_function_section if + first_function_block_is_cold. + 2006-02-13 J"orn Rennecke <joern.rennecke@st.com> PR middle-end/25335 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 686a2234ede..3338042a72c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,13 @@ +2006-02-13 Josh Conner <jconner@apple.com> + + PR target/25376 + * gcc.dg/pr25376.c: New test. + + * gcc.c-torture/compile/pr23237.c: Only compile test -- don't + assemble. + * lib/target-supports.exp (check_named_sections_available): + Only compile named-sections test -- don't assemble. + 2006-02-12 Gabriel Dos Reis <gdr@integrable-solutions.net> * g++.dg/warn/no-write-strings.C: New test. diff --git a/gcc/testsuite/gcc.c-torture/compile/pr23237.c b/gcc/testsuite/gcc.c-torture/compile/pr23237.c index bbb3483a557..955cdd060ff 100644 --- a/gcc/testsuite/gcc.c-torture/compile/pr23237.c +++ b/gcc/testsuite/gcc.c-torture/compile/pr23237.c @@ -1,5 +1,9 @@ /* { dg-require-effective-target named_sections } */ +/* Don't assemble, as this section syntax may not be valid on all platforms + (e.g., Darwin). */ +/* { dg-do compile } */ + static __attribute__ ((__section__ (".init.data"))) char *message; static __attribute__ ((__section__ (".init.data"))) int (*actions[])(void) = {}; void unpack_to_rootfs(void) diff --git a/gcc/testsuite/gcc.dg/pr25376.c b/gcc/testsuite/gcc.dg/pr25376.c new file mode 100644 index 00000000000..3008b091dc2 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr25376.c @@ -0,0 +1,9 @@ +/* PR25376. Verify that a named section is honored. */ +/* { dg-require-named-sections "" } */ + +void simple (void) __attribute__((section("my_named_section"))); +void simple (void) +{ +} + +/* { dg-final { scan-assembler "my_named_section" } } */ diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp index f9ca1a1652d..88794a3cb98 100644 --- a/gcc/testsuite/lib/target-supports.exp +++ b/gcc/testsuite/lib/target-supports.exp @@ -637,7 +637,7 @@ proc check_iconv_available { test_what } { # the same test run. proc check_named_sections_available { } { verbose "check_named_sections_available: compiling source" 2 - set answer [string match "" [get_compiler_messages named object { + set answer [string match "" [get_compiler_messages named assembly { int __attribute__ ((section("whatever"))) foo; }]] verbose "check_named_sections_available: returning $answer" 2 diff --git a/gcc/varasm.c b/gcc/varasm.c index 68bd026a279..bddf1ad9853 100644 --- a/gcc/varasm.c +++ b/gcc/varasm.c @@ -440,9 +440,14 @@ function_section (tree decl) reloc = 1; #ifdef USE_SELECT_SECTION_FOR_FUNCTIONS - return targetm.asm_out.select_section (decl, reloc, DECL_ALIGN (decl)); + if (decl != NULL_TREE + && DECL_SECTION_NAME (decl) != NULL_TREE) + return reloc ? unlikely_text_section () + : get_named_section (decl, NULL, 0); + else + return targetm.asm_out.select_section (decl, reloc, DECL_ALIGN (decl)); #else - return hot_function_section (decl); + return reloc ? unlikely_text_section () : hot_function_section (decl); #endif } @@ -450,9 +455,15 @@ section * current_function_section (void) { #ifdef USE_SELECT_SECTION_FOR_FUNCTIONS - return targetm.asm_out.select_section (current_function_decl, - in_cold_section_p, - DECL_ALIGN (current_function_decl)); + if (current_function_decl != NULL_TREE + && DECL_SECTION_NAME (current_function_decl) != NULL_TREE) + return in_cold_section_p ? unlikely_text_section () + : get_named_section (current_function_decl, + NULL, 0); + else + return targetm.asm_out.select_section (current_function_decl, + in_cold_section_p, + DECL_ALIGN (current_function_decl)); #else return (in_cold_section_p ? unlikely_text_section () |