On Wed, 18 Apr 2001, george anzinger wrote:
> "Richard B. Johnson" wrote:
> >
> > It seems that the nature of schedule() has changed in recent
> > kernels. I am trying to update my drivers to correspond to
> > the latest changes. Here is an example:
> >
> > This waits for some hardware (interrupt sets flag), time-out in one
> > second. This is in an ioctl(), i.e., user context:
> >
> > set_current_state(TASK_INTERRUPTIBLE);
> > current->policy = SCHED_YIELD;
> > timer = jiffies + HZ;
> > while(time_before(jiffies, timer))
> > {
> > if(flag) break;
> > schedule();
> > }
> > set_current_state(TASK_RUNNING);
> >
> > The problem is that schedule() never returns!!! If I use
> > schedule_timeout(1), it returns, but the granularity
> > of the timeout interval is such that it slows down the
> > driver (0.1 ms).
> >
> > So, is there something that I'm not doing that is preventing
> > schedule() from returning? It returns on a user-interrupt (^C),
> > but otherwise gives control to the kernel forever.
> >
> When schedule() is entered with TASK_INTERRUPTIBLE (actually with
> current state !=TASK_RUNNING) it takes the task out of the run_list. It
> has been this way for a long time. The normal way for the task to move
> back to the run_list is for wake_up to be called, which, of course (^C)
> does. In your case it would be best if you could get what ever sets
> "flag" to call wake_up.
>
> If what you really want to do is to spin in a SCHED_YIELD waiting for
> "flag" you need to a.) move the setting of SCHED_YIELD inside the while,
> and b.) eliminate the setting of current_state (both of them).
>
> George
Okay. Thanks. That works
Cheers,
Dick Johnson
Penguin : Linux version 2.2.4 on an i686 machine (400.59 BogoMips).
"Memory is like gasoline. You use it up when you are running. Of
course you get it all back when you reboot..."; Actual explanation
obtained from the Micro$oft help desk.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
This archive was generated by hypermail 2b29 : Mon Apr 23 2001 - 21:00:27 EST