Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 | // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0 /******************************************************************************* * * Module Name: dbfileio - Debugger file I/O commands. These can't usually * be used when running the debugger in Ring 0 (Kernel mode) * ******************************************************************************/ #include <acpi/acpi.h> #include "accommon.h" #include "acdebug.h" #include "actables.h" #define _COMPONENT ACPI_CA_DEBUGGER ACPI_MODULE_NAME("dbfileio") #ifdef ACPI_APPLICATION #include "acapps.h" #ifdef ACPI_DEBUGGER /******************************************************************************* * * FUNCTION: acpi_db_close_debug_file * * PARAMETERS: None * * RETURN: None * * DESCRIPTION: If open, close the current debug output file * ******************************************************************************/ void acpi_db_close_debug_file(void) { if (acpi_gbl_debug_file) { fclose(acpi_gbl_debug_file); acpi_gbl_debug_file = NULL; acpi_gbl_db_output_to_file = FALSE; acpi_os_printf("Debug output file %s closed\n", acpi_gbl_db_debug_filename); } } /******************************************************************************* * * FUNCTION: acpi_db_open_debug_file * * PARAMETERS: name - Filename to open * * RETURN: None * * DESCRIPTION: Open a file where debug output will be directed. * ******************************************************************************/ void acpi_db_open_debug_file(char *name) { acpi_db_close_debug_file(); acpi_gbl_debug_file = fopen(name, "w+"); if (!acpi_gbl_debug_file) { acpi_os_printf("Could not open debug file %s\n", name); return; } acpi_os_printf("Debug output file %s opened\n", name); acpi_ut_safe_strncpy(acpi_gbl_db_debug_filename, name, sizeof(acpi_gbl_db_debug_filename)); acpi_gbl_db_output_to_file = TRUE; } #endif /******************************************************************************* * * FUNCTION: acpi_db_load_tables * * PARAMETERS: list_head - List of ACPI tables to load * * RETURN: Status * * DESCRIPTION: Load ACPI tables from a previously constructed table list. * ******************************************************************************/ acpi_status acpi_db_load_tables(struct acpi_new_table_desc *list_head) { acpi_status status; struct acpi_new_table_desc *table_list_head; struct acpi_table_header *table; /* Load all ACPI tables in the list */ table_list_head = list_head; while (table_list_head) { table = table_list_head->table; status = acpi_load_table(table, NULL); if (ACPI_FAILURE(status)) { if (status == AE_ALREADY_EXISTS) { acpi_os_printf ("Table %4.4s is already installed\n", table->signature); } else { acpi_os_printf("Could not install table, %s\n", acpi_format_exception(status)); } return (status); } acpi_os_printf ("Acpi table [%4.4s] successfully installed and loaded\n", table->signature); table_list_head = table_list_head->next; } return (AE_OK); } #endif |