diff options
-rw-r--r-- | kernel/rcutree_trace.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/kernel/rcutree_trace.c b/kernel/rcutree_trace.c index 4b31c779e62e..1984cdc51e9a 100644 --- a/kernel/rcutree_trace.c +++ b/kernel/rcutree_trace.c | |||
@@ -155,12 +155,14 @@ static const struct file_operations rcudata_csv_fops = { | |||
155 | 155 | ||
156 | static void print_one_rcu_state(struct seq_file *m, struct rcu_state *rsp) | 156 | static void print_one_rcu_state(struct seq_file *m, struct rcu_state *rsp) |
157 | { | 157 | { |
158 | long gpnum; | ||
158 | int level = 0; | 159 | int level = 0; |
159 | struct rcu_node *rnp; | 160 | struct rcu_node *rnp; |
160 | 161 | ||
162 | gpnum = rsp->gpnum; | ||
161 | seq_printf(m, "c=%ld g=%ld s=%d jfq=%ld j=%x " | 163 | seq_printf(m, "c=%ld g=%ld s=%d jfq=%ld j=%x " |
162 | "nfqs=%lu/nfqsng=%lu(%lu) fqlh=%lu oqlen=%ld\n", | 164 | "nfqs=%lu/nfqsng=%lu(%lu) fqlh=%lu oqlen=%ld\n", |
163 | rsp->completed, rsp->gpnum, rsp->signaled, | 165 | rsp->completed, gpnum, rsp->signaled, |
164 | (long)(rsp->jiffies_force_qs - jiffies), | 166 | (long)(rsp->jiffies_force_qs - jiffies), |
165 | (int)(jiffies & 0xffff), | 167 | (int)(jiffies & 0xffff), |
166 | rsp->n_force_qs, rsp->n_force_qs_ngp, | 168 | rsp->n_force_qs, rsp->n_force_qs_ngp, |
@@ -171,8 +173,10 @@ static void print_one_rcu_state(struct seq_file *m, struct rcu_state *rsp) | |||
171 | seq_puts(m, "\n"); | 173 | seq_puts(m, "\n"); |
172 | level = rnp->level; | 174 | level = rnp->level; |
173 | } | 175 | } |
174 | seq_printf(m, "%lx/%lx %d:%d ^%d ", | 176 | seq_printf(m, "%lx/%lx %c>%c %d:%d ^%d ", |
175 | rnp->qsmask, rnp->qsmaskinit, | 177 | rnp->qsmask, rnp->qsmaskinit, |
178 | "T."[list_empty(&rnp->blocked_tasks[gpnum & 1])], | ||
179 | "T."[list_empty(&rnp->blocked_tasks[!(gpnum & 1)])], | ||
176 | rnp->grplo, rnp->grphi, rnp->grpnum); | 180 | rnp->grplo, rnp->grphi, rnp->grpnum); |
177 | } | 181 | } |
178 | seq_puts(m, "\n"); | 182 | seq_puts(m, "\n"); |