Deleted Added
full compact
thr_getschedparam.c (158073) thr_getschedparam.c (160287)
1/*
2 * Copyright (c) 1998 Daniel Eischen <eischen@vigrid.com>.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 15 unchanged lines hidden (view full) ---

24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
31 *
1/*
2 * Copyright (c) 1998 Daniel Eischen <eischen@vigrid.com>.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 15 unchanged lines hidden (view full) ---

24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
31 *
32 * $FreeBSD: head/lib/libthr/thread/thr_getschedparam.c 158073 2006-04-27 08:18:23Z davidxu $
32 * $FreeBSD: head/lib/libthr/thread/thr_getschedparam.c 160287 2006-07-12 06:13:18Z davidxu $
33 */
34
35#include "namespace.h"
36#include <errno.h>
37#include <pthread.h>
38#include "un-namespace.h"
39
40#include "thr_private.h"
41
42__weak_reference(_pthread_getschedparam, pthread_getschedparam);
43
44int
45_pthread_getschedparam(pthread_t pthread, int *policy,
46 struct sched_param *param)
47{
48 struct pthread *curthread = _get_curthread();
33 */
34
35#include "namespace.h"
36#include <errno.h>
37#include <pthread.h>
38#include "un-namespace.h"
39
40#include "thr_private.h"
41
42__weak_reference(_pthread_getschedparam, pthread_getschedparam);
43
44int
45_pthread_getschedparam(pthread_t pthread, int *policy,
46 struct sched_param *param)
47{
48 struct pthread *curthread = _get_curthread();
49 int ret, tmp;
49 int ret;
50
50
51 if ((param == NULL) || (policy == NULL))
52 /* Return an invalid argument error: */
53 ret = EINVAL;
54 else if (pthread == curthread) {
51 if (policy == NULL || param == NULL)
52 return (EINVAL);
53
54 if (pthread == curthread) {
55 /*
56 * Avoid searching the thread list when it is the current
57 * thread.
58 */
55 /*
56 * Avoid searching the thread list when it is the current
57 * thread.
58 */
59 THR_THREAD_LOCK(curthread, curthread);
60 param->sched_priority = pthread->base_priority;
61 tmp = pthread->attr.sched_policy;
62 THR_THREAD_UNLOCK(curthread, curthread);
63 *policy = tmp;
64 ret = 0;
59 THR_LOCK(curthread);
60
61 /*
62 * XXX Here we need two separated syscalls, atomic is only
63 * guaranteed in thread library, a new syscall is needed.
64 */
65
66 *policy = sched_getscheduler((pid_t)curthread->tid);
67 if (*policy == -1)
68 ret = errno;
69 else {
70 ret = sched_getparam((pid_t)curthread->tid, param);
71 if (ret == -1)
72 ret = errno;
73 }
74 THR_UNLOCK(curthread);
65 }
66 /* Find the thread in the list of active threads. */
67 else if ((ret = _thr_ref_add(curthread, pthread, /*include dead*/0))
68 == 0) {
69 THR_THREAD_LOCK(curthread, pthread);
75 }
76 /* Find the thread in the list of active threads. */
77 else if ((ret = _thr_ref_add(curthread, pthread, /*include dead*/0))
78 == 0) {
79 THR_THREAD_LOCK(curthread, pthread);
70 param->sched_priority = pthread->base_priority;
71 tmp = pthread->attr.sched_policy;
80 *policy = sched_getscheduler((pid_t)pthread->tid);
81 if (*policy == -1)
82 ret = errno;
83 else {
84 ret = sched_getparam((pid_t)pthread->tid, param);
85 if (ret == -1)
86 ret = errno;
87 }
72 THR_THREAD_UNLOCK(curthread, pthread);
73 _thr_ref_delete(curthread, pthread);
88 THR_THREAD_UNLOCK(curthread, pthread);
89 _thr_ref_delete(curthread, pthread);
74 *policy = tmp;
75 }
76 return (ret);
77}
90 }
91 return (ret);
92}