Well. I was going to ignore this patch, I will leave this to Thomas
anyway...

But can't resist, because I have to admit I dislike this one too ;)

On 10/25, Roman Pen wrote:
>
>  int kthread_park(struct task_struct *k)
>  {
> -     struct kthread *kthread = to_live_kthread_and_get(k);
> +     struct kthread *kthread;
>       int ret = -ENOSYS;
>  
> -     if (kthread) {
> -             if (!test_bit(KTHREAD_IS_PARKED, &kthread->flags)) {
> +     /*
> +      * Here we try to be careful and handle the case, when kthread
> +      * is going to die and will never park.

But why?

IMO we should not complicate this code for the case when the kernel
thread crashes.

> +     do {
> +             kthread = to_live_kthread_and_get(k);
> +             if (!kthread)
> +                     break;
> +             if (!__kthread_isparked(kthread)) {
>                       set_bit(KTHREAD_SHOULD_PARK, &kthread->flags);
>                       if (k != current) {
>                               wake_up_process(k);
>                               wait_for_completion(&kthread->parked);
>                       }
>               }
> +             if (k == current || __kthread_isparked(kthread))
> +                     /* The way out */
> +                     ret = 0;

And why do we need to restart if __kthread_isparked() is false? In this
case we know that we were woken up by the exiting kthread which won't
park anyway.

Oleg.

Reply via email to