提交 b2302c7f 编写于 作者: T Tejun Heo

percpu_ref: reorganize __percpu_ref_switch_to_atomic() and relocate percpu_ref_switch_to_atomic()

Reorganize __percpu_ref_switch_to_atomic() so that it looks
structurally similar to __percpu_ref_switch_to_percpu() and relocate
percpu_ref_switch_to_atomic so that the two internal functions are
co-located.

This patch doesn't introduce any functional differences.
Signed-off-by: NTejun Heo <tj@kernel.org>
上级 a2f5630c
...@@ -161,56 +161,30 @@ static void percpu_ref_noop_confirm_switch(struct percpu_ref *ref) ...@@ -161,56 +161,30 @@ static void percpu_ref_noop_confirm_switch(struct percpu_ref *ref)
static void __percpu_ref_switch_to_atomic(struct percpu_ref *ref, static void __percpu_ref_switch_to_atomic(struct percpu_ref *ref,
percpu_ref_func_t *confirm_switch) percpu_ref_func_t *confirm_switch)
{ {
if (!(ref->percpu_count_ptr & __PERCPU_REF_ATOMIC)) { if (ref->percpu_count_ptr & __PERCPU_REF_ATOMIC) {
/* switching from percpu to atomic */ if (confirm_switch) {
ref->percpu_count_ptr |= __PERCPU_REF_ATOMIC; /*
* Somebody else already set ATOMIC. Wait for its
/* * completion and invoke @confirm_switch() directly.
* Non-NULL ->confirm_switch is used to indicate that */
* switching is in progress. Use noop one if unspecified. wait_event(percpu_ref_switch_waitq, !ref->confirm_switch);
*/ confirm_switch(ref);
WARN_ON_ONCE(ref->confirm_switch); }
ref->confirm_switch = return;
confirm_switch ?: percpu_ref_noop_confirm_switch;
percpu_ref_get(ref); /* put after confirmation */
call_rcu_sched(&ref->rcu, percpu_ref_switch_to_atomic_rcu);
} else if (confirm_switch) {
/*
* Somebody else already set ATOMIC. Wait for its
* completion and invoke @confirm_switch() directly.
*/
wait_event(percpu_ref_switch_waitq, !ref->confirm_switch);
confirm_switch(ref);
} }
}
/** /* switching from percpu to atomic */
* percpu_ref_switch_to_atomic - switch a percpu_ref to atomic mode ref->percpu_count_ptr |= __PERCPU_REF_ATOMIC;
* @ref: percpu_ref to switch to atomic mode
* @confirm_switch: optional confirmation callback /*
* * Non-NULL ->confirm_switch is used to indicate that switching is
* There's no reason to use this function for the usual reference counting. * in progress. Use noop one if unspecified.
* Use percpu_ref_kill[_and_confirm](). */
* WARN_ON_ONCE(ref->confirm_switch);
* Schedule switching of @ref to atomic mode. All its percpu counts will ref->confirm_switch = confirm_switch ?: percpu_ref_noop_confirm_switch;
* be collected to the main atomic counter. On completion, when all CPUs
* are guaraneed to be in atomic mode, @confirm_switch, which may not percpu_ref_get(ref); /* put after confirmation */
* block, is invoked. This function may be invoked concurrently with all call_rcu_sched(&ref->rcu, percpu_ref_switch_to_atomic_rcu);
* the get/put operations and can safely be mixed with kill and reinit
* operations. Note that @ref will stay in atomic mode across kill/reinit
* cycles until percpu_ref_switch_to_percpu() is called.
*
* This function normally doesn't block and can be called from any context
* but it may block if @confirm_kill is specified and @ref is already in
* the process of switching to atomic mode. In such cases, @confirm_switch
* will be invoked after the switching is complete.
*/
void percpu_ref_switch_to_atomic(struct percpu_ref *ref,
percpu_ref_func_t *confirm_switch)
{
ref->force_atomic = true;
__percpu_ref_switch_to_atomic(ref, confirm_switch);
} }
static void __percpu_ref_switch_to_percpu(struct percpu_ref *ref) static void __percpu_ref_switch_to_percpu(struct percpu_ref *ref)
...@@ -240,6 +214,34 @@ static void __percpu_ref_switch_to_percpu(struct percpu_ref *ref) ...@@ -240,6 +214,34 @@ static void __percpu_ref_switch_to_percpu(struct percpu_ref *ref)
ref->percpu_count_ptr & ~__PERCPU_REF_ATOMIC); ref->percpu_count_ptr & ~__PERCPU_REF_ATOMIC);
} }
/**
* percpu_ref_switch_to_atomic - switch a percpu_ref to atomic mode
* @ref: percpu_ref to switch to atomic mode
* @confirm_switch: optional confirmation callback
*
* There's no reason to use this function for the usual reference counting.
* Use percpu_ref_kill[_and_confirm]().
*
* Schedule switching of @ref to atomic mode. All its percpu counts will
* be collected to the main atomic counter. On completion, when all CPUs
* are guaraneed to be in atomic mode, @confirm_switch, which may not
* block, is invoked. This function may be invoked concurrently with all
* the get/put operations and can safely be mixed with kill and reinit
* operations. Note that @ref will stay in atomic mode across kill/reinit
* cycles until percpu_ref_switch_to_percpu() is called.
*
* This function normally doesn't block and can be called from any context
* but it may block if @confirm_kill is specified and @ref is already in
* the process of switching to atomic mode. In such cases, @confirm_switch
* will be invoked after the switching is complete.
*/
void percpu_ref_switch_to_atomic(struct percpu_ref *ref,
percpu_ref_func_t *confirm_switch)
{
ref->force_atomic = true;
__percpu_ref_switch_to_atomic(ref, confirm_switch);
}
/** /**
* percpu_ref_switch_to_percpu - switch a percpu_ref to percpu mode * percpu_ref_switch_to_percpu - switch a percpu_ref to percpu mode
* @ref: percpu_ref to switch to percpu mode * @ref: percpu_ref to switch to percpu mode
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册