Branch data Line data Source code
1 : : // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 2 : : /****************************************************************************** 3 : : * 4 : : * Module Name: pswalk - Parser routines to walk parsed op tree(s) 5 : : * 6 : : * Copyright (C) 2000 - 2020, Intel Corp. 7 : : * 8 : : *****************************************************************************/ 9 : : 10 : : #include <acpi/acpi.h> 11 : : #include "accommon.h" 12 : : #include "acparser.h" 13 : : 14 : : #define _COMPONENT ACPI_PARSER 15 : : ACPI_MODULE_NAME("pswalk") 16 : : 17 : : /******************************************************************************* 18 : : * 19 : : * FUNCTION: acpi_ps_delete_parse_tree 20 : : * 21 : : * PARAMETERS: subtree_root - Root of tree (or subtree) to delete 22 : : * 23 : : * RETURN: None 24 : : * 25 : : * DESCRIPTION: Delete a portion of or an entire parse tree. 26 : : * 27 : : ******************************************************************************/ 28 : : #include "amlcode.h" 29 : 89617 : void acpi_ps_delete_parse_tree(union acpi_parse_object *subtree_root) 30 : : { 31 : 89617 : union acpi_parse_object *op = subtree_root; 32 : 89617 : union acpi_parse_object *next = NULL; 33 : 89617 : union acpi_parse_object *parent = NULL; 34 : 89617 : u32 level = 0; 35 : : 36 : 89617 : ACPI_FUNCTION_TRACE_PTR(ps_delete_parse_tree, subtree_root); 37 : : 38 : 89617 : ACPI_DEBUG_PRINT((ACPI_DB_PARSE_TREES, " root %p\n", subtree_root)); 39 : : 40 : : /* Visit all nodes in the subtree */ 41 : : 42 [ + - ]: 329131 : while (op) { 43 [ + + ]: 329131 : if (op != parent) { 44 : : 45 : : /* This is the descending case */ 46 : : 47 : 259281 : if (ACPI_IS_DEBUG_ENABLED 48 : : (ACPI_LV_PARSE_TREES, _COMPONENT)) { 49 : : 50 : : /* This debug option will print the entire parse tree */ 51 : : 52 : : acpi_os_printf(" %*.s%s %p", (level * 4), 53 : : " ", 54 : : acpi_ps_get_opcode_name(op-> 55 : : common. 56 : : aml_opcode), 57 : : op); 58 : : 59 : : if (op->named.aml_opcode == AML_INT_NAMEPATH_OP) { 60 : : acpi_os_printf(" %4.4s", 61 : : op->common.value.string); 62 : : } 63 : : if (op->named.aml_opcode == AML_STRING_OP) { 64 : : acpi_os_printf(" %s", 65 : : op->common.value.string); 66 : : } 67 : : acpi_os_printf("\n"); 68 : : } 69 : : 70 : : /* Look for an argument or child of the current op */ 71 : : 72 : 259281 : next = acpi_ps_get_arg(op, 0); 73 [ + + ]: 259281 : if (next) { 74 : : 75 : : /* Still going downward in tree (Op is not completed yet) */ 76 : : 77 : 69850 : op = next; 78 : 69850 : level++; 79 : 69850 : continue; 80 : : } 81 : : } 82 : : 83 : : /* No more children, this Op is complete. */ 84 : : 85 : 259281 : next = op->common.next; 86 : 259281 : parent = op->common.parent; 87 : : 88 : 259281 : acpi_ps_free_op(op); 89 : : 90 : : /* If we are back to the starting point, the walk is complete. */ 91 : : 92 [ + + ]: 259281 : if (op == subtree_root) { 93 : : return_VOID; 94 : : } 95 : : 96 [ + + ]: 169664 : if (next) { 97 : : op = next; 98 : : } else { 99 : 69850 : level--; 100 : 69850 : op = parent; 101 : : } 102 : : } 103 : : 104 : : return_VOID; 105 : : }