diff options
author | Paul E. McKenney <paulmck@linux.ibm.com> | 2019-01-11 23:51:49 -0500 |
---|---|---|
committer | Paul E. McKenney <paulmck@linux.ibm.com> | 2019-03-26 17:40:13 -0400 |
commit | d87cda5094585b7a0f62075de68266cb9c1b35ca (patch) | |
tree | d23e6a6f7143ee36505312db1bebee7e2a189e52 /kernel/rcu/tree_plugin.h | |
parent | 21d0d79ab051bf9facb9960a30e58b93a31c75a5 (diff) |
rcu: Move rcu_print_task_exp_stall() to tree_exp.h
Because expedited CPU stall warnings are contained within the
kernel/rcu/tree_exp.h file, rcu_print_task_exp_stall() should live
there too. This commit carries out the required code motion.
Signed-off-by: Paul E. McKenney <paulmck@linux.ibm.com>
Diffstat (limited to 'kernel/rcu/tree_plugin.h')
-rw-r--r-- | kernel/rcu/tree_plugin.h | 31 |
1 files changed, 0 insertions, 31 deletions
diff --git a/kernel/rcu/tree_plugin.h b/kernel/rcu/tree_plugin.h index 7fa3bc4d481b..72519c57f656 100644 --- a/kernel/rcu/tree_plugin.h +++ b/kernel/rcu/tree_plugin.h | |||
@@ -643,27 +643,6 @@ static void rcu_read_unlock_special(struct task_struct *t) | |||
643 | } | 643 | } |
644 | 644 | ||
645 | /* | 645 | /* |
646 | * Scan the current list of tasks blocked within RCU read-side critical | ||
647 | * sections, printing out the tid of each that is blocking the current | ||
648 | * expedited grace period. | ||
649 | */ | ||
650 | static int rcu_print_task_exp_stall(struct rcu_node *rnp) | ||
651 | { | ||
652 | struct task_struct *t; | ||
653 | int ndetected = 0; | ||
654 | |||
655 | if (!rnp->exp_tasks) | ||
656 | return 0; | ||
657 | t = list_entry(rnp->exp_tasks->prev, | ||
658 | struct task_struct, rcu_node_entry); | ||
659 | list_for_each_entry_continue(t, &rnp->blkd_tasks, rcu_node_entry) { | ||
660 | pr_cont(" P%d", t->pid); | ||
661 | ndetected++; | ||
662 | } | ||
663 | return ndetected; | ||
664 | } | ||
665 | |||
666 | /* | ||
667 | * Check that the list of blocked tasks for the newly completed grace | 646 | * Check that the list of blocked tasks for the newly completed grace |
668 | * period is in fact empty. It is a serious bug to complete a grace | 647 | * period is in fact empty. It is a serious bug to complete a grace |
669 | * period that still has RCU readers blocked! This function must be | 648 | * period that still has RCU readers blocked! This function must be |
@@ -907,16 +886,6 @@ static bool rcu_preempt_need_deferred_qs(struct task_struct *t) | |||
907 | static void rcu_preempt_deferred_qs(struct task_struct *t) { } | 886 | static void rcu_preempt_deferred_qs(struct task_struct *t) { } |
908 | 887 | ||
909 | /* | 888 | /* |
910 | * Because preemptible RCU does not exist, we never have to check for | ||
911 | * tasks blocked within RCU read-side critical sections that are | ||
912 | * blocking the current expedited grace period. | ||
913 | */ | ||
914 | static int rcu_print_task_exp_stall(struct rcu_node *rnp) | ||
915 | { | ||
916 | return 0; | ||
917 | } | ||
918 | |||
919 | /* | ||
920 | * Because there is no preemptible RCU, there can be no readers blocked, | 889 | * Because there is no preemptible RCU, there can be no readers blocked, |
921 | * so there is no need to check for blocked tasks. So check only for | 890 | * so there is no need to check for blocked tasks. So check only for |
922 | * bogus qsmask values. | 891 | * bogus qsmask values. |