Re: the select system call's implementation may have some bug in preempt kernel mode

From: wu Jianfeng
Date: Fri Oct 09 2009 - 03:12:45 EST


> Right, but that does not cause the task to be scheduled out for ever.

I don't know why ???
the process state is TASK_INTERRUPTIBLE, and was scheduled out.

if no one wake up it or any signals received, it will sleep for ever.
The process does't entered any file's wait queue at that point, so I
am sure no one will wake up it.

Am i right?


2009/10/9 Thomas Gleixner <tglx@xxxxxxxxxxxxx>:
> On Fri, 9 Oct 2009, wu Jianfeng wrote:
>> A process may sleep for ever when he call select system call.
>> In detail, if the process was scheduled out just at the point it set
>> its state to TASK_INTERRUPTIBLE.
>>
>> The events that may cause the process to be scheduled out is(in
>> preempt kernel) :
>> 1) time interrupt and the process's time slice is exhausted.
>> 2) an interrupt accured, and wake up another process with high priority.
>
> Right, but that does not cause the task to be scheduled out for ever.
>
>>               set_current_state(TASK_INTERRUPTIBLE);   ######## here set the
>> interrupt to  TASK_INTERRUPTIBLE state
>>
>>                ########### if the process was schedued out here, it
>> will can never been waken up .
>>                ########### Because the process wasn't attached to any
>> file's waitqueue at this point yet
>
> When the task is scheduled out at that point, it is not
> deactivated. It is preempted, which means it stays on the run queue
> despite of the TASK_INTERRUPTIBLE state and is scheduled back in later
> on.
>
> Thanks,
>
>        tglx
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/