diff options
| author | Dmitry Torokhov <dtor@insightbb.com> | 2007-05-08 01:31:11 -0400 |
|---|---|---|
| committer | Dmitry Torokhov <dtor@insightbb.com> | 2007-05-08 01:31:11 -0400 |
| commit | 334d0dd8b660557608142f0f77abc6812b48f08b (patch) | |
| tree | 9393a9aa099d7d42deda5f9f5054796c0c769be7 /drivers/base/platform.c | |
| parent | 3f07d8796262f6aee135c8dd9a91210da9f888e4 (diff) | |
| parent | 5b94f675f57e4ff16c8fda09088d7480a84dcd91 (diff) | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
Diffstat (limited to 'drivers/base/platform.c')
| -rw-r--r-- | drivers/base/platform.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/drivers/base/platform.c b/drivers/base/platform.c index 30480f6f2af2..17b5ece8f82c 100644 --- a/drivers/base/platform.c +++ b/drivers/base/platform.c | |||
| @@ -292,20 +292,22 @@ EXPORT_SYMBOL_GPL(platform_device_add); | |||
| 292 | * @pdev: platform device we're removing | 292 | * @pdev: platform device we're removing |
| 293 | * | 293 | * |
| 294 | * Note that this function will also release all memory- and port-based | 294 | * Note that this function will also release all memory- and port-based |
| 295 | * resources owned by the device (@dev->resource). | 295 | * resources owned by the device (@dev->resource). This function |
| 296 | * must _only_ be externally called in error cases. All other usage | ||
| 297 | * is a bug. | ||
| 296 | */ | 298 | */ |
| 297 | void platform_device_del(struct platform_device *pdev) | 299 | void platform_device_del(struct platform_device *pdev) |
| 298 | { | 300 | { |
| 299 | int i; | 301 | int i; |
| 300 | 302 | ||
| 301 | if (pdev) { | 303 | if (pdev) { |
| 304 | device_del(&pdev->dev); | ||
| 305 | |||
| 302 | for (i = 0; i < pdev->num_resources; i++) { | 306 | for (i = 0; i < pdev->num_resources; i++) { |
| 303 | struct resource *r = &pdev->resource[i]; | 307 | struct resource *r = &pdev->resource[i]; |
| 304 | if (r->flags & (IORESOURCE_MEM|IORESOURCE_IO)) | 308 | if (r->flags & (IORESOURCE_MEM|IORESOURCE_IO)) |
| 305 | release_resource(r); | 309 | release_resource(r); |
| 306 | } | 310 | } |
| 307 | |||
| 308 | device_del(&pdev->dev); | ||
| 309 | } | 311 | } |
| 310 | } | 312 | } |
| 311 | EXPORT_SYMBOL_GPL(platform_device_del); | 313 | EXPORT_SYMBOL_GPL(platform_device_del); |
