__read_mostly bool sched_debug_verbose;
 
+#ifdef CONFIG_SMP
+static struct dentry           *sd_dentry;
+
+
+static ssize_t sched_verbose_write(struct file *filp, const char __user *ubuf,
+                                 size_t cnt, loff_t *ppos)
+{
+       ssize_t result;
+       bool orig;
+
+       cpus_read_lock();
+       mutex_lock(&sched_domains_mutex);
+
+       orig = sched_debug_verbose;
+       result = debugfs_write_file_bool(filp, ubuf, cnt, ppos);
+
+       if (sched_debug_verbose && !orig)
+               update_sched_domain_debugfs();
+       else if (!sched_debug_verbose && orig) {
+               debugfs_remove(sd_dentry);
+               sd_dentry = NULL;
+       }
+
+       mutex_unlock(&sched_domains_mutex);
+       cpus_read_unlock();
+
+       return result;
+}
+#else
+#define sched_verbose_write debugfs_write_file_bool
+#endif
+
+static const struct file_operations sched_verbose_fops = {
+       .read =         debugfs_read_file_bool,
+       .write =        sched_verbose_write,
+       .open =         simple_open,
+       .llseek =       default_llseek,
+};
+
 static const struct seq_operations sched_debug_sops;
 
 static int sched_debug_open(struct inode *inode, struct file *filp)
        debugfs_sched = debugfs_create_dir("sched", NULL);
 
        debugfs_create_file("features", 0644, debugfs_sched, NULL, &sched_feat_fops);
-       debugfs_create_bool("verbose", 0644, debugfs_sched, &sched_debug_verbose);
+       debugfs_create_file_unsafe("verbose", 0644, debugfs_sched, &sched_debug_verbose, &sched_verbose_fops);
 #ifdef CONFIG_PREEMPT_DYNAMIC
        debugfs_create_file("preempt", 0644, debugfs_sched, NULL, &sched_dynamic_fops);
 #endif
 #ifdef CONFIG_SMP
 
 static cpumask_var_t           sd_sysctl_cpus;
-static struct dentry           *sd_dentry;
 
 static int sd_flags_show(struct seq_file *m, void *v)
 {
        if (!debugfs_sched)
                return;
 
+       if (!sched_debug_verbose)
+               return;
+
        if (!cpumask_available(sd_sysctl_cpus)) {
                if (!alloc_cpumask_var(&sd_sysctl_cpus, GFP_KERNEL))
                        return;
                cpumask_copy(sd_sysctl_cpus, cpu_possible_mask);
        }
 
-       if (!sd_dentry)
+       if (!sd_dentry) {
                sd_dentry = debugfs_create_dir("domains", debugfs_sched);
 
+               /* rebuild sd_sysctl_cpus if empty since it gets cleared below */
+               if (cpumask_empty(sd_sysctl_cpus))
+                       cpumask_copy(sd_sysctl_cpus, cpu_online_mask);
+       }
+
        for_each_cpu(cpu, sd_sysctl_cpus) {
                struct sched_domain *sd;
                struct dentry *d_cpu;