aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/htl
diff options
context:
space:
mode:
authorMartin Sebor <msebor@redhat.com>2021-04-27 13:01:55 -0600
committerMartin Sebor <msebor@redhat.com>2021-04-27 13:01:55 -0600
commita1561c3bbe8e72c6e44280d1eb5e529d2da4ecd0 (patch)
treee3313210ed99c03771560866bc346355ac308e0e /sysdeps/htl
parent876cdfd154f93a913202fa77ed98e97e66aff9c9 (diff)
downloadglibc-a1561c3bbe8e72c6e44280d1eb5e529d2da4ecd0.tar
glibc-a1561c3bbe8e72c6e44280d1eb5e529d2da4ecd0.tar.gz
glibc-a1561c3bbe8e72c6e44280d1eb5e529d2da4ecd0.tar.bz2
glibc-a1561c3bbe8e72c6e44280d1eb5e529d2da4ecd0.zip
Add __attribute_access_none to disable GCC warnings [BZ #27714]
GCC 11 warns when a pointer to an uninitialized object is passed to a function that takes a const-qualified argument. This is done on the assumption that most such functions read from the object. For the rare case of a function that doesn't, GCC 11 extends attribute access to add a new mode called none. POSIX pthread_setspecific() is one such rare function that takes a const void* argument but that doesn't read from the object it points to. To suppress the -Wmaybe-uninitialized issued by GCC 11 when the address of an uninitialized object is passed to it (e.g., the result of malloc()), this change #defines __attr_access_none in cdefs.h and uses the macro on the function in sysdeps/htl/pthread.h and sysdeps/nptl/pthread.h.
Diffstat (limited to 'sysdeps/htl')
-rw-r--r--sysdeps/htl/pthread.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/sysdeps/htl/pthread.h b/sysdeps/htl/pthread.h
index 0923ad0002..6bcf97d692 100644
--- a/sysdeps/htl/pthread.h
+++ b/sysdeps/htl/pthread.h
@@ -822,7 +822,7 @@ extern void *pthread_getspecific (pthread_key_t __key) __THROW;
/* Set the caller thread's thread specific value of KEY to VALUE. */
extern int pthread_setspecific (pthread_key_t __key, const void *__value)
- __THROW;
+ __THROW __attr_access_none (2);
/* Dynamic package initialization. */