diff options
| -rw-r--r-- | drivers/acpi/glue.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/drivers/acpi/glue.c b/drivers/acpi/glue.c index eda0978b57c6..06f8634fe58b 100644 --- a/drivers/acpi/glue.c +++ b/drivers/acpi/glue.c | |||
| @@ -142,6 +142,7 @@ EXPORT_SYMBOL(acpi_get_physical_device); | |||
| 142 | 142 | ||
| 143 | static int acpi_bind_one(struct device *dev, acpi_handle handle) | 143 | static int acpi_bind_one(struct device *dev, acpi_handle handle) |
| 144 | { | 144 | { |
| 145 | struct acpi_device *acpi_dev; | ||
| 145 | acpi_status status; | 146 | acpi_status status; |
| 146 | 147 | ||
| 147 | if (dev->archdata.acpi_handle) { | 148 | if (dev->archdata.acpi_handle) { |
| @@ -157,6 +158,16 @@ static int acpi_bind_one(struct device *dev, acpi_handle handle) | |||
| 157 | } | 158 | } |
| 158 | dev->archdata.acpi_handle = handle; | 159 | dev->archdata.acpi_handle = handle; |
| 159 | 160 | ||
| 161 | status = acpi_bus_get_device(handle, &acpi_dev); | ||
| 162 | if (!ACPI_FAILURE(status)) { | ||
| 163 | int ret; | ||
| 164 | |||
| 165 | ret = sysfs_create_link(&dev->kobj, &acpi_dev->dev.kobj, | ||
| 166 | "firmware_node"); | ||
| 167 | ret = sysfs_create_link(&acpi_dev->dev.kobj, &dev->kobj, | ||
| 168 | "physical_node"); | ||
| 169 | } | ||
| 170 | |||
| 160 | return 0; | 171 | return 0; |
| 161 | } | 172 | } |
| 162 | 173 | ||
| @@ -165,8 +176,17 @@ static int acpi_unbind_one(struct device *dev) | |||
| 165 | if (!dev->archdata.acpi_handle) | 176 | if (!dev->archdata.acpi_handle) |
| 166 | return 0; | 177 | return 0; |
| 167 | if (dev == acpi_get_physical_device(dev->archdata.acpi_handle)) { | 178 | if (dev == acpi_get_physical_device(dev->archdata.acpi_handle)) { |
| 179 | struct acpi_device *acpi_dev; | ||
| 180 | |||
| 168 | /* acpi_get_physical_device increase refcnt by one */ | 181 | /* acpi_get_physical_device increase refcnt by one */ |
| 169 | put_device(dev); | 182 | put_device(dev); |
| 183 | |||
| 184 | if (!acpi_bus_get_device(dev->archdata.acpi_handle, | ||
| 185 | &acpi_dev)) { | ||
| 186 | sysfs_remove_link(&dev->kobj, "firmware_node"); | ||
| 187 | sysfs_remove_link(&acpi_dev->dev.kobj, "physical_node"); | ||
| 188 | } | ||
| 189 | |||
| 170 | acpi_detach_data(dev->archdata.acpi_handle, | 190 | acpi_detach_data(dev->archdata.acpi_handle, |
| 171 | acpi_glue_data_handler); | 191 | acpi_glue_data_handler); |
| 172 | dev->archdata.acpi_handle = NULL; | 192 | dev->archdata.acpi_handle = NULL; |
