Re: [PATCH 2/2] posix-cpu-timers: use ->sighand instead of->signal to check the task is alive
From: Roland McGrath
Date: Thu Feb 05 2009 - 15:52:14 EST
> We can't use them as refcounts. You can't bump ->live or ->count without
> breaking group_dead or exec logic. Perhaps we can use ->count, but then
> we need other changes.
We certainly need to clean up exec anyway.
> But this has nothing to do with this patch.
Agreed.
> The goal is to keep task->signal after release_task(), it will be freed
> by __put_task_struct(). This allows a lot of simplifications and we can
> move some fields from task_struct to signal_struct.
That sounds fine to me in theory, but I still wonder what the story will be
about the use of siglock.
> But first we should change the code which does [...]
I did understand the rationale given the signal_struct lifetime change.
> > Uses here protecting cpu_clock_sample_group() e.g., are
> > around looking at ->signal->foobar, so if ->signal is still there, why not
> > look at it and be able to get the sample in whatever small window this is?
>
> What if arm_timer() sees ->signal != NULL, proceeds, and attaches the
> timer to the signal_struct of the already dead task? This signal_strcut
> will be released with the pending timer.
Of course. I distinctly mentioned the read-only uses (sample).
> Even cpu_clock_sample_group() is not safe, unless we add other changes.
Why? It does no locking and only relies on the signal_struct lifetime.
> But in any case. Even if we don't need the further changes, do you
> agree this patch is correct and doesn't change the behaviour?
Yes.
Thanks,
Roland
--
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/