Hello, Currently, percpu_ref destruction - freeing the percpu counter - happens when the percpu_ref is released. This while a bit more convenient restricts how percpu_ref can be used. It can't be initialized with static percpu area and it can't be reinitialized without going through percpu allocation.
There are use cases which can take advantage of cycling percpu_ref through init/release multiple times. This patchset separates out percpu_ref destruction into percpu_exit() which should be invoked explicitly and introduces percpu_ref_reinit() which can be used to recycle a released percpu_ref. This patchset doesn't add any users. Patchset to use this will soon be posted. This patchset contains the following six patches. 0001-percpu-refcount-aio-use-percpu_ref_cancel_init-in-io.patch 0002-percpu-refcount-one-bit-is-enough-for-REF_STATUS.patch 0003-percpu-refcount-add-helpers-for-percpu_count-accesse.patch 0004-percpu-refcount-use-unsigned-long-for-pcpu_count-poi.patch 0005-percpu-refcount-require-percpu_ref-to-be-exited-expl.patch 0006-percpu-refcount-implement-percpu_ref_reinit-and-perc.patch 0001-0004 are prep/cleanups. 0005 separates out percpu destruction into percpu_ref_exit() and 0006 implements percpu_ref_reinit(). This patchset is on top of percpu/for-3.17 6fbc07bbe2b5 ("percpu: invoke __verify_pcpu_ptr() from the generic part of accessors and operations"). diffstat follows. drivers/target/target_core_tpg.c | 4 + fs/aio.c | 6 +- include/linux/percpu-refcount.h | 64 +++++++++++++++++++---------- kernel/cgroup.c | 8 ++- lib/percpu-refcount.c | 86 ++++++++++++++++++++++++--------------- 5 files changed, 109 insertions(+), 59 deletions(-) Thanks. -- tejun -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/