diff --git a/storage/dump_storage.cpp b/storage/dump_storage.cpp
index d40d963..2367d4c 100644
--- a/storage/dump_storage.cpp
+++ b/storage/dump_storage.cpp
@@ -67,11 +67,31 @@ int main() {
int mnt_time = android::base::GetIntProperty(F2FS_MNT_TIME_PROPERTY, 0);
printf("--- F2FS - checkpoint=disable time (ms) ---\n%d\n\n", mnt_time);
+ const std::string f2fs_proc_path("/proc/fs/f2fs/");
+ std::unique_ptr
procdir(
+ opendir(f2fs_proc_path.c_str()), closedir);
+ if (procdir) {
+ dirent *proc_entry;
+ while ((proc_entry = readdir(procdir.get())) != nullptr) {
+ std::string proc_name(proc_entry->d_name);
+ if (proc_name == "." || proc_name == ".." ||
+ strncmp(proc_name.c_str(), "dm-", 3))
+ continue;
+ dumpFileContent(("F2FS - " + proc_name).c_str(),
+ (f2fs_proc_path + proc_name + "/disk_map").c_str());
+ }
+ }
+
//UFS
dumpFileContent("UFS model", "/sys/block/sda/device/model");
dumpFileContent("UFS rev", "/sys/block/sda/device/rev");
dumpFileContent("UFS size", "/sys/block/sda/size");
+ dumpFileContent("UFS phy version",
+ "/dev/sys/block/bootdevice/pixel/phy_version");
+ dumpFileContent("UFS phy release_date",
+ "/dev/sys/block/bootdevice/pixel/phy_release_date");
+
dumpFileContent("UFS Slow IO Read",
"/dev/sys/block/bootdevice/slowio_read_cnt");
dumpFileContent("UFS Slow IO Write",
diff --git a/storage/sepolicy/dump_storage.te b/storage/sepolicy/dump_storage.te
index 7a5f563..67c4b9a 100644
--- a/storage/sepolicy/dump_storage.te
+++ b/storage/sepolicy/dump_storage.te
@@ -4,6 +4,10 @@ pixel_bugreport(dump_storage)
# adb bugreport
allow dump_storage sysfs_scsi_devices_0000:dir r_dir_perms;
allow dump_storage sysfs_scsi_devices_0000:file r_file_perms;
+allow dump_storage sysfs:file r_file_perms;
+
+allow dump_storage proc_f2fs:dir r_dir_perms;
+allow dump_storage proc_f2fs:file r_file_perms;
# adb bugreport
userdebug_or_eng(`