svn commit: r252503 - head/contrib/llvm/lib/Target/ARM

Andrew Turner andrew at FreeBSD.org
Tue Jul 2 08:04:42 UTC 2013


Author: andrew
Date: Tue Jul  2 08:04:41 2013
New Revision: 252503
URL: http://svnweb.freebsd.org/changeset/base/252503

Log:
  Work around an ARM EABI issue where clang would sometimes incorrectly align
  the stack in a leaf function that uses TLS.
  
  The issue is, when using TLS, the function is no longer a leaf as it calls
  __aeabi_read_tp. With statically linked programs this is not an issue as
  it doesn't make use of the stack, however with dynamically linked
  applications we enter rtld which does use the stack and makes assumptions
  about it's alignment.
  
  This is only a temporary fix until a better patch can be made and submitted
  upstream.

Modified:
  head/contrib/llvm/lib/Target/ARM/ARMFrameLowering.h

Modified: head/contrib/llvm/lib/Target/ARM/ARMFrameLowering.h
==============================================================================
--- head/contrib/llvm/lib/Target/ARM/ARMFrameLowering.h	Tue Jul  2 07:36:04 2013	(r252502)
+++ head/contrib/llvm/lib/Target/ARM/ARMFrameLowering.h	Tue Jul  2 08:04:41 2013	(r252503)
@@ -27,7 +27,7 @@ protected:
 
 public:
   explicit ARMFrameLowering(const ARMSubtarget &sti)
-    : TargetFrameLowering(StackGrowsDown, sti.getStackAlignment(), 0, 4),
+    : TargetFrameLowering(StackGrowsDown, sti.getStackAlignment(), 0, 8),
       STI(sti) {
   }
 


More information about the svn-src-head mailing list