mirror of
https://sourceware.org/git/glibc.git
synced 2025-12-03 12:11:17 +03:00
pthread: Remove alloca usage from __sem_check_add_mapping
sem_open already returns EINVAL for input names larger than NAME_MAX, so it can assume the largest name length with tfind. Checked on x86_64-linux-gnu.
This commit is contained in:
@@ -31,6 +31,15 @@ struct inuse_sem
|
|||||||
char name[];
|
char name[];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct search_sem
|
||||||
|
{
|
||||||
|
dev_t dev;
|
||||||
|
ino_t ino;
|
||||||
|
int refcnt;
|
||||||
|
sem_t *sem;
|
||||||
|
char name[NAME_MAX];
|
||||||
|
};
|
||||||
|
|
||||||
/* Comparison function for search of existing mapping. */
|
/* Comparison function for search of existing mapping. */
|
||||||
static int
|
static int
|
||||||
sem_search (const void *a, const void *b)
|
sem_search (const void *a, const void *b)
|
||||||
@@ -61,6 +70,9 @@ sem_t *
|
|||||||
__sem_check_add_mapping (const char *name, int fd, sem_t *existing)
|
__sem_check_add_mapping (const char *name, int fd, sem_t *existing)
|
||||||
{
|
{
|
||||||
size_t namelen = strlen (name);
|
size_t namelen = strlen (name);
|
||||||
|
if (namelen > NAME_MAX)
|
||||||
|
return SEM_FAILED;
|
||||||
|
|
||||||
sem_t *result = SEM_FAILED;
|
sem_t *result = SEM_FAILED;
|
||||||
|
|
||||||
/* Get the information about the file. */
|
/* Get the information about the file. */
|
||||||
@@ -71,13 +83,12 @@ __sem_check_add_mapping (const char *name, int fd, sem_t *existing)
|
|||||||
lll_lock (sem_mappings_lock, LLL_PRIVATE);
|
lll_lock (sem_mappings_lock, LLL_PRIVATE);
|
||||||
|
|
||||||
/* Search for an existing mapping given the information we have. */
|
/* Search for an existing mapping given the information we have. */
|
||||||
struct inuse_sem *fake;
|
struct search_sem fake;
|
||||||
fake = (struct inuse_sem *) alloca (sizeof (*fake) + namelen);
|
memcpy (fake.name, name, namelen);
|
||||||
memcpy (fake->name, name, namelen);
|
fake.dev = st.st_dev;
|
||||||
fake->dev = st.st_dev;
|
fake.ino = st.st_ino;
|
||||||
fake->ino = st.st_ino;
|
|
||||||
|
|
||||||
struct inuse_sem **foundp = __tfind (fake, &sem_mappings, sem_search);
|
struct inuse_sem **foundp = __tfind (&fake, &sem_mappings, sem_search);
|
||||||
if (foundp != NULL)
|
if (foundp != NULL)
|
||||||
{
|
{
|
||||||
/* There is already a mapping. Use it. */
|
/* There is already a mapping. Use it. */
|
||||||
|
|||||||
Reference in New Issue
Block a user