summaryrefslogtreecommitdiff
path: root/libddekit/condvar.c
diff options
context:
space:
mode:
Diffstat (limited to 'libddekit/condvar.c')
-rw-r--r--libddekit/condvar.c52
1 files changed, 52 insertions, 0 deletions
diff --git a/libddekit/condvar.c b/libddekit/condvar.c
new file mode 100644
index 00000000..64df3ed6
--- /dev/null
+++ b/libddekit/condvar.c
@@ -0,0 +1,52 @@
+/**
+ * Unchecked (no BSD invariants) condition variable implementation for
+ * dde-internal use. Written from scratch.
+ *
+ * \author Thomas Friebel <tf13@os.inf.tu-dresden.de>
+ */
+#include <pthread.h>
+
+#include "ddekit/memory.h"
+#include "ddekit/condvar.h"
+
+struct ddekit_condvar {
+ pthread_cond_t cond;
+};
+
+ddekit_condvar_t *ddekit_condvar_init() {
+ ddekit_condvar_t *cvp;
+
+ cvp = ddekit_simple_malloc (sizeof (*cvp));
+
+ if (cvp == NULL)
+ return NULL;
+
+ pthread_cond_init (&cvp->cond, NULL);
+ return cvp;
+}
+
+void ddekit_condvar_deinit(ddekit_condvar_t *cvp) {
+ ddekit_simple_free (cvp);
+}
+
+void ddekit_condvar_wait(ddekit_condvar_t *cvp, ddekit_lock_t *mp) {
+ /* This isn't nice. The encapsulation is broken.
+ * TODO I can merge the two files condvar.c and lock.c. */
+ pthread_cond_wait (&cvp->cond, (pthread_mutex_t *) *mp);
+}
+
+int ddekit_condvar_wait_timed(ddekit_condvar_t *cvp,
+ ddekit_lock_t *mp, int timo) {
+ // TODO currently just let it like this.
+ ddekit_condvar_wait (cvp, mp);
+ return 0;
+}
+
+void ddekit_condvar_signal(ddekit_condvar_t *cvp)
+{
+ pthread_cond_signal (&cvp->cond);
+}
+
+void ddekit_condvar_broadcast(ddekit_condvar_t *cvp) {
+ pthread_cond_broadcast (&cvp->cond);
+}