aboutsummaryrefslogtreecommitdiffstats
path: root/fs/proc/array.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/proc/array.c')
-rw-r--r--fs/proc/array.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/fs/proc/array.c b/fs/proc/array.c
index 9390032a11e1..79375fc115d2 100644
--- a/fs/proc/array.c
+++ b/fs/proc/array.c
@@ -138,7 +138,7 @@ static const char * const task_state_array[] = {
138static inline const char *get_task_state(struct task_struct *tsk) 138static inline const char *get_task_state(struct task_struct *tsk)
139{ 139{
140 BUILD_BUG_ON(1 + ilog2(TASK_REPORT_MAX) != ARRAY_SIZE(task_state_array)); 140 BUILD_BUG_ON(1 + ilog2(TASK_REPORT_MAX) != ARRAY_SIZE(task_state_array));
141 return task_state_array[__get_task_state(tsk)]; 141 return task_state_array[task_state_index(tsk)];
142} 142}
143 143
144static inline int get_task_umask(struct task_struct *tsk) 144static inline int get_task_umask(struct task_struct *tsk)
@@ -366,6 +366,11 @@ static void task_cpus_allowed(struct seq_file *m, struct task_struct *task)
366 cpumask_pr_args(&task->cpus_allowed)); 366 cpumask_pr_args(&task->cpus_allowed));
367} 367}
368 368
369static inline void task_core_dumping(struct seq_file *m, struct mm_struct *mm)
370{
371 seq_printf(m, "CoreDumping:\t%d\n", !!mm->core_state);
372}
373
369int proc_pid_status(struct seq_file *m, struct pid_namespace *ns, 374int proc_pid_status(struct seq_file *m, struct pid_namespace *ns,
370 struct pid *pid, struct task_struct *task) 375 struct pid *pid, struct task_struct *task)
371{ 376{
@@ -376,6 +381,7 @@ int proc_pid_status(struct seq_file *m, struct pid_namespace *ns,
376 381
377 if (mm) { 382 if (mm) {
378 task_mem(m, mm); 383 task_mem(m, mm);
384 task_core_dumping(m, mm);
379 mmput(mm); 385 mmput(mm);
380 } 386 }
381 task_sig(m, task); 387 task_sig(m, task);
@@ -454,7 +460,7 @@ static int do_task_stat(struct seq_file *m, struct pid_namespace *ns,
454 cutime = sig->cutime; 460 cutime = sig->cutime;
455 cstime = sig->cstime; 461 cstime = sig->cstime;
456 cgtime = sig->cgtime; 462 cgtime = sig->cgtime;
457 rsslim = ACCESS_ONCE(sig->rlim[RLIMIT_RSS].rlim_cur); 463 rsslim = READ_ONCE(sig->rlim[RLIMIT_RSS].rlim_cur);
458 464
459 /* add up live thread stats at the group level */ 465 /* add up live thread stats at the group level */
460 if (whole) { 466 if (whole) {