void mtapi_taskattr_set( MTAPI_INOUT mtapi_task_attributes_t* attributes, MTAPI_IN mtapi_uint_t attribute_num, MTAPI_IN void* attribute, MTAPI_IN mtapi_size_t attribute_size, MTAPI_OUT mtapi_status_t* status) { mtapi_status_t local_status = MTAPI_ERR_UNKNOWN; embb_mtapi_log_trace("mtapi_taskattr_set() called\n"); if (MTAPI_NULL != attributes) { if (MTAPI_ATTRIBUTE_POINTER_AS_VALUE != attribute_size && MTAPI_NULL == attribute) { local_status = MTAPI_ERR_PARAMETER; } else { switch (attribute_num) { case MTAPI_TASK_DETACHED: local_status = embb_mtapi_attr_set_mtapi_boolean_t( &attributes->is_detached, attribute, attribute_size); break; case MTAPI_TASK_INSTANCES: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->num_instances, attribute, attribute_size); break; case MTAPI_TASK_PRIORITY: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->priority, attribute, attribute_size); break; case MTAPI_TASK_AFFINITY: local_status = embb_mtapi_attr_set_mtapi_affinity_t( &attributes->affinity, attribute, attribute_size); break; case MTAPI_TASK_USER_DATA: attributes->user_data = (void*)attribute; local_status = MTAPI_SUCCESS; break; case MTAPI_TASK_COMPLETE_FUNCTION: memcpy(&attributes->complete_func, &attribute, sizeof(void*)); local_status = MTAPI_SUCCESS; break; default: /* attribute unknown */ local_status = MTAPI_ERR_ATTR_NUM; break; } } } else { local_status = MTAPI_ERR_PARAMETER; } mtapi_status_set(status, local_status); }
void mtapi_actionattr_set( MTAPI_INOUT mtapi_action_attributes_t* attributes, MTAPI_IN mtapi_uint_t attribute_num, MTAPI_IN void* attribute, MTAPI_IN mtapi_size_t attribute_size, MTAPI_OUT mtapi_status_t* status) { mtapi_status_t local_status = MTAPI_ERR_UNKNOWN; embb_mtapi_log_trace("mtapi_actionattr_set() called\n"); if (MTAPI_NULL != attributes) { if (MTAPI_ATTRIBUTE_POINTER_AS_VALUE != attribute_size && MTAPI_NULL == attribute) { local_status = MTAPI_ERR_PARAMETER; } else { switch (attribute_num) { case MTAPI_ACTION_GLOBAL: local_status = embb_mtapi_attr_set_mtapi_boolean_t( &attributes->global, attribute, attribute_size); break; case MTAPI_ACTION_AFFINITY: local_status = embb_mtapi_attr_set_mtapi_affinity_t( &attributes->affinity, attribute, attribute_size); break; case MTAPI_ACTION_DOMAIN_SHARED: local_status = embb_mtapi_attr_set_mtapi_boolean_t( &attributes->domain_shared, attribute, attribute_size); break; default: /* attribute unknown */ local_status = MTAPI_ERR_ATTR_NUM; break; } } } else { /* this should not happen, if someone calls set, a valid action_attributes pointer should be supplied */ local_status = MTAPI_ERR_PARAMETER; } mtapi_status_set(status, local_status); }
void mtapi_nodeattr_set( MTAPI_INOUT mtapi_node_attributes_t* attributes, MTAPI_IN mtapi_uint_t attribute_num, MTAPI_IN void* attribute, MTAPI_IN mtapi_size_t attribute_size, MTAPI_OUT mtapi_status_t* status) { mtapi_status_t local_status = MTAPI_ERR_UNKNOWN; embb_mtapi_log_trace("mtapi_nodeattr_set() called\n"); if (MTAPI_NULL != attributes) { if (MTAPI_ATTRIBUTE_POINTER_AS_VALUE != attribute_size && MTAPI_NULL == attribute) { local_status = MTAPI_ERR_PARAMETER; } else { switch (attribute_num) { case MTAPI_NODE_CORE_AFFINITY: if (MTAPI_NODE_CORE_AFFINITY_SIZE == attribute_size) { attributes->core_affinity = *(embb_core_set_t*)attribute; attributes->num_cores = embb_core_set_count(&attributes->core_affinity); local_status = MTAPI_SUCCESS; } else { local_status = MTAPI_ERR_ATTR_SIZE; } break; case MTAPI_NODE_NUMCORES: local_status = MTAPI_ERR_ATTR_READONLY; break; case MTAPI_NODE_TYPE: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->type, attribute, attribute_size); break; case MTAPI_NODE_MAX_TASKS: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->max_tasks, attribute, attribute_size); break; case MTAPI_NODE_MAX_ACTIONS: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->max_actions, attribute, attribute_size); break; case MTAPI_NODE_MAX_GROUPS: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->max_groups, attribute, attribute_size); break; case MTAPI_NODE_MAX_QUEUES: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->max_queues, attribute, attribute_size); break; case MTAPI_NODE_QUEUE_LIMIT: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->queue_limit, attribute, attribute_size); break; case MTAPI_NODE_MAX_JOBS: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->max_jobs, attribute, attribute_size); break; case MTAPI_NODE_MAX_ACTIONS_PER_JOB: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->max_actions_per_job, attribute, attribute_size); break; case MTAPI_NODE_MAX_PRIORITIES: local_status = embb_mtapi_attr_set_mtapi_uint_t( &attributes->max_priorities, attribute, attribute_size); break; case MTAPI_NODE_REUSE_MAIN_THREAD: local_status = embb_mtapi_attr_set_mtapi_boolean_t( &attributes->reuse_main_thread, attribute, attribute_size); break; case MTAPI_NODE_WORKER_PRIORITIES: local_status = MTAPI_SUCCESS; attributes->worker_priorities = (mtapi_worker_priority_entry_t*)attribute; break; default: /* attribute unknown */ local_status = MTAPI_ERR_ATTR_NUM; break; } } } else { /* this should not happen, if someone calls set, a valid action_attributes pointer should be supplied */ local_status = MTAPI_ERR_PARAMETER; } mtapi_status_set(status, local_status); }