|
@@ -1051,7 +1051,37 @@ static ssize_t io_stat_show(struct device *dev,
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static ssize_t mm_stat_show(struct device *dev,
|
|
|
|
+ struct device_attribute *attr, char *buf)
|
|
|
|
+{
|
|
|
|
+ struct zram *zram = dev_to_zram(dev);
|
|
|
|
+ u64 orig_size, mem_used = 0;
|
|
|
|
+ long max_used;
|
|
|
|
+ ssize_t ret;
|
|
|
|
+
|
|
|
|
+ down_read(&zram->init_lock);
|
|
|
|
+ if (init_done(zram))
|
|
|
|
+ mem_used = zs_get_total_pages(zram->meta->mem_pool);
|
|
|
|
+
|
|
|
|
+ orig_size = atomic64_read(&zram->stats.pages_stored);
|
|
|
|
+ max_used = atomic_long_read(&zram->stats.max_used_pages);
|
|
|
|
+
|
|
|
|
+ ret = scnprintf(buf, PAGE_SIZE,
|
|
|
|
+ "%8llu %8llu %8llu %8lu %8ld %8llu %8llu\n",
|
|
|
|
+ orig_size << PAGE_SHIFT,
|
|
|
|
+ (u64)atomic64_read(&zram->stats.compr_data_size),
|
|
|
|
+ mem_used << PAGE_SHIFT,
|
|
|
|
+ zram->limit_pages << PAGE_SHIFT,
|
|
|
|
+ max_used << PAGE_SHIFT,
|
|
|
|
+ (u64)atomic64_read(&zram->stats.zero_pages),
|
|
|
|
+ (u64)atomic64_read(&zram->stats.num_migrated));
|
|
|
|
+ up_read(&zram->init_lock);
|
|
|
|
+
|
|
|
|
+ return ret;
|
|
|
|
+}
|
|
|
|
+
|
|
static DEVICE_ATTR_RO(io_stat);
|
|
static DEVICE_ATTR_RO(io_stat);
|
|
|
|
+static DEVICE_ATTR_RO(mm_stat);
|
|
ZRAM_ATTR_RO(num_reads);
|
|
ZRAM_ATTR_RO(num_reads);
|
|
ZRAM_ATTR_RO(num_writes);
|
|
ZRAM_ATTR_RO(num_writes);
|
|
ZRAM_ATTR_RO(failed_reads);
|
|
ZRAM_ATTR_RO(failed_reads);
|
|
@@ -1080,6 +1110,7 @@ static struct attribute *zram_disk_attrs[] = {
|
|
&dev_attr_max_comp_streams.attr,
|
|
&dev_attr_max_comp_streams.attr,
|
|
&dev_attr_comp_algorithm.attr,
|
|
&dev_attr_comp_algorithm.attr,
|
|
&dev_attr_io_stat.attr,
|
|
&dev_attr_io_stat.attr,
|
|
|
|
+ &dev_attr_mm_stat.attr,
|
|
NULL,
|
|
NULL,
|
|
};
|
|
};
|
|
|
|
|