}
 static DEVICE_ATTR_RO(size);
 
+static ssize_t deep_flush_show(struct device *dev,
+               struct device_attribute *attr, char *buf)
+{
+       struct nd_region *nd_region = to_nd_region(dev);
+
+       /*
+        * NOTE: in the nvdimm_has_flush() error case this attribute is
+        * not visible.
+        */
+       return sprintf(buf, "%d\n", nvdimm_has_flush(nd_region));
+}
+
+static ssize_t deep_flush_store(struct device *dev, struct device_attribute *attr,
+               const char *buf, size_t len)
+{
+       bool flush;
+       int rc = strtobool(buf, &flush);
+       struct nd_region *nd_region = to_nd_region(dev);
+
+       if (rc)
+               return rc;
+       if (!flush)
+               return -EINVAL;
+       nvdimm_flush(nd_region);
+
+       return len;
+}
+static DEVICE_ATTR_RW(deep_flush);
+
 static ssize_t mappings_show(struct device *dev,
                struct device_attribute *attr, char *buf)
 {
        &dev_attr_btt_seed.attr,
        &dev_attr_pfn_seed.attr,
        &dev_attr_dax_seed.attr,
+       &dev_attr_deep_flush.attr,
        &dev_attr_read_only.attr,
        &dev_attr_set_cookie.attr,
        &dev_attr_available_size.attr,
        if (!is_nd_pmem(dev) && a == &dev_attr_resource.attr)
                return 0;
 
+       if (a == &dev_attr_deep_flush.attr) {
+               int has_flush = nvdimm_has_flush(nd_region);
+
+               if (has_flush == 1)
+                       return a->mode;
+               else if (has_flush == 0)
+                       return 0444;
+               else
+                       return 0;
+       }
+
        if (a != &dev_attr_set_cookie.attr
                        && a != &dev_attr_available_size.attr)
                return a->mode;