Hi all,<br><br>I'd like to contribute to this as I think it is an interesting discussion. <br><br>I understood (if am not wrong) from Leon that is the urgent task the one suspending the rest of the tasks in order not to be interrupted when performing all his processing and I/O.<br>
<br>Does not using a priority ceiling semaphore to protect this I/O solve the problem? I know the ceiling of the semaphore should be the highest possible so the task is not preempted by another tasks with higher priority.<br>
<br>The only problem I see with the Leon's solution is that, from real-time point of view,  the schedulability analysis is kind of broken as a tasks with low priority can block higher priority tasks without sharing any resource with them. This is beyong priority inversion :D<br>
<br>Just a comment, I might be completely wrong.<br><br>wkr<br><br>aitor<br><br><br><div class="gmail_quote">On Wed, Apr 22, 2009 at 6:22 PM, Leon Pollak <span dir="ltr"><<a href="mailto:leonp@plris.com">leonp@plris.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;"><div style="font-family: 'Console'; font-size: 12pt; font-weight: 400; font-style: normal;">
<div class="im">On Wednesday April 22 2009, Thomas Dörfler wrote:<br></div><div class="im">
> I really doubt that I have a bigger experience than you have, and please<br>
>  don't take my critics against your proposal personally.<br></div>
I respect you enough not to do this...:-)<div class="im"><br>
<p style="margin: 0px; text-indent: 0px;"><br></p><p style="margin: 0px; text-indent: 0px;"><br></p>> I think RTEMS has several methods to control, when a task should execute<br>
> and when it shouldn't. Most of them are synchronous to each task's<br>
> probgram flow (e.g. semaphores, waiting for events etc).<br>
><br>
> Suspending a task from outside almost always means that you don't know<br>
> the state this task is in when you suspend it. And if even multiple<br>
> "control" tasks would suspend/resume arbitrary other tasks, you (no: I!)<br>
> would soon loose track when which task is suspended...<br>
><br>
> Consider your current problem: If I got you right, you want to make<br>
> sure, that no other task is executed even when your task is waiting<br>
> during I/O. Let's assume you use a serial termios channel for console<br>
> output. If you suspend another task, while it is somewhere deep in<br>
> termios, this task may even hold the output semaphore you are waiting on<br>
> to get control of the output channel.<br>
><br>
> In short: you can never be sure in which state you actually suspend a task.<br>
><br>
> This is why I consider it bad practice to control other tasks via<br>
> suspend/resume.<br></div>
Well, I should intend to agree with you in general.<br>
But still, these commands 9suspend/resume) exist in the API and people (like me) use them.<br>
<p style="margin: 0px; text-indent: 0px;"><br></p>OK, we (users of s/r) need to be careful to avoid the case you described, but still be able to do what we want.<br>
<p style="margin: 0px; text-indent: 0px;"><br></p>Just now, it is a serious problem for me:<br>
I have an urgent job to be done, which can not be interrupted by other I/O and processing tasks despite the state they reside in. I can not block interrupts and task switching at all, as the urgent task must do some processing requiring these facilities.<br>

<p style="margin: 0px; text-indent: 0px;"><br></p>When the urgent job finishes, I should like to return to the normal processing, which has been interrupted.<br>
<p style="margin: 0px; text-indent: 0px;"><br></p>Just now, I can not, as previously suspended tasks will be resumed by exiting from the urgent task.<br>
<p style="margin: 0px; text-indent: 0px;"><br></p>May be you see some other way to do this?<br>
<p style="margin: 0px; text-indent: 0px;"><br></p>Many thanks.<br><font color="#888888">
Leon</font></div><br>_______________________________________________<br>
rtems-users mailing list<br>
<a href="mailto:rtems-users@rtems.com">rtems-users@rtems.com</a><br>
<a href="http://rtems.rtems.org/mailman/listinfo/rtems-users" target="_blank">http://rtems.rtems.org/mailman/listinfo/rtems-users</a><br>
<br></blockquote></div><br>