# HG changeset patch # User Liam Donovan # Date 1462623795 -3600 # Node ID 88cf310417cd787cc348231d78bad1c298e5f128 # Parent 1606b50a58c68c732b2282941766ca1712415e84 Add a parameter 'autoSchedule' to createAuxiliaryTask() which when true causes the task to be automatically scheduled after every render function call, without the user needing to call scheduleAuxiliaryTask() diff -r 1606b50a58c6 -r 88cf310417cd core/PRU.cpp --- a/core/PRU.cpp Sat May 07 12:51:10 2016 +0100 +++ b/core/PRU.cpp Sat May 07 13:23:15 2016 +0100 @@ -643,6 +643,8 @@ // Set the test pin high xenomai_gpio[GPIO_CLEARDATAOUT] = TEST_PIN_MASK; } + + BeagleRT_autoScheduleAuxiliaryTasks(); // FIXME: TESTING!! // if(testCount > 100000) diff -r 1606b50a58c6 -r 88cf310417cd core/RTAudio.cpp --- a/core/RTAudio.cpp Sat May 07 12:51:10 2016 +0100 +++ b/core/RTAudio.cpp Sat May 07 13:23:15 2016 +0100 @@ -48,6 +48,7 @@ bool started; bool hasArgs; void* args; + bool autoSchedule; } InternalAuxiliaryTask; const char gRTAudioThreadName[] = "beaglert-audio"; @@ -294,7 +295,7 @@ // (equal or lower) priority. Audio priority is defined in BEAGLERT_AUDIO_PRIORITY; // priority should be generally be less than this. // Returns an (opaque) pointer to the created task on success; 0 on failure -AuxiliaryTask BeagleRT_createAuxiliaryTask(void (*functionToCall)(void* args), int priority, const char *name, void* args) +AuxiliaryTask BeagleRT_createAuxiliaryTask(void (*functionToCall)(void* args), int priority, const char *name, void* args, bool autoSchedule) { InternalAuxiliaryTask *newTask = (InternalAuxiliaryTask*)malloc(sizeof(InternalAuxiliaryTask)); @@ -312,27 +313,33 @@ newTask->started = false; newTask->args = args; newTask->hasArgs = true; - + newTask->autoSchedule = autoSchedule; + getAuxTasks().push_back(newTask); return (AuxiliaryTask)newTask; } -AuxiliaryTask BeagleRT_createAuxiliaryTask(void (*functionToCall)(void), int priority, const char *name) +AuxiliaryTask BeagleRT_createAuxiliaryTask(void (*functionToCall)(void), int priority, const char *name, bool autoSchedule) { InternalAuxiliaryTask *newTask = (InternalAuxiliaryTask*)malloc(sizeof(InternalAuxiliaryTask)); + // Attempt to create the task if(rt_task_create(&(newTask->task), name, 0, priority, T_JOINABLE | T_FPU)) { cout << "Error: unable to create auxiliary task " << name << endl; free(newTask); return 0; } + // Populate the rest of the data structure and store it in the vector newTask->function = functionToCall; newTask->name = strdup(name); newTask->priority = priority; newTask->started = false; newTask->hasArgs = false; + newTask->autoSchedule = autoSchedule; + getAuxTasks().push_back(newTask); + return (AuxiliaryTask)newTask; } @@ -347,6 +354,14 @@ } rt_task_resume(&taskToSchedule->task); } +void BeagleRT_autoScheduleAuxiliaryTasks(){ + vector::iterator it; + for(it = getAuxTasks().begin(); it != getAuxTasks().end(); it++) { + if ((InternalAuxiliaryTask *)(*it)->autoSchedule){ + BeagleRT_scheduleAuxiliaryTask(*it); + } + } +} // Calculation loop that can be used for other tasks running at a lower // priority than the audio thread. Simple wrapper for Xenomai calls. @@ -359,7 +374,7 @@ void (*auxiliary_argfunction)(void* args) = task->argfunction; void (*auxiliary_function)(void) = task->function; - // get the name + // get the task's name const char *name = task->name; // Wait for a notification diff -r 1606b50a58c6 -r 88cf310417cd include/BeagleRT.h --- a/include/BeagleRT.h Sat May 07 12:51:10 2016 +0100 +++ b/include/BeagleRT.h Sat May 07 13:23:15 2016 +0100 @@ -579,8 +579,8 @@ * \param priority Xenomai priority level at which the task should run. * \param name Name for this task, which should be unique system-wide (no other running program should use this name). */ -AuxiliaryTask BeagleRT_createAuxiliaryTask(void (*functionToCall)(void*), int priority, const char *name, void* args); -AuxiliaryTask BeagleRT_createAuxiliaryTask(void (*functionToCall)(void), int priority, const char *name); +AuxiliaryTask BeagleRT_createAuxiliaryTask(void (*functionToCall)(void*), int priority, const char *name, void* args, bool autoSchedule = false); +AuxiliaryTask BeagleRT_createAuxiliaryTask(void (*functionToCall)(void), int priority, const char *name, bool autoSchedule = false); /** * \brief Start an auxiliary task so that it can be run. @@ -609,6 +609,7 @@ * \param task Task to schedule for running. */ void BeagleRT_scheduleAuxiliaryTask(AuxiliaryTask task); +void BeagleRT_autoScheduleAuxiliaryTasks(); /** @} */ #include