diff options
author | Bob Moore <robert.moore@intel.com> | 2008-04-10 11:06:39 -0400 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2008-04-22 14:29:26 -0400 |
commit | 9e41d93c975d403380b7debe05517d630c8e2836 (patch) | |
tree | 1f6e7afbca5c54cc16c7e8f88b93f1fccd7ae08a | |
parent | 7f4ac9f91383a0707de559dc8fbca986fc2d302f (diff) |
ACPICA: Fixed a memory leak when Device or Thermal objects referenced in packages
Problem introduced in fix for Package references.
Signed-off-by: Bob Moore <robert.moore@intel.com>
Signed-off-by: Alexey Starikovskiy <astarikovskiy@suse.de>
Signed-off-by: Len Brown <len.brown@intel.com>
-rw-r--r-- | drivers/acpi/dispatcher/dsobject.c | 38 | ||||
-rw-r--r-- | drivers/acpi/utilities/utdelete.c | 8 |
2 files changed, 26 insertions, 20 deletions
diff --git a/drivers/acpi/dispatcher/dsobject.c b/drivers/acpi/dispatcher/dsobject.c index fe28b9aeb65c..7556d919bf8b 100644 --- a/drivers/acpi/dispatcher/dsobject.c +++ b/drivers/acpi/dispatcher/dsobject.c | |||
@@ -172,7 +172,19 @@ acpi_ds_build_internal_object(struct acpi_walk_state *walk_state, | |||
172 | switch (op->common.node->type) { | 172 | switch (op->common.node->type) { |
173 | /* | 173 | /* |
174 | * For these types, we need the actual node, not the subobject. | 174 | * For these types, we need the actual node, not the subobject. |
175 | * However, the subobject got an extra reference count above. | 175 | * However, the subobject did not get an extra reference count above. |
176 | * | ||
177 | * TBD: should ex_resolve_node_to_value be changed to fix this? | ||
178 | */ | ||
179 | case ACPI_TYPE_DEVICE: | ||
180 | case ACPI_TYPE_THERMAL: | ||
181 | |||
182 | acpi_ut_add_reference(op->common.node->object); | ||
183 | |||
184 | /*lint -fallthrough */ | ||
185 | /* | ||
186 | * For these types, we need the actual node, not the subobject. | ||
187 | * The subobject got an extra reference count in ex_resolve_node_to_value. | ||
176 | */ | 188 | */ |
177 | case ACPI_TYPE_MUTEX: | 189 | case ACPI_TYPE_MUTEX: |
178 | case ACPI_TYPE_METHOD: | 190 | case ACPI_TYPE_METHOD: |
@@ -180,25 +192,15 @@ acpi_ds_build_internal_object(struct acpi_walk_state *walk_state, | |||
180 | case ACPI_TYPE_PROCESSOR: | 192 | case ACPI_TYPE_PROCESSOR: |
181 | case ACPI_TYPE_EVENT: | 193 | case ACPI_TYPE_EVENT: |
182 | case ACPI_TYPE_REGION: | 194 | case ACPI_TYPE_REGION: |
183 | case ACPI_TYPE_DEVICE: | ||
184 | case ACPI_TYPE_THERMAL: | ||
185 | 195 | ||
186 | obj_desc = | 196 | /* We will create a reference object for these types below */ |
187 | (union acpi_operand_object *)op->common. | ||
188 | node; | ||
189 | break; | 197 | break; |
190 | 198 | ||
191 | default: | 199 | default: |
192 | break; | 200 | /* |
193 | } | 201 | * All other types - the node was resolved to an actual |
194 | 202 | * object, we are done. | |
195 | /* | 203 | */ |
196 | * If above resolved to an operand object, we are done. Otherwise, | ||
197 | * we have a NS node, we must create the package entry as a named | ||
198 | * reference. | ||
199 | */ | ||
200 | if (ACPI_GET_DESCRIPTOR_TYPE(obj_desc) != | ||
201 | ACPI_DESC_TYPE_NAMED) { | ||
202 | goto exit; | 204 | goto exit; |
203 | } | 205 | } |
204 | } | 206 | } |
@@ -223,7 +225,7 @@ acpi_ds_build_internal_object(struct acpi_walk_state *walk_state, | |||
223 | 225 | ||
224 | exit: | 226 | exit: |
225 | *obj_desc_ptr = obj_desc; | 227 | *obj_desc_ptr = obj_desc; |
226 | return_ACPI_STATUS(AE_OK); | 228 | return_ACPI_STATUS(status); |
227 | } | 229 | } |
228 | 230 | ||
229 | /******************************************************************************* | 231 | /******************************************************************************* |
@@ -743,6 +745,8 @@ acpi_ds_init_object_from_op(struct acpi_walk_state *walk_state, | |||
743 | /* Node was saved in Op */ | 745 | /* Node was saved in Op */ |
744 | 746 | ||
745 | obj_desc->reference.node = op->common.node; | 747 | obj_desc->reference.node = op->common.node; |
748 | obj_desc->reference.object = | ||
749 | op->common.node->object; | ||
746 | } | 750 | } |
747 | 751 | ||
748 | obj_desc->reference.opcode = opcode; | 752 | obj_desc->reference.opcode = opcode; |
diff --git a/drivers/acpi/utilities/utdelete.c b/drivers/acpi/utilities/utdelete.c index dcb34f805714..6a763cd85f8c 100644 --- a/drivers/acpi/utilities/utdelete.c +++ b/drivers/acpi/utilities/utdelete.c | |||
@@ -524,10 +524,12 @@ acpi_ut_update_object_reference(union acpi_operand_object *object, u16 action) | |||
524 | 524 | ||
525 | case ACPI_TYPE_LOCAL_REFERENCE: | 525 | case ACPI_TYPE_LOCAL_REFERENCE: |
526 | /* | 526 | /* |
527 | * The target of an Index (a package, string, or buffer) must track | 527 | * The target of an Index (a package, string, or buffer) or a named |
528 | * changes to the ref count of the index. | 528 | * reference must track changes to the ref count of the index or |
529 | * target object. | ||
529 | */ | 530 | */ |
530 | if (object->reference.opcode == AML_INDEX_OP) { | 531 | if ((object->reference.opcode == AML_INDEX_OP) || |
532 | (object->reference.opcode == AML_INT_NAMEPATH_OP)) { | ||
531 | next_object = object->reference.object; | 533 | next_object = object->reference.object; |
532 | } | 534 | } |
533 | break; | 535 | break; |