mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-03 08:11:08 +00:00
NPTL: Don't (re)validate sched_priority in pthread_create.
This commit is contained in:
parent
cbd463e2cf
commit
d960211ff5
@ -1,5 +1,9 @@
|
|||||||
2014-11-19 Roland McGrath <roland@hack.frob.com>
|
2014-11-19 Roland McGrath <roland@hack.frob.com>
|
||||||
|
|
||||||
|
* nptl/pthread_create.c (__pthread_create_2_1): Don't try to validate
|
||||||
|
the sched_priority value here. It was already checked when the user
|
||||||
|
called pthread_attr_setschedparam.
|
||||||
|
|
||||||
* nptl/tst-bad-schedattr.c: New file.
|
* nptl/tst-bad-schedattr.c: New file.
|
||||||
* nptl/Makefile (tests): Add it.
|
* nptl/Makefile (tests): Add it.
|
||||||
|
|
||||||
|
@ -605,6 +605,7 @@ __pthread_create_2_1 (newthread, attr, start_routine, arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (iattr->flags & ATTR_FLAG_SCHED_SET)
|
if (iattr->flags & ATTR_FLAG_SCHED_SET)
|
||||||
|
/* The values were validated in pthread_attr_setschedparam. */
|
||||||
memcpy (&pd->schedparam, &iattr->schedparam,
|
memcpy (&pd->schedparam, &iattr->schedparam,
|
||||||
sizeof (struct sched_param));
|
sizeof (struct sched_param));
|
||||||
else if ((pd->flags & ATTR_FLAG_SCHED_SET) == 0)
|
else if ((pd->flags & ATTR_FLAG_SCHED_SET) == 0)
|
||||||
@ -612,26 +613,6 @@ __pthread_create_2_1 (newthread, attr, start_routine, arg)
|
|||||||
INTERNAL_SYSCALL (sched_getparam, scerr, 2, 0, &pd->schedparam);
|
INTERNAL_SYSCALL (sched_getparam, scerr, 2, 0, &pd->schedparam);
|
||||||
pd->flags |= ATTR_FLAG_SCHED_SET;
|
pd->flags |= ATTR_FLAG_SCHED_SET;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check for valid priorities. */
|
|
||||||
int minprio = INTERNAL_SYSCALL (sched_get_priority_min, scerr, 1,
|
|
||||||
iattr->schedpolicy);
|
|
||||||
int maxprio = INTERNAL_SYSCALL (sched_get_priority_max, scerr, 1,
|
|
||||||
iattr->schedpolicy);
|
|
||||||
if (pd->schedparam.sched_priority < minprio
|
|
||||||
|| pd->schedparam.sched_priority > maxprio)
|
|
||||||
{
|
|
||||||
/* Perhaps a thread wants to change the IDs and if waiting
|
|
||||||
for this stillborn thread. */
|
|
||||||
if (__builtin_expect (atomic_exchange_acq (&pd->setxid_futex, 0)
|
|
||||||
== -2, 0))
|
|
||||||
lll_futex_wake (&pd->setxid_futex, 1, LLL_PRIVATE);
|
|
||||||
|
|
||||||
__deallocate_stack (pd);
|
|
||||||
|
|
||||||
retval = EINVAL;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Pass the descriptor to the caller. */
|
/* Pass the descriptor to the caller. */
|
||||||
|
Loading…
Reference in New Issue
Block a user