1 // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
2 /******************************************************************************
4 * Module Name: dswscope - Scope stack manipulation
6 * Copyright (C) 2000 - 2019, Intel Corp.
8 *****************************************************************************/
10 #include <acpi/acpi.h>
14 #define _COMPONENT ACPI_DISPATCHER
15 ACPI_MODULE_NAME("dswscope")
17 /****************************************************************************
19 * FUNCTION: acpi_ds_scope_stack_clear
21 * PARAMETERS: walk_state - Current state
25 * DESCRIPTION: Pop (and free) everything on the scope stack except the
26 * root scope object (which remains at the stack top.)
28 ***************************************************************************/
29 void acpi_ds_scope_stack_clear(struct acpi_walk_state
*walk_state
)
31 union acpi_generic_state
*scope_info
;
33 ACPI_FUNCTION_NAME(ds_scope_stack_clear
);
35 while (walk_state
->scope_info
) {
37 /* Pop a scope off the stack */
39 scope_info
= walk_state
->scope_info
;
40 walk_state
->scope_info
= scope_info
->scope
.next
;
42 ACPI_DEBUG_PRINT((ACPI_DB_EXEC
,
43 "Popped object type (%s)\n",
44 acpi_ut_get_type_name(scope_info
->common
.
47 acpi_ut_delete_generic_state(scope_info
);
51 /****************************************************************************
53 * FUNCTION: acpi_ds_scope_stack_push
55 * PARAMETERS: node - Name to be made current
56 * type - Type of frame being pushed
57 * walk_state - Current state
61 * DESCRIPTION: Push the current scope on the scope stack, and make the
62 * passed Node current.
64 ***************************************************************************/
67 acpi_ds_scope_stack_push(struct acpi_namespace_node
*node
,
68 acpi_object_type type
,
69 struct acpi_walk_state
*walk_state
)
71 union acpi_generic_state
*scope_info
;
72 union acpi_generic_state
*old_scope_info
;
74 ACPI_FUNCTION_TRACE(ds_scope_stack_push
);
80 ACPI_ERROR((AE_INFO
, "Null scope parameter"));
81 return_ACPI_STATUS(AE_BAD_PARAMETER
);
84 /* Make sure object type is valid */
86 if (!acpi_ut_valid_object_type(type
)) {
87 ACPI_WARNING((AE_INFO
, "Invalid object type: 0x%X", type
));
90 /* Allocate a new scope object */
92 scope_info
= acpi_ut_create_generic_state();
94 return_ACPI_STATUS(AE_NO_MEMORY
);
97 /* Init new scope object */
99 scope_info
->common
.descriptor_type
= ACPI_DESC_TYPE_STATE_WSCOPE
;
100 scope_info
->scope
.node
= node
;
101 scope_info
->common
.value
= (u16
) type
;
103 walk_state
->scope_depth
++;
105 ACPI_DEBUG_PRINT((ACPI_DB_EXEC
,
106 "[%.2d] Pushed scope ",
107 (u32
) walk_state
->scope_depth
));
109 old_scope_info
= walk_state
->scope_info
;
110 if (old_scope_info
) {
111 ACPI_DEBUG_PRINT_RAW((ACPI_DB_EXEC
,
113 acpi_ut_get_node_name(old_scope_info
->
115 acpi_ut_get_type_name(old_scope_info
->
118 ACPI_DEBUG_PRINT_RAW((ACPI_DB_EXEC
, ACPI_NAMESPACE_ROOT
));
121 ACPI_DEBUG_PRINT_RAW((ACPI_DB_EXEC
,
122 ", New scope -> [%4.4s] (%s)\n",
123 acpi_ut_get_node_name(scope_info
->scope
.node
),
124 acpi_ut_get_type_name(scope_info
->common
.value
)));
126 /* Push new scope object onto stack */
128 acpi_ut_push_generic_state(&walk_state
->scope_info
, scope_info
);
129 return_ACPI_STATUS(AE_OK
);
132 /****************************************************************************
134 * FUNCTION: acpi_ds_scope_stack_pop
136 * PARAMETERS: walk_state - Current state
140 * DESCRIPTION: Pop the scope stack once.
142 ***************************************************************************/
144 acpi_status
acpi_ds_scope_stack_pop(struct acpi_walk_state
*walk_state
)
146 union acpi_generic_state
*scope_info
;
147 union acpi_generic_state
*new_scope_info
;
149 ACPI_FUNCTION_TRACE(ds_scope_stack_pop
);
152 * Pop scope info object off the stack.
154 scope_info
= acpi_ut_pop_generic_state(&walk_state
->scope_info
);
156 return_ACPI_STATUS(AE_STACK_UNDERFLOW
);
159 walk_state
->scope_depth
--;
161 ACPI_DEBUG_PRINT((ACPI_DB_EXEC
,
162 "[%.2d] Popped scope [%4.4s] (%s), New scope -> ",
163 (u32
) walk_state
->scope_depth
,
164 acpi_ut_get_node_name(scope_info
->scope
.node
),
165 acpi_ut_get_type_name(scope_info
->common
.value
)));
167 new_scope_info
= walk_state
->scope_info
;
168 if (new_scope_info
) {
169 ACPI_DEBUG_PRINT_RAW((ACPI_DB_EXEC
, "[%4.4s] (%s)\n",
170 acpi_ut_get_node_name(new_scope_info
->
172 acpi_ut_get_type_name(new_scope_info
->
175 ACPI_DEBUG_PRINT_RAW((ACPI_DB_EXEC
, "%s\n",
176 ACPI_NAMESPACE_ROOT
));
179 acpi_ut_delete_generic_state(scope_info
);
180 return_ACPI_STATUS(AE_OK
);