https://gcc.gnu.org/bugzilla/show_bug.cgi?id=68986
--- Comment #16 from hjl at gcc dot gnu.org <hjl at gcc dot gnu.org> --- Author: hjl Date: Tue Jan 26 12:51:07 2016 New Revision: 232825 URL: https://gcc.gnu.org/viewcvs?rev=232825&root=gcc&view=rev Log: Update stack alignment in ix86_update_stack_boundary Stack alignment adjustment for __tls_get_addr should be done in ix86_update_stack_boundary, not ix86_compute_frame_layout. Also there is no need to over-align stack for __tls_get_addr and function with __tls_get_addr call isn't a leaf function. gcc/ PR target/68986 * config/i386/i386.c (ix86_compute_frame_layout): Move stack alignment adjustment to ... (ix86_update_stack_boundary): Here. Don't over-align stack for __tls_get_addr. (ix86_finalize_stack_realign_flags): Use stack_alignment_needed if __tls_get_addr is called. gcc/testsuite/ PR target/68986 * gcc.target/i386/pr68986-1.c: New test. * gcc.target/i386/pr68986-2.c: Likewise. * gcc.target/i386/pr68986-3.c: Likewise. Added: trunk/gcc/testsuite/gcc.target/i386/pr68986-1.c trunk/gcc/testsuite/gcc.target/i386/pr68986-2.c trunk/gcc/testsuite/gcc.target/i386/pr68986-3.c Modified: trunk/gcc/ChangeLog trunk/gcc/config/i386/i386.c trunk/gcc/testsuite/ChangeLog