pthread_getschedparam.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /* Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Lesser General Public
  6. License as published by the Free Software Foundation; either
  7. version 2.1 of the License, or (at your option) any later version.
  8. The GNU C Library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public
  13. License along with the GNU C Library; if not, write to the Free
  14. Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  15. 02111-1307 USA. */
  16. #include <errno.h>
  17. #include <string.h>
  18. #include "pthreadP.h"
  19. #include <lowlevellock.h>
  20. int
  21. __pthread_getschedparam (threadid, policy, param)
  22. pthread_t threadid;
  23. int *policy;
  24. struct sched_param *param;
  25. {
  26. struct pthread *pd = (struct pthread *) threadid;
  27. /* Make sure the descriptor is valid. */
  28. if (INVALID_TD_P (pd))
  29. /* Not a valid thread handle. */
  30. return ESRCH;
  31. int result = 0;
  32. /* We have to handle cancellation in the following code since we are
  33. locking another threads descriptor. */
  34. pthread_cleanup_push ((void (*) (void *)) lll_unlock_wake_cb, &pd->lock);
  35. lll_lock (pd->lock);
  36. /* The library is responsible for maintaining the values at all
  37. times. If the user uses a interface other than
  38. pthread_setschedparam to modify the scheduler setting it is not
  39. the library's problem. In case the descriptor's values have
  40. not yet been retrieved do it now. */
  41. if ((pd->flags & ATTR_FLAG_SCHED_SET) == 0)
  42. {
  43. if (sched_getparam (pd->tid, &pd->schedparam) != 0)
  44. result = 1;
  45. else
  46. pd->flags |= ATTR_FLAG_SCHED_SET;
  47. }
  48. if ((pd->flags & ATTR_FLAG_POLICY_SET) == 0)
  49. {
  50. pd->schedpolicy = sched_getscheduler (pd->tid);
  51. if (pd->schedpolicy == -1)
  52. result = 1;
  53. else
  54. pd->flags |= ATTR_FLAG_POLICY_SET;
  55. }
  56. if (result == 0)
  57. {
  58. *policy = pd->schedpolicy;
  59. memcpy (param, &pd->schedparam, sizeof (struct sched_param));
  60. }
  61. lll_unlock (pd->lock);
  62. pthread_cleanup_pop (0);
  63. return result;
  64. }
  65. strong_alias (__pthread_getschedparam, pthread_getschedparam)