Skip to content

Commit

Permalink
Fix x86-64 TCB alignment for future processor versions.
Browse files Browse the repository at this point in the history
  • Loading branch information
Ulrich Drepper committed Jul 29, 2009
1 parent 649bf13 commit 586fa88
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 6 deletions.
3 changes: 1 addition & 2 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
2009-07-29 Ulrich Drepper <drepper@redhat.com>

* sysdeps/x86_64/dl-trampoline.S (_dl_runtime_profile): Improve CFI
information.
* sysdeps/x86_64/dl-trampoline.S (_dl_runtime_profile): Improve CFI.

2009-07-28 H.J. Lu <hongjiu.lu@intel.com>

Expand Down
10 changes: 7 additions & 3 deletions nptl/ChangeLog
Original file line number Diff line number Diff line change
@@ -1,9 +1,13 @@
2009-07-29 Ulrich Drepper <drepper@redhat.com>

* sysdeps/x86_64/tls.h (TLS_TCB_ALIGN): Define explicitly to 32.

* sysdeps/x86_64/tls.h (tcbhead_t): Add room for SSE registers the
dynamic linker might have to save. Define RTLD_CHECK_FOREIGN_CALL,
RTLD_ENABLE_FOREIGN_CALL, RTLD_PREPARE_FOREIGN_CALL, and
RTLD_FINALIZE_FOREIGN_CALL. Pretty printing.
dynamic linker might have to save.
Define RTLD_CHECK_FOREIGN_CALL, RTLD_ENABLE_FOREIGN_CALL,
RTLD_PREPARE_FOREIGN_CALL, and RTLD_FINALIZE_FOREIGN_CALL. Pretty
printing.

* sysdeps/x86_64/tcb-offsets.sym: Add RTLD_SAVESPACE_SSE.

2009-07-28 Ulrich Drepper <drepper@redhat.com>
Expand Down
7 changes: 6 additions & 1 deletion nptl/sysdeps/x86_64/tls.h
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,12 @@ typedef struct
# define TLS_TCB_SIZE sizeof (struct pthread)

/* Alignment requirements for the TCB. */
# define TLS_TCB_ALIGN __alignof__ (struct pthread)
//# define TLS_TCB_ALIGN __alignof__ (struct pthread)
// Normally the above would be correct But we have to store post-AVX
// vector registers in the TCB and we want the storage to be aligned.
// unfortunately there isn't yet a type for these values and hence no
// 32-byte alignment requirement. Make this explicit, for now.
# define TLS_TCB_ALIGN 32

/* The TCB can have any size and the memory following the address the
thread pointer points to is unspecified. Allocate the TCB there. */
Expand Down

0 comments on commit 586fa88

Please sign in to comment.