]> git.vomp.tv Git - vompclient.git/blob - thread.cc
EPG tweaks, EPG made NTSC compatible
[vompclient.git] / thread.cc
1 /*
2     Copyright 2004-2005 Chris Tallon
3
4     This file is part of VOMP.
5
6     VOMP is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     VOMP is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with VOMP; if not, write to the Free Software
18     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19 */
20
21 #include "thread.h"
22
23 // Undeclared functions, only for use in this file to start the thread
24 void threadInternalStart(void *arg)
25 {
26   // I don't want signals
27   sigset_t sigs;
28   sigfillset(&sigs);
29   pthread_sigmask(SIG_BLOCK, &sigs, NULL);
30
31   Thread *t = (Thread *)arg;
32   t->threadInternalStart2();
33 }
34
35 void Thread::threadInternalStart2()
36 {
37   threadMethod();
38 }
39
40 int Thread::threadStart()
41 {
42   pthread_cond_init(&threadCond, NULL);
43   pthread_mutex_init(&threadCondMutex, NULL);
44
45   threadActive = 1;
46   if (pthread_create(&pthread, NULL, (void*(*)(void*))threadInternalStart, (void *)this) == -1) return 0;
47   return 1;
48 }
49
50 void Thread::threadStop()
51 {
52   threadActive = 0;
53   // Signal thread here in case it's waiting
54   threadSignal();
55   pthread_join(pthread, NULL);
56   this->threadPostStopCleanup();
57 }
58
59 void Thread::threadCancel()
60 {
61   threadActive = 0;
62   pthread_cancel(pthread);
63   pthread_join(pthread, NULL);
64   this->threadPostStopCleanup();
65 }
66
67 void Thread::threadCheckExit()
68 {
69   if (!threadActive) pthread_exit(NULL);
70 }
71
72 char Thread::threadIsActive()
73 {
74   return threadActive;
75 }
76
77 void Thread::threadLock()
78 {
79   pthread_mutex_lock(&threadCondMutex);
80 }
81
82 void Thread::threadUnlock()
83 {
84   pthread_mutex_unlock(&threadCondMutex);
85 }
86
87 void Thread::threadSignal()
88 {
89   pthread_mutex_lock(&threadCondMutex);
90   pthread_cond_signal(&threadCond);
91   pthread_mutex_unlock(&threadCondMutex);
92 }
93
94 void Thread::threadSignalNoLock()
95 {
96   pthread_cond_signal(&threadCond);
97 }
98
99 void Thread::threadWaitForSignal()
100 {
101   pthread_cond_wait(&threadCond, &threadCondMutex);
102 }
103
104 void Thread::threadWaitForSignalTimed(struct timespec* ts)
105 {
106   pthread_cond_timedwait(&threadCond, &threadCondMutex, ts);
107 }
108
109 void Thread::threadSetKillable()
110 {
111   pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL);
112   pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL);
113 }