break;
case MSG_DEL_TASK:
debug("Receiving a delete task request");
- task_delete();
+ c = read16();
+ task_delete(c);
+ //Write acknowledgement
+ write_byte('d');
+ write16(c);
+ write_byte('\n');
break;
case MSG_GET_TASK:
debug("Receiving a task");
default:
debug("Unknown message: %X", c);
}
+ } else {
+// debug("No input");
}
}
if(getmillis()-loopmillis < LOOPDELAY){
return;
}
+ loopmillis = getmillis();
#endif
-
- int ct;
- long cyclestart;
- struct task *curtask;
+ debug("Loop");
read_message();
//Run tasks
- cyclestart = getmillis();
- for(ct = 0; ct<MAXTASKS; ct++){
- //See whether the task is even in use
- if((curtask = task_get(ct)) == NULL){
-// debug("Task %d not implemented\n", ct);
- continue;
- }
+ unsigned long cyclestart = getmillis();
+ for(struct task *t = task_head(); t != NULL; t = task_next(t)){
//interrupt task
- if(is_interrupt_task(curtask) && had_interrupt(curtask)){
- debug("Interrupt task %d not implemented", ct);
- run_task(curtask);
+ if(is_interrupt_task(t) && had_interrupt(t)){
+ debug("Interrupt task %d not implemented", t->taskid);
+ run_task(t);
//Interval task, and interval passed
- } else if(cyclestart-curtask->lastrun > curtask->interval){
- debug("Running interval task: %d", ct);
- run_task(curtask);
+ } else if(cyclestart-t->lastrun > t->interval){
+ debug("Running interval task: %d", t->taskid);
+ run_task(t);
//Oneshot task, thus disable
- if(curtask->interval == 0){
- curtask->used = false;
+ if(t->interval == 0){
+ task_delete(t->taskid);
}
- curtask->lastrun = cyclestart;
+ t->lastrun = cyclestart;
}
}
}