/* threads.c - Manage threads Copyright (C) Lumiera.org 2008, Christian Thaeter This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ //TODO: Support library includes// #include "include/logging.h" //TODO: Lumiera header includes// #include "threads.h" //TODO: internal/static forward declarations// //TODO: System includes// #include /** * @file * */ //NOBUG_DEFINE_FLAG_PARENT (threads, lumiera); /*TODO insert a suitable/better parent flag here */ //code goes here// struct lumiera_thread_mockup { void (*fn)(void*); void* arg; LumieraReccondition finished; }; #if 0 static void* pthread_runner (void* thread) { pthread_setcancelstate (PTHREAD_CANCEL_DISABLE, NULL); struct lumiera_thread_mockup* starter = (struct lumiera_thread_mockup*) thread; LumieraReccondition thread_end_notification = starter->finished; starter->fn (starter->arg); if (!thread_end_notification) return NULL; // no signalling of thread termination desired LUMIERA_RECCONDITION_SECTION(cond_sync, thread_end_notification) LUMIERA_RECCONDITION_BROADCAST; return NULL; } static pthread_once_t attr_once = PTHREAD_ONCE_INIT; static pthread_attr_t attrs; static void thread_attr_init (void) { pthread_attr_init (&attrs); pthread_attr_setdetachstate (&attrs, PTHREAD_CREATE_DETACHED); //cancel ... } #endif #if 0 LumieraThread lumiera_thread_run (enum lumiera_thread_class kind, void (*start_routine)(void *), void * arg, LumieraReccondition finished, const char* purpose, struct nobug_flag* flag) { (void) kind; (void) purpose; (void) flag; if (attr_once == PTHREAD_ONCE_INIT) pthread_once (&attr_once, thread_attr_init); static struct lumiera_thread_mockup thread; thread.fn = start_routine; thread.arg = arg; thread.finished = finished; pthread_t dummy; int error = pthread_create (&dummy, &attrs, pthread_runner, &thread); if (error) return 0; /////TODO temporary addition by Ichthyo; probably we'll set lumiera_error? return (LumieraThread) 1; } #endif // TODO: new implementation, remove the above one // maybe this shouldn't return LumieraThread at all // when this is called it should have already been decided that the function // shall run in parallel, as a thread LumieraThread lumiera_thread_run (enum lumiera_thread_class kind, void (*function)(void *), void * arg, LumieraReccondition finished, const char* purpose, struct nobug_flag* flag) { (void)finished; (void)function; (void)arg; // ask the threadpool for a thread (it might create a new one) LumieraThread self = lumiera_threadpool_acquire_thread(kind, purpose, flag); // set the function and data to be run // lumiera_thread_set_func_data (self, start_routine, arg, purpose, flag); // and let it really run (signal the condition var, it waits there) LUMIERA_RECCONDITION_SECTION(cond_sync, self->finished) LUMIERA_RECCONDITION_SIGNAL; // NOTE: example only, add solid error handling! return self; } /* // Local Variables: // mode: C // c-file-style: "gnu" // indent-tabs-mode: nil // End: */