diff options
author | Lars Ellenberg <lars.ellenberg@linbit.com> | 2014-05-06 09:05:23 -0400 |
---|---|---|
committer | Philipp Reisner <philipp.reisner@linbit.com> | 2014-07-10 12:35:19 -0400 |
commit | b44e1184fc3158821a74c870f777a39e4aac2ce5 (patch) | |
tree | a839d29f8598bd8f3c58eaea0daa007b7c4ab6b7 | |
parent | 54e6fc38e888a54b016e1e04e1eceea78ddf7ace (diff) |
drbd: debugfs: add version tag to debugfs files
Make the first line of debugfs files a version number,
starting now with "v: 0".
If we change content of presentation, we will bump that.
Monitoring or diagnostic scritps that may parse these files
can then easily know when they need to be reviewed.
Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
-rw-r--r-- | drivers/block/drbd/drbd_debugfs.c | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/drivers/block/drbd/drbd_debugfs.c b/drivers/block/drbd/drbd_debugfs.c index 45b52056f88d..a4d0666a5931 100644 --- a/drivers/block/drbd/drbd_debugfs.c +++ b/drivers/block/drbd/drbd_debugfs.c | |||
@@ -11,7 +11,13 @@ | |||
11 | #include "drbd_req.h" | 11 | #include "drbd_req.h" |
12 | #include "drbd_debugfs.h" | 12 | #include "drbd_debugfs.h" |
13 | 13 | ||
14 | |||
15 | /********************************************************************** | ||
16 | * Whenever you change the file format, remember to bump the version. * | ||
17 | **********************************************************************/ | ||
18 | |||
14 | static struct dentry *drbd_debugfs_root; | 19 | static struct dentry *drbd_debugfs_root; |
20 | static struct dentry *drbd_debugfs_version; | ||
15 | static struct dentry *drbd_debugfs_resources; | 21 | static struct dentry *drbd_debugfs_resources; |
16 | static struct dentry *drbd_debugfs_minors; | 22 | static struct dentry *drbd_debugfs_minors; |
17 | 23 | ||
@@ -368,6 +374,9 @@ static int in_flight_summary_show(struct seq_file *m, void *pos) | |||
368 | if (!connection || !kref_get_unless_zero(&connection->kref)) | 374 | if (!connection || !kref_get_unless_zero(&connection->kref)) |
369 | return -ESTALE; | 375 | return -ESTALE; |
370 | 376 | ||
377 | /* BUMP me if you change the file format/content/presentation */ | ||
378 | seq_printf(m, "v: %u\n\n", 0); | ||
379 | |||
371 | seq_puts(m, "oldest bitmap IO\n"); | 380 | seq_puts(m, "oldest bitmap IO\n"); |
372 | seq_print_resource_pending_bitmap_io(m, resource, jif); | 381 | seq_print_resource_pending_bitmap_io(m, resource, jif); |
373 | seq_putc(m, '\n'); | 382 | seq_putc(m, '\n'); |
@@ -562,6 +571,9 @@ static int callback_history_show(struct seq_file *m, void *ignored) | |||
562 | struct drbd_connection *connection = m->private; | 571 | struct drbd_connection *connection = m->private; |
563 | unsigned long jif = jiffies; | 572 | unsigned long jif = jiffies; |
564 | 573 | ||
574 | /* BUMP me if you change the file format/content/presentation */ | ||
575 | seq_printf(m, "v: %u\n\n", 0); | ||
576 | |||
565 | seq_puts(m, "n\tage\tcallsite\tfn\n"); | 577 | seq_puts(m, "n\tage\tcallsite\tfn\n"); |
566 | seq_print_timing_details(m, "worker", connection->w_cb_nr, connection->w_timing_details, jif); | 578 | seq_print_timing_details(m, "worker", connection->w_cb_nr, connection->w_timing_details, jif); |
567 | seq_print_timing_details(m, "receiver", connection->r_cb_nr, connection->r_timing_details, jif); | 579 | seq_print_timing_details(m, "receiver", connection->r_cb_nr, connection->r_timing_details, jif); |
@@ -686,6 +698,10 @@ static void resync_dump_detail(struct seq_file *m, struct lc_element *e) | |||
686 | static int device_resync_extents_show(struct seq_file *m, void *ignored) | 698 | static int device_resync_extents_show(struct seq_file *m, void *ignored) |
687 | { | 699 | { |
688 | struct drbd_device *device = m->private; | 700 | struct drbd_device *device = m->private; |
701 | |||
702 | /* BUMP me if you change the file format/content/presentation */ | ||
703 | seq_printf(m, "v: %u\n\n", 0); | ||
704 | |||
689 | if (get_ldev_if_state(device, D_FAILED)) { | 705 | if (get_ldev_if_state(device, D_FAILED)) { |
690 | lc_seq_printf_stats(m, device->resync); | 706 | lc_seq_printf_stats(m, device->resync); |
691 | lc_seq_dump_details(m, device->resync, "rs_left flags", resync_dump_detail); | 707 | lc_seq_dump_details(m, device->resync, "rs_left flags", resync_dump_detail); |
@@ -697,6 +713,10 @@ static int device_resync_extents_show(struct seq_file *m, void *ignored) | |||
697 | static int device_act_log_extents_show(struct seq_file *m, void *ignored) | 713 | static int device_act_log_extents_show(struct seq_file *m, void *ignored) |
698 | { | 714 | { |
699 | struct drbd_device *device = m->private; | 715 | struct drbd_device *device = m->private; |
716 | |||
717 | /* BUMP me if you change the file format/content/presentation */ | ||
718 | seq_printf(m, "v: %u\n\n", 0); | ||
719 | |||
700 | if (get_ldev_if_state(device, D_FAILED)) { | 720 | if (get_ldev_if_state(device, D_FAILED)) { |
701 | lc_seq_printf_stats(m, device->act_log); | 721 | lc_seq_printf_stats(m, device->act_log); |
702 | lc_seq_dump_details(m, device->act_log, "", NULL); | 722 | lc_seq_dump_details(m, device->act_log, "", NULL); |
@@ -713,6 +733,9 @@ static int device_oldest_requests_show(struct seq_file *m, void *ignored) | |||
713 | struct drbd_request *r1, *r2; | 733 | struct drbd_request *r1, *r2; |
714 | int i; | 734 | int i; |
715 | 735 | ||
736 | /* BUMP me if you change the file format/content/presentation */ | ||
737 | seq_printf(m, "v: %u\n\n", 0); | ||
738 | |||
716 | seq_puts(m, RQ_HDR); | 739 | seq_puts(m, RQ_HDR); |
717 | spin_lock_irq(&resource->req_lock); | 740 | spin_lock_irq(&resource->req_lock); |
718 | /* WRITE, then READ */ | 741 | /* WRITE, then READ */ |
@@ -839,12 +862,36 @@ void drbd_debugfs_peer_device_cleanup(struct drbd_peer_device *peer_device) | |||
839 | drbd_debugfs_remove(&peer_device->debugfs_peer_dev); | 862 | drbd_debugfs_remove(&peer_device->debugfs_peer_dev); |
840 | } | 863 | } |
841 | 864 | ||
865 | static int drbd_version_show(struct seq_file *m, void *ignored) | ||
866 | { | ||
867 | seq_printf(m, "# %s\n", drbd_buildtag()); | ||
868 | seq_printf(m, "VERSION=%s\n", REL_VERSION); | ||
869 | seq_printf(m, "API_VERSION=%u\n", API_VERSION); | ||
870 | seq_printf(m, "PRO_VERSION_MIN=%u\n", PRO_VERSION_MIN); | ||
871 | seq_printf(m, "PRO_VERSION_MAX=%u\n", PRO_VERSION_MAX); | ||
872 | return 0; | ||
873 | } | ||
874 | |||
875 | static int drbd_version_open(struct inode *inode, struct file *file) | ||
876 | { | ||
877 | return single_open(file, drbd_version_show, NULL); | ||
878 | } | ||
879 | |||
880 | static struct file_operations drbd_version_fops = { | ||
881 | .owner = THIS_MODULE, | ||
882 | .open = drbd_version_open, | ||
883 | .llseek = seq_lseek, | ||
884 | .read = seq_read, | ||
885 | .release = single_release, | ||
886 | }; | ||
887 | |||
842 | /* not __exit, may be indirectly called | 888 | /* not __exit, may be indirectly called |
843 | * from the module-load-failure path as well. */ | 889 | * from the module-load-failure path as well. */ |
844 | void drbd_debugfs_cleanup(void) | 890 | void drbd_debugfs_cleanup(void) |
845 | { | 891 | { |
846 | drbd_debugfs_remove(&drbd_debugfs_resources); | 892 | drbd_debugfs_remove(&drbd_debugfs_resources); |
847 | drbd_debugfs_remove(&drbd_debugfs_minors); | 893 | drbd_debugfs_remove(&drbd_debugfs_minors); |
894 | drbd_debugfs_remove(&drbd_debugfs_version); | ||
848 | drbd_debugfs_remove(&drbd_debugfs_root); | 895 | drbd_debugfs_remove(&drbd_debugfs_root); |
849 | } | 896 | } |
850 | 897 | ||
@@ -857,6 +904,11 @@ int __init drbd_debugfs_init(void) | |||
857 | goto fail; | 904 | goto fail; |
858 | drbd_debugfs_root = dentry; | 905 | drbd_debugfs_root = dentry; |
859 | 906 | ||
907 | dentry = debugfs_create_file("version", 0444, drbd_debugfs_root, NULL, &drbd_version_fops); | ||
908 | if (IS_ERR_OR_NULL(dentry)) | ||
909 | goto fail; | ||
910 | drbd_debugfs_version = dentry; | ||
911 | |||
860 | dentry = debugfs_create_dir("resources", drbd_debugfs_root); | 912 | dentry = debugfs_create_dir("resources", drbd_debugfs_root); |
861 | if (IS_ERR_OR_NULL(dentry)) | 913 | if (IS_ERR_OR_NULL(dentry)) |
862 | goto fail; | 914 | goto fail; |