aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/acpi/ec_sys.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/acpi/ec_sys.c')
-rw-r--r--drivers/acpi/ec_sys.c31
1 files changed, 24 insertions, 7 deletions
diff --git a/drivers/acpi/ec_sys.c b/drivers/acpi/ec_sys.c
index 3ef978185c73..0e869b3f81ca 100644
--- a/drivers/acpi/ec_sys.c
+++ b/drivers/acpi/ec_sys.c
@@ -17,6 +17,11 @@ MODULE_AUTHOR("Thomas Renninger <trenn@suse.de>");
17MODULE_DESCRIPTION("ACPI EC sysfs access driver"); 17MODULE_DESCRIPTION("ACPI EC sysfs access driver");
18MODULE_LICENSE("GPL"); 18MODULE_LICENSE("GPL");
19 19
20static bool write_support;
21module_param(write_support, bool, 0644);
22MODULE_PARM_DESC(write_support, "Dangerous, reboot and removal of battery may "
23 "be needed.");
24
20#define EC_SPACE_SIZE 256 25#define EC_SPACE_SIZE 256
21 26
22struct sysdev_class acpi_ec_sysdev_class = { 27struct sysdev_class acpi_ec_sysdev_class = {
@@ -102,6 +107,8 @@ int acpi_ec_add_debugfs(struct acpi_ec *ec, unsigned int ec_device_count)
102{ 107{
103 struct dentry *dev_dir; 108 struct dentry *dev_dir;
104 char name[64]; 109 char name[64];
110 mode_t mode = 0400;
111
105 if (ec_device_count == 0) { 112 if (ec_device_count == 0) {
106 acpi_ec_debugfs_dir = debugfs_create_dir("ec", NULL); 113 acpi_ec_debugfs_dir = debugfs_create_dir("ec", NULL);
107 if (!acpi_ec_debugfs_dir) 114 if (!acpi_ec_debugfs_dir)
@@ -111,17 +118,27 @@ int acpi_ec_add_debugfs(struct acpi_ec *ec, unsigned int ec_device_count)
111 sprintf(name, "ec%u", ec_device_count); 118 sprintf(name, "ec%u", ec_device_count);
112 dev_dir = debugfs_create_dir(name, acpi_ec_debugfs_dir); 119 dev_dir = debugfs_create_dir(name, acpi_ec_debugfs_dir);
113 if (!dev_dir) { 120 if (!dev_dir) {
114 if (ec_device_count == 0) 121 if (ec_device_count != 0)
115 debugfs_remove_recursive(acpi_ec_debugfs_dir); 122 goto error;
116 /* TBD: Proper cleanup for multiple ECs */
117 return -ENOMEM; 123 return -ENOMEM;
118 } 124 }
119 125
120 debugfs_create_x32("gpe", 0444, dev_dir, (u32 *)&first_ec->gpe); 126 if (!debugfs_create_x32("gpe", 0444, dev_dir, (u32 *)&first_ec->gpe))
121 debugfs_create_bool("use_global_lock", 0444, dev_dir, 127 goto error;
122 (u32 *)&first_ec->global_lock); 128 if (!debugfs_create_bool("use_global_lock", 0444, dev_dir,
123 debugfs_create_file("io", 0666, dev_dir, ec, &acpi_ec_io_ops); 129 (u32 *)&first_ec->global_lock))
130 goto error;
131
132 if (write_support)
133 mode = 0600;
134 if (!debugfs_create_file("io", mode, dev_dir, ec, &acpi_ec_io_ops))
135 goto error;
136
124 return 0; 137 return 0;
138
139error:
140 debugfs_remove_recursive(acpi_ec_debugfs_dir);
141 return -ENOMEM;
125} 142}
126 143
127static int __init acpi_ec_sys_init(void) 144static int __init acpi_ec_sys_init(void)