Helixis 1.0
Task Programming API
sources/internal_includes/parallel/parallel_task_groups.h
Go to the documentation of this file.
00001 /*
00002 ** Copyright 2009-2011, helixis.org
00003 ** All rights reserved.
00004 **
00005 ** Redistribution and use in source and binary forms, with or without modification, are permitted provided
00006 ** that the following conditions are met:
00007 **
00008 ** Redistributions of source code must retain the above copyright notice, this list of conditions and the
00009 ** following disclaimer.
00010 **
00011 ** Redistributions in binary form must reproduce the above copyright notice, this list of conditions and
00012 ** the following disclaimer in the documentation and/or other materials provided with the distribution.
00013 **
00014 ** Neither the name of the helixis.org nor the names of its contributors may be used to endorse or promote
00015 ** products derived from this software without specific prior written permission.
00016 **
00017 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED
00018 ** WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
00019 ** PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
00020 ** ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
00021 ** TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00022 ** HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
00023 ** NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00024 ** POSSIBILITY OF SUCH DAMAGE.
00025 */
00026 
00027 #ifndef __HLX_PARALLEL_TASK_GROUPS_H__
00028 # define __HLX_PARALLEL_TASK_GROUPS_H__
00029 
00030 #if defined(HLX_BUILD_WITH_PARALLEL_THREADING)
00031 
00032 #ifdef __cplusplus
00033 extern "C"      {
00034 #endif
00035 
00036 /*
00037 ** TYPES
00038 */
00039 
00040 typedef struct
00041 {
00042         hlx_group_id          id;
00043         hlx_list              tasks;
00044         unsigned int          size;
00045         hlx_thread            thread;
00046         struct queue_state*   buf_tasks;
00047         atom_t                active_count;
00048 }            hlx_group;
00049 
00050 /*
00051 ** FUNCTIONS
00052 */
00053 
00054 void                  hlx_group_bufferize_task(hlx_group*, hlx_task*);
00055 void                  hlx_group_flush_task_buffer(hlx_group *);
00056 void                  hlx_group_construct(hlx_group*);
00057 void                  hlx_group_destruct(hlx_group*);
00058 void                  hlx_group_add_task(hlx_group*, hlx_task*);
00059 atom_t                hlx_group_get_size(hlx_group*);
00060 
00061 #ifdef __cplusplus
00062 }
00063 #endif
00064 
00065 #endif /* !HLX_BUILD_WITH_PARALLEL_THREADING */
00066 
00067 #endif /* !__HLX_PARALLEL_TASK_GROUPS_H__ */
00068 
00069 /*
00070 ** END OF FILE
00071 */
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Defines