LKML Archive on lore.kernel.org help / color / mirror / Atom feed
From: Marcelo Tosatti <mtosatti@redhat.com> To: linux-kernel@vger.kernel.org Cc: Nitesh Lal <nilal@redhat.com>, Nicolas Saenz Julienne <nsaenzju@redhat.com>, Frederic Weisbecker <frederic@kernel.org>, Christoph Lameter <cl@linux.com>, Juri Lelli <juri.lelli@redhat.com>, Peter Zijlstra <peterz@infradead.org>, Alex Belits <abelits@belits.com>, Peter Xu <peterx@redhat.com> Subject: [patch V3 4/8] procfs: add per-pid task isolation state Date: Tue, 24 Aug 2021 12:24:27 -0300 [thread overview] Message-ID: <20210824152646.784916432@fuller.cnet> (raw) In-Reply-To: 20210824152423.300346181@fuller.cnet Add /proc/pid/task_isolation file, to query the state of task isolation configuration. --- fs/proc/base.c | 4 ++ include/linux/task_isolation.h | 2 + kernel/task_isolation.c | 60 +++++++++++++++++++++++++++++++++++++++++ 3 files changed, 66 insertions(+) Index: linux-2.6/fs/proc/base.c =================================================================== --- linux-2.6.orig/fs/proc/base.c +++ linux-2.6/fs/proc/base.c @@ -95,6 +95,8 @@ #include <linux/posix-timers.h> #include <linux/time_namespace.h> #include <linux/resctrl.h> +#include <linux/prctl.h> +#include <linux/task_isolation.h> #include <trace/events/oom.h> #include "internal.h" #include "fd.h" @@ -661,6 +663,69 @@ static int proc_pid_syscall(struct seq_f } #endif /* CONFIG_HAVE_ARCH_TRACEHOOK */ +#ifdef CONFIG_CPU_ISOLATION + +struct qoptions { + unsigned long mask; + char *name; +}; + +static struct qoptions iopts[] = { + {ISOL_F_QUIESCE, "quiesce"}, +}; +#define ILEN (sizeof(iopts) / sizeof(struct qoptions)) + +static struct qoptions qopts[] = { + {ISOL_F_QUIESCE_VMSTATS, "vmstat_sync"}, +}; +#define QLEN (sizeof(qopts) / sizeof(struct qoptions)) + +static void show_isolation_state(struct seq_file *m, + struct qoptions *iopt, + int mask, + const char *hdr) +{ + int i; + + seq_printf(m, hdr); + for (i = 0; i < ILEN; i++) { + if (mask & iopt->mask) + seq_printf(m, "%s ", iopt->name); + iopt++; + } + if (mask == 0) + seq_printf(m, "none "); + seq_printf(m, "\n"); +} + +int proc_pid_task_isolation(struct seq_file *m, struct pid_namespace *ns, + struct pid *pid, struct task_struct *t) +{ + int active_mask, quiesce_mask, conf_mask; + struct isol_info *isol_info; + struct inode *inode = m->private; + struct task_struct *task = get_proc_task(inode); + + isol_info = t->isol_info; + if (!isol_info) + active_mask = quiesce_mask = conf_mask = 0; + else { + active_mask = isol_info->active_mask; + quiesce_mask = isol_info->quiesce_mask; + conf_mask = isol_info->conf_mask; + } + + show_isolation_state(m, iopts, conf_mask, "Configured state: "); + show_isolation_state(m, iopts, active_mask, "Active state: "); + show_isolation_state(m, qopts, quiesce_mask, "Quiescing: "); + + put_task_struct(task); + + return 0; +} + +#endif /* CONFIG_CPU_ISOLATION */ + /************************************************************************/ /* Here the fs part begins */ /************************************************************************/ @@ -3278,6 +3343,9 @@ static const struct pid_entry tgid_base_ #ifdef CONFIG_SECCOMP_CACHE_DEBUG ONE("seccomp_cache", S_IRUSR, proc_pid_seccomp_cache), #endif +#ifdef CONFIG_CPU_ISOLATION + ONE("task_isolation", S_IRUSR, proc_pid_task_isolation), +#endif }; static int proc_tgid_base_readdir(struct file *file, struct dir_context *ctx)
next prev parent reply other threads:[~2021-08-24 15:42 UTC|newest] Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top 2021-08-24 15:24 [patch V3 0/8] extensible prctl task isolation interface and vmstat sync Marcelo Tosatti 2021-08-24 15:24 ` [patch V3 1/8] add basic task isolation prctl interface Marcelo Tosatti 2021-08-24 15:24 ` [patch V3 2/8] add prctl task isolation prctl docs and samples Marcelo Tosatti 2021-08-26 9:59 ` Frederic Weisbecker 2021-08-26 12:11 ` Marcelo Tosatti 2021-08-26 19:15 ` Christoph Lameter 2021-08-26 20:37 ` Marcelo Tosatti 2021-08-27 13:08 ` Frederic Weisbecker 2021-08-27 14:44 ` Marcelo Tosatti 2021-08-30 11:38 ` Frederic Weisbecker 2021-09-01 13:11 ` Nitesh Lal 2021-09-01 17:34 ` Marcelo Tosatti 2021-09-01 17:49 ` Nitesh Lal 2021-08-24 15:24 ` [patch V3 3/8] task isolation: sync vmstats on return to userspace Marcelo Tosatti 2021-09-10 13:49 ` nsaenzju 2021-08-24 15:24 ` Marcelo Tosatti [this message] 2021-08-24 15:24 ` [patch V3 5/8] task isolation: sync vmstats conditional on changes Marcelo Tosatti 2021-08-25 9:46 ` Christoph Lameter 2021-08-24 15:24 ` [patch V3 6/8] KVM: x86: call isolation prepare from VM-entry code path Marcelo Tosatti 2021-08-24 15:24 ` [patch V3 7/8] mm: vmstat: move need_update Marcelo Tosatti 2021-08-24 15:24 ` [patch V3 8/8] mm: vmstat_refresh: avoid queueing work item if cpu stats are clean Marcelo Tosatti 2021-08-25 9:30 ` Christoph Lameter 2021-09-01 13:05 ` Nitesh Lal 2021-09-01 17:32 ` Marcelo Tosatti 2021-09-01 18:33 ` Marcelo Tosatti 2021-09-03 17:38 ` Nitesh Lal 2021-08-25 10:02 ` [patch V3 0/8] extensible prctl task isolation interface and vmstat sync Marcelo Tosatti
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20210824152646.784916432@fuller.cnet \ --to=mtosatti@redhat.com \ --cc=abelits@belits.com \ --cc=cl@linux.com \ --cc=frederic@kernel.org \ --cc=juri.lelli@redhat.com \ --cc=linux-kernel@vger.kernel.org \ --cc=nilal@redhat.com \ --cc=nsaenzju@redhat.com \ --cc=peterx@redhat.com \ --cc=peterz@infradead.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).