Commit 0a727dea authored by Antonino A. Daplas's avatar Antonino A. Daplas Committed by Linus Torvalds

[PATCH] fbcon: Honor the return value of device_create_file

Check the return value of device_create_file().  If return is 'fail', remove
attributes by calling device_remove_file().
Signed-off-by: default avatarAntonino Daplas <adaplas@pol.net>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 1a6600be
...@@ -133,6 +133,7 @@ static int info_idx = -1; ...@@ -133,6 +133,7 @@ static int info_idx = -1;
/* console rotation */ /* console rotation */
static int rotate; static int rotate;
static int fbcon_has_sysfs;
static const struct consw fb_con; static const struct consw fb_con;
...@@ -3166,11 +3167,26 @@ static struct class_device_attribute class_device_attrs[] = { ...@@ -3166,11 +3167,26 @@ static struct class_device_attribute class_device_attrs[] = {
static int fbcon_init_class_device(void) static int fbcon_init_class_device(void)
{ {
int i; int i, error = 0;
fbcon_has_sysfs = 1;
for (i = 0; i < ARRAY_SIZE(class_device_attrs); i++) {
error = class_device_create_file(fbcon_class_device,
&class_device_attrs[i]);
if (error)
break;
}
if (error) {
while (--i >= 0)
class_device_remove_file(fbcon_class_device,
&class_device_attrs[i]);
fbcon_has_sysfs = 0;
}
for (i = 0; i < ARRAY_SIZE(class_device_attrs); i++)
class_device_create_file(fbcon_class_device,
&class_device_attrs[i]);
return 0; return 0;
} }
...@@ -3279,9 +3295,13 @@ static void __exit fbcon_deinit_class_device(void) ...@@ -3279,9 +3295,13 @@ static void __exit fbcon_deinit_class_device(void)
{ {
int i; int i;
for (i = 0; i < ARRAY_SIZE(class_device_attrs); i++) if (fbcon_has_sysfs) {
class_device_remove_file(fbcon_class_device, for (i = 0; i < ARRAY_SIZE(class_device_attrs); i++)
&class_device_attrs[i]); class_device_remove_file(fbcon_class_device,
&class_device_attrs[i]);
fbcon_has_sysfs = 0;
}
} }
static void __exit fb_console_exit(void) static void __exit fb_console_exit(void)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment