1 /* SPDX-License-Identifier: GPL-2.0 */
2
3 #ifndef __842_DEBUGFS_H__
4 #define __842_DEBUGFS_H__
5
6 #include <linux/debugfs.h>
7
8 static bool sw842_template_counts;
9 module_param_named(template_counts, sw842_template_counts, bool, 0444);
10
11 static atomic_t template_count[OPS_MAX], template_repeat_count,
12 template_zeros_count, template_short_data_count, template_end_count;
13
14 static struct dentry *sw842_debugfs_root;
15
sw842_debugfs_create(void)16 static int __init sw842_debugfs_create(void)
17 {
18 umode_t m = S_IRUGO | S_IWUSR;
19 int i;
20
21 if (!debugfs_initialized())
22 return -ENODEV;
23
24 sw842_debugfs_root = debugfs_create_dir(MODULE_NAME, NULL);
25 if (IS_ERR(sw842_debugfs_root))
26 return PTR_ERR(sw842_debugfs_root);
27
28 for (i = 0; i < ARRAY_SIZE(template_count); i++) {
29 char name[32];
30
31 snprintf(name, 32, "template_%02x", i);
32 debugfs_create_atomic_t(name, m, sw842_debugfs_root,
33 &template_count[i]);
34 }
35 debugfs_create_atomic_t("template_repeat", m, sw842_debugfs_root,
36 &template_repeat_count);
37 debugfs_create_atomic_t("template_zeros", m, sw842_debugfs_root,
38 &template_zeros_count);
39 debugfs_create_atomic_t("template_short_data", m, sw842_debugfs_root,
40 &template_short_data_count);
41 debugfs_create_atomic_t("template_end", m, sw842_debugfs_root,
42 &template_end_count);
43
44 return 0;
45 }
46
sw842_debugfs_remove(void)47 static void __exit sw842_debugfs_remove(void)
48 {
49 if (sw842_debugfs_root && !IS_ERR(sw842_debugfs_root))
50 debugfs_remove_recursive(sw842_debugfs_root);
51 }
52
53 #endif
54