diff options
Diffstat (limited to 'drivers/acpi')
-rw-r--r-- | drivers/acpi/dock.c | 81 |
1 files changed, 24 insertions, 57 deletions
diff --git a/drivers/acpi/dock.c b/drivers/acpi/dock.c index 7338b6a3e049..4f2aa98e2cee 100644 --- a/drivers/acpi/dock.c +++ b/drivers/acpi/dock.c | |||
@@ -936,6 +936,19 @@ static ssize_t show_dock_type(struct device *dev, | |||
936 | } | 936 | } |
937 | static DEVICE_ATTR(type, S_IRUGO, show_dock_type, NULL); | 937 | static DEVICE_ATTR(type, S_IRUGO, show_dock_type, NULL); |
938 | 938 | ||
939 | static struct attribute *dock_attributes[] = { | ||
940 | &dev_attr_docked.attr, | ||
941 | &dev_attr_flags.attr, | ||
942 | &dev_attr_undock.attr, | ||
943 | &dev_attr_uid.attr, | ||
944 | &dev_attr_type.attr, | ||
945 | NULL | ||
946 | }; | ||
947 | |||
948 | static struct attribute_group dock_attribute_group = { | ||
949 | .attrs = dock_attributes | ||
950 | }; | ||
951 | |||
939 | /** | 952 | /** |
940 | * dock_add - add a new dock station | 953 | * dock_add - add a new dock station |
941 | * @handle: the dock station handle | 954 | * @handle: the dock station handle |
@@ -969,9 +982,8 @@ static int dock_add(acpi_handle handle) | |||
969 | dock_station_count, NULL, 0); | 982 | dock_station_count, NULL, 0); |
970 | dock_device = dock_station->dock_device; | 983 | dock_device = dock_station->dock_device; |
971 | if (IS_ERR(dock_device)) { | 984 | if (IS_ERR(dock_device)) { |
972 | kfree(dock_station); | 985 | ret = PTR_ERR(dock_device); |
973 | dock_station = NULL; | 986 | goto out; |
974 | return PTR_ERR(dock_device); | ||
975 | } | 987 | } |
976 | platform_device_add_data(dock_device, &dock_station, | 988 | platform_device_add_data(dock_device, &dock_station, |
977 | sizeof(struct dock_station *)); | 989 | sizeof(struct dock_station *)); |
@@ -986,47 +998,9 @@ static int dock_add(acpi_handle handle) | |||
986 | if (is_battery(handle)) | 998 | if (is_battery(handle)) |
987 | dock_station->flags |= DOCK_IS_BAT; | 999 | dock_station->flags |= DOCK_IS_BAT; |
988 | 1000 | ||
989 | ret = device_create_file(&dock_device->dev, &dev_attr_docked); | 1001 | ret = sysfs_create_group(&dock_device->dev.kobj, &dock_attribute_group); |
990 | if (ret) { | ||
991 | printk(KERN_ERR "Error %d adding sysfs file\n", ret); | ||
992 | platform_device_unregister(dock_device); | ||
993 | kfree(dock_station); | ||
994 | dock_station = NULL; | ||
995 | return ret; | ||
996 | } | ||
997 | ret = device_create_file(&dock_device->dev, &dev_attr_undock); | ||
998 | if (ret) { | ||
999 | printk(KERN_ERR "Error %d adding sysfs file\n", ret); | ||
1000 | device_remove_file(&dock_device->dev, &dev_attr_docked); | ||
1001 | platform_device_unregister(dock_device); | ||
1002 | kfree(dock_station); | ||
1003 | dock_station = NULL; | ||
1004 | return ret; | ||
1005 | } | ||
1006 | ret = device_create_file(&dock_device->dev, &dev_attr_uid); | ||
1007 | if (ret) { | ||
1008 | printk(KERN_ERR "Error %d adding sysfs file\n", ret); | ||
1009 | device_remove_file(&dock_device->dev, &dev_attr_docked); | ||
1010 | device_remove_file(&dock_device->dev, &dev_attr_undock); | ||
1011 | platform_device_unregister(dock_device); | ||
1012 | kfree(dock_station); | ||
1013 | dock_station = NULL; | ||
1014 | return ret; | ||
1015 | } | ||
1016 | ret = device_create_file(&dock_device->dev, &dev_attr_flags); | ||
1017 | if (ret) { | ||
1018 | printk(KERN_ERR "Error %d adding sysfs file\n", ret); | ||
1019 | device_remove_file(&dock_device->dev, &dev_attr_docked); | ||
1020 | device_remove_file(&dock_device->dev, &dev_attr_undock); | ||
1021 | device_remove_file(&dock_device->dev, &dev_attr_uid); | ||
1022 | platform_device_unregister(dock_device); | ||
1023 | kfree(dock_station); | ||
1024 | dock_station = NULL; | ||
1025 | return ret; | ||
1026 | } | ||
1027 | ret = device_create_file(&dock_device->dev, &dev_attr_type); | ||
1028 | if (ret) | 1002 | if (ret) |
1029 | printk(KERN_ERR"Error %d adding sysfs file\n", ret); | 1003 | goto err_unregister; |
1030 | 1004 | ||
1031 | /* Find dependent devices */ | 1005 | /* Find dependent devices */ |
1032 | acpi_walk_namespace(ACPI_TYPE_DEVICE, ACPI_ROOT_OBJECT, | 1006 | acpi_walk_namespace(ACPI_TYPE_DEVICE, ACPI_ROOT_OBJECT, |
@@ -1036,10 +1010,8 @@ static int dock_add(acpi_handle handle) | |||
1036 | /* add the dock station as a device dependent on itself */ | 1010 | /* add the dock station as a device dependent on itself */ |
1037 | dd = alloc_dock_dependent_device(handle); | 1011 | dd = alloc_dock_dependent_device(handle); |
1038 | if (!dd) { | 1012 | if (!dd) { |
1039 | kfree(dock_station); | ||
1040 | dock_station = NULL; | ||
1041 | ret = -ENOMEM; | 1013 | ret = -ENOMEM; |
1042 | goto dock_add_err_unregister; | 1014 | goto err_rmgroup; |
1043 | } | 1015 | } |
1044 | add_dock_dependent_device(dock_station, dd); | 1016 | add_dock_dependent_device(dock_station, dd); |
1045 | 1017 | ||
@@ -1047,15 +1019,14 @@ static int dock_add(acpi_handle handle) | |||
1047 | list_add(&dock_station->sibling, &dock_stations); | 1019 | list_add(&dock_station->sibling, &dock_stations); |
1048 | return 0; | 1020 | return 0; |
1049 | 1021 | ||
1050 | dock_add_err_unregister: | 1022 | err_rmgroup: |
1051 | device_remove_file(&dock_device->dev, &dev_attr_type); | 1023 | sysfs_remove_group(&dock_device->dev.kobj, &dock_attribute_group); |
1052 | device_remove_file(&dock_device->dev, &dev_attr_docked); | 1024 | err_unregister: |
1053 | device_remove_file(&dock_device->dev, &dev_attr_undock); | ||
1054 | device_remove_file(&dock_device->dev, &dev_attr_uid); | ||
1055 | device_remove_file(&dock_device->dev, &dev_attr_flags); | ||
1056 | platform_device_unregister(dock_device); | 1025 | platform_device_unregister(dock_device); |
1026 | out: | ||
1057 | kfree(dock_station); | 1027 | kfree(dock_station); |
1058 | dock_station = NULL; | 1028 | dock_station = NULL; |
1029 | printk(KERN_ERR "%s encountered error %d\n", __func__, ret); | ||
1059 | return ret; | 1030 | return ret; |
1060 | } | 1031 | } |
1061 | 1032 | ||
@@ -1076,11 +1047,7 @@ static int dock_remove(struct dock_station *dock_station) | |||
1076 | kfree(dd); | 1047 | kfree(dd); |
1077 | 1048 | ||
1078 | /* cleanup sysfs */ | 1049 | /* cleanup sysfs */ |
1079 | device_remove_file(&dock_device->dev, &dev_attr_type); | 1050 | sysfs_remove_group(&dock_device->dev.kobj, &dock_attribute_group); |
1080 | device_remove_file(&dock_device->dev, &dev_attr_docked); | ||
1081 | device_remove_file(&dock_device->dev, &dev_attr_undock); | ||
1082 | device_remove_file(&dock_device->dev, &dev_attr_uid); | ||
1083 | device_remove_file(&dock_device->dev, &dev_attr_flags); | ||
1084 | platform_device_unregister(dock_device); | 1051 | platform_device_unregister(dock_device); |
1085 | 1052 | ||
1086 | /* free dock station memory */ | 1053 | /* free dock station memory */ |