diff options
author | Len Brown <len.brown@intel.com> | 2006-07-10 10:39:41 +0400 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2006-07-10 10:39:41 +0400 |
commit | 0f12b15ebcedce115a5d8e5ff741e49a7993f67c (patch) | |
tree | 3bfea88873b2a43c5528b9687fa010b6eff23458 /drivers/acpi/namespace/nsalloc.c | |
parent | 20b499aa06edf59fa2d21f29d42d36586c6c058e (diff) | |
parent | f6dd9221dddb3550e60d32aee688588ec208312c (diff) | |
download | linux-0f12b15ebcedce115a5d8e5ff741e49a7993f67c.tar.xz |
Pull acpica-20060707 into test branch
Diffstat (limited to 'drivers/acpi/namespace/nsalloc.c')
-rw-r--r-- | drivers/acpi/namespace/nsalloc.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/drivers/acpi/namespace/nsalloc.c b/drivers/acpi/namespace/nsalloc.c index dc3f0739a46b..55b407aae266 100644 --- a/drivers/acpi/namespace/nsalloc.c +++ b/drivers/acpi/namespace/nsalloc.c @@ -386,14 +386,17 @@ void acpi_ns_delete_namespace_subtree(struct acpi_namespace_node *parent_node) * specific ID. Used to delete entire ACPI tables. All * reference counts are updated. * + * MUTEX: Locks namespace during deletion walk. + * ******************************************************************************/ void acpi_ns_delete_namespace_by_owner(acpi_owner_id owner_id) { struct acpi_namespace_node *child_node; struct acpi_namespace_node *deletion_node; - u32 level; struct acpi_namespace_node *parent_node; + u32 level; + acpi_status status; ACPI_FUNCTION_TRACE_U32(ns_delete_namespace_by_owner, owner_id); @@ -401,6 +404,13 @@ void acpi_ns_delete_namespace_by_owner(acpi_owner_id owner_id) return_VOID; } + /* Lock namespace for possible update */ + + status = acpi_ut_acquire_mutex(ACPI_MTX_NAMESPACE); + if (ACPI_FAILURE(status)) { + return_VOID; + } + deletion_node = NULL; parent_node = acpi_gbl_root_node; child_node = NULL; @@ -469,5 +479,6 @@ void acpi_ns_delete_namespace_by_owner(acpi_owner_id owner_id) } } + (void)acpi_ut_release_mutex(ACPI_MTX_NAMESPACE); return_VOID; } |