emulating context-switch

R

refigh

hi every body,
I have a embedded board with a processor without OS on it. there are
some independent tasks which should be run always. I put them into a
while(true) loop and call them one after another i.g.

while(true){
task(1);
task(2);
task(3);
}

by above code it seems they are run concurrently.

sometimes one of these task takes too much time and then causes
problem for other tasks. I want to emulate context switch in c++. the
method I consider to implement is:
I divide each task to some reasonable parts and after reach any of
these checkpoints, a task should return and a task_manager in body of
main function select another task to continue( for example by a
priority mechanism ).
but I think pausing a function is not easy? am I right? I think I must
define many variables as static and also save the inputs of function
for call a paused function again,
is there a simpler method in assembly? does anybody has a better
suggestion?
( I should mention that it is not possible to use interrupts for me
also. )
thanks.
 
B

Bo Lorentsen

I divide each task to some reasonable parts and after reach any of
these checkpoints, a task should return and a task_manager in body of
main function select another task to continue( for example by a
priority mechanism ).
but I think pausing a function is not easy?
No, you need to use something like async IO and longjmp to manage this,
and you need to manage an individual stack for each task, in order to
make all local values work.

And yes this is an cooperative model, and one task that does hand in a
long running loop will stop all other tasks while looping (thats why we
used "yield()" in win16 :)
am I right? I think I must
define many variables as static and also save the inputs of function
for call a paused function again,
is there a simpler method in assembly?
The local value problem are fixed by setting up a stack per thread, and
this goes for function arguments too, as these are all stack based i C
and C++.
does anybody has a better
suggestion?
( I should mention that it is not possible to use interrupts for me
also. )
This would be the best way to task switch, by giving time slices to each
task (using an interrupt for this), but .... depending on the platform
you are writing for/on, it may be more sensible to use your energy on
porting a custom Linux kernel to the platform, instead of reinventing
the wheel.

Else take a look at http://en.wikipedia.org/wiki/List_of_operating_systems

Lastly, I am not sure this it the prober news group for this kind of
question (nor answer) :)

/BL
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
473,995
Messages
2,570,236
Members
46,821
Latest member
AleidaSchi

Latest Threads

Top