[PATCH] D36607: [Support/Parallel] - Do not spawn thread for single/last task.
Davide Italiano via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Aug 16 05:47:05 PDT 2017
davide added a comment.
In https://reviews.llvm.org/D36607#843179, @grimar wrote:
> In https://reviews.llvm.org/D36607#843164, @davide wrote:
>
> > Adaptive mutexes (e.g. for pthread_*) work using this principle. The kernel maintains a shared page and threads contending on the lock spin until the lock owner isn't descheduled.
> > This works because in general the cost of a context switch overcomes that of wasting few cycles spinning (under the assumption the CS is small).
> > An approximation of this scheme would be that of spinning for a certain number of cycles decreasing a variable each time (and going to sleep when the variable reaches zero).
> > This is, FWIW, what FreeBSD pthread mutexes do.
> > A different (and possibly more effective) proposal for `Parallel` would be that of exploring work-stealing algorithms for queueing.
>
>
> Interesting.
> And what this patch do is orthogonal thing, since helps to avoid all threading/syncing overhead at all for free in some cases.
This is not true in general. Imagine that the `Fn(J)` callback takes a considerable amount of time, much larger than the synchronization overhead, then your sequential version will take much more time than the parallel version (unless I'm missing some detail).
It's hard to find the right balance without having a characterization of the length of a critical section (or, FWIW, the data access pattern).
In other words, I think your patch just "fixes" this problem but may cause a significant slowdown somewhere else. LLVM doesn't make a heavy use of parallel/concurrent data structures, so it's unlikely to show up in practice.
If you still want to go for this route (I'm not sure it's the best way forward, alas) you should at least guarantee this doesn't regress ThinLTO (which is the only other main consumer of parallel).
https://reviews.llvm.org/D36607
More information about the llvm-commits
mailing list