|
|
00db10 |
commit 37f8abad1c7b274e66eaf2d04684bd8a7ba0bcef
|
|
|
00db10 |
Author: Adhemerval Zanella <adhemerval.zanella@linaro.org>
|
|
|
00db10 |
Date: Mon Jan 30 18:07:32 2017 -0200
|
|
|
00db10 |
|
|
|
00db10 |
nptl: Remove COLORING_INCREMENT
|
|
|
00db10 |
|
|
|
00db10 |
This patch removes the COLORING_INCREMENT define and usage on allocatestack.c.
|
|
|
00db10 |
It has not been used since 564cd8b67ec487f (glibc-2.3.3) by any architecture.
|
|
|
00db10 |
The idea is to simplify the code by removing obsolete code.
|
|
|
00db10 |
|
|
|
00db10 |
* nptl/allocatestack.c [COLORING_INCREMENT] (nptl_ncreated): Remove.
|
|
|
00db10 |
(allocate_stack): Remove COLORING_INCREMENT usage.
|
|
|
00db10 |
* nptl/stack-aliasing.h (COLORING_INCREMENT). Likewise.
|
|
|
00db10 |
* sysdeps/i386/i686/stack-aliasing.h (COLORING_INCREMENT): Likewise.
|
|
|
00db10 |
|
|
|
00db10 |
Conflicts:
|
|
|
00db10 |
nptl/allocatestack.c
|
|
|
00db10 |
|
|
|
00db10 |
Textual conflict due to missing backport of commit
|
|
|
00db10 |
a1ffb40e32741f992c743e7b16c061fefa3747ac (Use glibc_likely instead
|
|
|
00db10 |
__builtin_expect.).
|
|
|
00db10 |
|
|
|
00db10 |
diff --git a/nptl/allocatestack.c b/nptl/allocatestack.c
|
|
|
00db10 |
index 0fba6ce3474e8b35..00f9dcffe721a6b3 100644
|
|
|
00db10 |
--- a/nptl/allocatestack.c
|
|
|
00db10 |
+++ b/nptl/allocatestack.c
|
|
|
00db10 |
@@ -124,11 +124,6 @@ static uintptr_t in_flight_stack;
|
|
|
00db10 |
list_t __stack_user __attribute__ ((nocommon));
|
|
|
00db10 |
hidden_data_def (__stack_user)
|
|
|
00db10 |
|
|
|
00db10 |
-#if COLORING_INCREMENT != 0
|
|
|
00db10 |
-/* Number of threads created. */
|
|
|
00db10 |
-static unsigned int nptl_ncreated;
|
|
|
00db10 |
-#endif
|
|
|
00db10 |
-
|
|
|
00db10 |
|
|
|
00db10 |
/* Check whether the stack is still used or not. */
|
|
|
00db10 |
#define FREE_P(descr) ((descr)->tid <= 0)
|
|
|
00db10 |
@@ -456,14 +451,6 @@ allocate_stack (const struct pthread_attr *attr, struct pthread **pdp,
|
|
|
00db10 |
const int prot = (PROT_READ | PROT_WRITE
|
|
|
00db10 |
| ((GL(dl_stack_flags) & PF_X) ? PROT_EXEC : 0));
|
|
|
00db10 |
|
|
|
00db10 |
-#if COLORING_INCREMENT != 0
|
|
|
00db10 |
- /* Add one more page for stack coloring. Don't do it for stacks
|
|
|
00db10 |
- with 16 times pagesize or larger. This might just cause
|
|
|
00db10 |
- unnecessary misalignment. */
|
|
|
00db10 |
- if (size <= 16 * pagesize_m1)
|
|
|
00db10 |
- size += pagesize_m1 + 1;
|
|
|
00db10 |
-#endif
|
|
|
00db10 |
-
|
|
|
00db10 |
/* Adjust the stack size for alignment. */
|
|
|
00db10 |
size &= ~__static_tls_align_m1;
|
|
|
00db10 |
assert (size != 0);
|
|
|
00db10 |
@@ -506,34 +493,11 @@ allocate_stack (const struct pthread_attr *attr, struct pthread **pdp,
|
|
|
00db10 |
So we can never get a null pointer back from mmap. */
|
|
|
00db10 |
assert (mem != NULL);
|
|
|
00db10 |
|
|
|
00db10 |
-#if COLORING_INCREMENT != 0
|
|
|
00db10 |
- /* Atomically increment NCREATED. */
|
|
|
00db10 |
- unsigned int ncreated = atomic_increment_val (&nptl_ncreated);
|
|
|
00db10 |
-
|
|
|
00db10 |
- /* We chose the offset for coloring by incrementing it for
|
|
|
00db10 |
- every new thread by a fixed amount. The offset used
|
|
|
00db10 |
- module the page size. Even if coloring would be better
|
|
|
00db10 |
- relative to higher alignment values it makes no sense to
|
|
|
00db10 |
- do it since the mmap() interface does not allow us to
|
|
|
00db10 |
- specify any alignment for the returned memory block. */
|
|
|
00db10 |
- size_t coloring = (ncreated * COLORING_INCREMENT) & pagesize_m1;
|
|
|
00db10 |
-
|
|
|
00db10 |
- /* Make sure the coloring offsets does not disturb the alignment
|
|
|
00db10 |
- of the TCB and static TLS block. */
|
|
|
00db10 |
- if (__builtin_expect ((coloring & __static_tls_align_m1) != 0, 0))
|
|
|
00db10 |
- coloring = (((coloring + __static_tls_align_m1)
|
|
|
00db10 |
- & ~(__static_tls_align_m1))
|
|
|
00db10 |
- & ~pagesize_m1);
|
|
|
00db10 |
-#else
|
|
|
00db10 |
- /* Unless specified we do not make any adjustments. */
|
|
|
00db10 |
-# define coloring 0
|
|
|
00db10 |
-#endif
|
|
|
00db10 |
-
|
|
|
00db10 |
/* Place the thread descriptor at the end of the stack. */
|
|
|
00db10 |
#if TLS_TCB_AT_TP
|
|
|
00db10 |
- pd = (struct pthread *) ((char *) mem + size - coloring) - 1;
|
|
|
00db10 |
+ pd = (struct pthread *) ((char *) mem + size) - 1;
|
|
|
00db10 |
#elif TLS_DTV_AT_TP
|
|
|
00db10 |
- pd = (struct pthread *) ((((uintptr_t) mem + size - coloring
|
|
|
00db10 |
+ pd = (struct pthread *) ((((uintptr_t) mem + size
|
|
|
00db10 |
- __static_tls_size)
|
|
|
00db10 |
& ~__static_tls_align_m1)
|
|
|
00db10 |
- TLS_PRE_TCB_SIZE);
|
|
|
00db10 |
diff --git a/nptl/stack-aliasing.h b/nptl/stack-aliasing.h
|
|
|
00db10 |
index 526b54e18f7e0a27..62fdc9265e0038e6 100644
|
|
|
00db10 |
--- a/nptl/stack-aliasing.h
|
|
|
00db10 |
+++ b/nptl/stack-aliasing.h
|
|
|
00db10 |
@@ -16,12 +16,6 @@
|
|
|
00db10 |
License along with the GNU C Library; if not, see
|
|
|
00db10 |
<http://www.gnu.org/licenses/>. */
|
|
|
00db10 |
|
|
|
00db10 |
-/* This is a number of bytes (less than a page) by which to "color" the
|
|
|
00db10 |
- starting stack address of new threads. This number is multiplied by the
|
|
|
00db10 |
- number of threads created so far and then truncated modulo page size,
|
|
|
00db10 |
- to get a roughly even distribution of values for different threads. */
|
|
|
00db10 |
-#define COLORING_INCREMENT 0
|
|
|
00db10 |
-
|
|
|
00db10 |
/* This is a number of bytes that is an alignment that should be avoided
|
|
|
00db10 |
when choosing the exact size of a new thread's stack. If the size
|
|
|
00db10 |
chosen is aligned to this, an extra page will be added to render the
|
|
|
00db10 |
diff --git a/sysdeps/i386/i686/stack-aliasing.h b/sysdeps/i386/i686/stack-aliasing.h
|
|
|
00db10 |
index 1e35ceb2061d60f9..d73e45461f928a6a 100644
|
|
|
00db10 |
--- a/sysdeps/i386/i686/stack-aliasing.h
|
|
|
00db10 |
+++ b/sysdeps/i386/i686/stack-aliasing.h
|
|
|
00db10 |
@@ -16,11 +16,6 @@
|
|
|
00db10 |
License along with the GNU C Library; if not, see
|
|
|
00db10 |
<http://www.gnu.org/licenses/>. */
|
|
|
00db10 |
|
|
|
00db10 |
-/* It turns out that stack coloring is in general not good on P4s. Some
|
|
|
00db10 |
- applications will benefit. We will probably have a configuration option
|
|
|
00db10 |
- at some point. To enable coloring, set this to 128. */
|
|
|
00db10 |
-#define COLORING_INCREMENT 0
|
|
|
00db10 |
-
|
|
|
00db10 |
/* What is useful is to avoid the 64k aliasing problem which reliably
|
|
|
00db10 |
happens if all stacks use sizes which are a multiple of 64k. Tell
|
|
|
00db10 |
the stack allocator to disturb this by allocation one more page if
|