diff options
author | Fangrui Song <maskray@google.com> | 2021-04-16 11:26:39 -0700 |
---|---|---|
committer | Fangrui Song <maskray@google.com> | 2021-04-16 11:26:39 -0700 |
commit | cd6ae7ea5431c2b8f16201fb0e2c413bf8d2df06 (patch) | |
tree | 68d5b5402097696b3e3898fad40a143720da0438 /libio/tst-cleanup-start-stop-gc.c | |
parent | 1a8605b6cd257e8a74e29b5b71c057211f5fb847 (diff) | |
download | glibc-cd6ae7ea5431c2b8f16201fb0e2c413bf8d2df06.tar.gz glibc-cd6ae7ea5431c2b8f16201fb0e2c413bf8d2df06.tar.xz glibc-cd6ae7ea5431c2b8f16201fb0e2c413bf8d2df06.zip |
Set the retain attribute on _elf_set_element if CC supports [BZ #27492]
So that text_set_element/data_set_element/bss_set_element defined variables will be retained by the linker. Note: 'used' and 'retain' are orthogonal: 'used' makes sure the variable will not be optimized out; 'retain' prevents section garbage collection if the linker support SHF_GNU_RETAIN. GNU ld 2.37 and LLD 13 will support -z start-stop-gc which allow C identifier name sections to be GCed even if there are live __start_/__stop_ references. Without the change, there are some static linking problems, e.g. _IO_cleanup (libio/genops.c) may be discarded by ld --gc-sections, so stdout is not flushed on exit. Note: GCC may warning 'retain' attribute ignored while __has_attribute(retain) is 1 (https://gcc.gnu.org/bugzilla/show_bug.cgi?id=99587). Reviewed-by: H.J. Lu <hjl.tools@gmail.com>
Diffstat (limited to 'libio/tst-cleanup-start-stop-gc.c')
-rw-r--r-- | libio/tst-cleanup-start-stop-gc.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/libio/tst-cleanup-start-stop-gc.c b/libio/tst-cleanup-start-stop-gc.c new file mode 100644 index 0000000000..c39956e2a8 --- /dev/null +++ b/libio/tst-cleanup-start-stop-gc.c @@ -0,0 +1 @@ +#include "tst-cleanup.c" |