|
@@ -162,11 +162,14 @@ static void invoke_rcu_callbacks(struct rcu_state *rsp, struct rcu_data *rdp);
|
|
|
static int kthread_prio = CONFIG_RCU_KTHREAD_PRIO;
|
|
|
module_param(kthread_prio, int, 0644);
|
|
|
|
|
|
-/* Delay in jiffies for grace-period initialization delays. */
|
|
|
-static int gp_init_delay = IS_ENABLED(CONFIG_RCU_TORTURE_TEST_SLOW_INIT)
|
|
|
- ? CONFIG_RCU_TORTURE_TEST_SLOW_INIT_DELAY
|
|
|
- : 0;
|
|
|
+/* Delay in jiffies for grace-period initialization delays, debug only. */
|
|
|
+#ifdef CONFIG_RCU_TORTURE_TEST_SLOW_INIT
|
|
|
+static int gp_init_delay = CONFIG_RCU_TORTURE_TEST_SLOW_INIT_DELAY;
|
|
|
module_param(gp_init_delay, int, 0644);
|
|
|
+#else /* #ifdef CONFIG_RCU_TORTURE_TEST_SLOW_INIT */
|
|
|
+static const int gp_init_delay;
|
|
|
+#endif /* #else #ifdef CONFIG_RCU_TORTURE_TEST_SLOW_INIT */
|
|
|
+#define PER_RCU_NODE_PERIOD 10 /* Number of grace periods between delays. */
|
|
|
|
|
|
/*
|
|
|
* Track the rcutorture test sequence number and the update version
|
|
@@ -1843,9 +1846,8 @@ static int rcu_gp_init(struct rcu_state *rsp)
|
|
|
raw_spin_unlock_irq(&rnp->lock);
|
|
|
cond_resched_rcu_qs();
|
|
|
ACCESS_ONCE(rsp->gp_activity) = jiffies;
|
|
|
- if (IS_ENABLED(CONFIG_RCU_TORTURE_TEST_SLOW_INIT) &&
|
|
|
- gp_init_delay > 0 &&
|
|
|
- !(rsp->gpnum % (rcu_num_nodes * 10)))
|
|
|
+ if (gp_init_delay > 0 &&
|
|
|
+ !(rsp->gpnum % (rcu_num_nodes * PER_RCU_NODE_PERIOD)))
|
|
|
schedule_timeout_uninterruptible(gp_init_delay);
|
|
|
}
|
|
|
|