xref: /linux/drivers/acpi/acpica/acapps.h (revision b2d0f5d5dc53532e6f07bc546a476a55ebdfe0f3)
1 /******************************************************************************
2  *
3  * Module Name: acapps - common include for ACPI applications/tools
4  *
5  *****************************************************************************/
6 
7 /*
8  * Copyright (C) 2000 - 2017, Intel Corp.
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions, and the following disclaimer,
16  *    without modification.
17  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18  *    substantially similar to the "NO WARRANTY" disclaimer below
19  *    ("Disclaimer") and any redistribution must be conditioned upon
20  *    including a substantially similar Disclaimer requirement for further
21  *    binary redistribution.
22  * 3. Neither the names of the above-listed copyright holders nor the names
23  *    of any contributors may be used to endorse or promote products derived
24  *    from this software without specific prior written permission.
25  *
26  * Alternatively, this software may be distributed under the terms of the
27  * GNU General Public License ("GPL") version 2 as published by the Free
28  * Software Foundation.
29  *
30  * NO WARRANTY
31  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41  * POSSIBILITY OF SUCH DAMAGES.
42  */
43 
44 #ifndef _ACAPPS
45 #define _ACAPPS
46 
47 #ifdef ACPI_USE_STANDARD_HEADERS
48 #include <sys/stat.h>
49 #endif				/* ACPI_USE_STANDARD_HEADERS */
50 
51 /* Common info for tool signons */
52 
53 #define ACPICA_NAME                 "Intel ACPI Component Architecture"
54 #define ACPICA_COPYRIGHT            "Copyright (c) 2000 - 2017 Intel Corporation"
55 
56 #if ACPI_MACHINE_WIDTH == 64
57 #define ACPI_WIDTH          " (64-bit version)"
58 
59 #elif ACPI_MACHINE_WIDTH == 32
60 #define ACPI_WIDTH          " (32-bit version)"
61 
62 #else
63 #error unknown ACPI_MACHINE_WIDTH
64 #define ACPI_WIDTH          " (unknown bit width, not 32 or 64)"
65 
66 #endif
67 
68 /* Macros for signons and file headers */
69 
70 #define ACPI_COMMON_SIGNON(utility_name) \
71 	"\n%s\n%s version %8.8X\n%s\n\n", \
72 	ACPICA_NAME, \
73 	utility_name, ((u32) ACPI_CA_VERSION), \
74 	ACPICA_COPYRIGHT
75 
76 #define ACPI_COMMON_HEADER(utility_name, prefix) \
77 	"%s%s\n%s%s version %8.8X%s\n%s%s\n%s\n", \
78 	prefix, ACPICA_NAME, \
79 	prefix, utility_name, ((u32) ACPI_CA_VERSION), ACPI_WIDTH, \
80 	prefix, ACPICA_COPYRIGHT, \
81 	prefix
82 
83 /* Macros for usage messages */
84 
85 #define ACPI_USAGE_HEADER(usage) \
86 	printf ("Usage: %s\nOptions:\n", usage);
87 
88 #define ACPI_USAGE_TEXT(description) \
89 	printf (description);
90 
91 #define ACPI_OPTION(name, description) \
92 	printf ("  %-20s%s\n", name, description);
93 
94 /* Check for unexpected exceptions */
95 
96 #define ACPI_CHECK_STATUS(name, status, expected) \
97 	if (status != expected) \
98 	{ \
99 		acpi_os_printf ("Unexpected %s from %s (%s-%d)\n", \
100 			acpi_format_exception (status), #name, _acpi_module_name, __LINE__); \
101 	}
102 
103 /* Check for unexpected non-AE_OK errors */
104 
105 #define ACPI_CHECK_OK(name, status)   ACPI_CHECK_STATUS (name, status, AE_OK);
106 
107 #define FILE_SUFFIX_DISASSEMBLY     "dsl"
108 #define FILE_SUFFIX_BINARY_TABLE    ".dat"	/* Needs the dot */
109 
110 /* acfileio */
111 
112 acpi_status
113 ac_get_all_tables_from_file(char *filename,
114 			    u8 get_only_aml_tables,
115 			    struct acpi_new_table_desc **return_list_head);
116 
117 void ac_delete_table_list(struct acpi_new_table_desc *list_head);
118 
119 u8 ac_is_file_binary(FILE * file);
120 
121 acpi_status ac_validate_table_header(FILE * file, long table_offset);
122 
123 /* Values for get_only_aml_tables */
124 
125 #define ACPI_GET_ONLY_AML_TABLES    TRUE
126 #define ACPI_GET_ALL_TABLES         FALSE
127 
128 /*
129  * getopt
130  */
131 int acpi_getopt(int argc, char **argv, char *opts);
132 
133 int acpi_getopt_argument(int argc, char **argv);
134 
135 extern int acpi_gbl_optind;
136 extern int acpi_gbl_opterr;
137 extern int acpi_gbl_sub_opt_char;
138 extern char *acpi_gbl_optarg;
139 
140 /*
141  * cmfsize - Common get file size function
142  */
143 u32 cm_get_file_size(ACPI_FILE file);
144 
145 /*
146  * adwalk
147  */
148 void
149 acpi_dm_cross_reference_namespace(union acpi_parse_object *parse_tree_root,
150 				  struct acpi_namespace_node *namespace_root,
151 				  acpi_owner_id owner_id);
152 
153 void acpi_dm_dump_tree(union acpi_parse_object *origin);
154 
155 void acpi_dm_find_orphan_methods(union acpi_parse_object *origin);
156 
157 void
158 acpi_dm_finish_namespace_load(union acpi_parse_object *parse_tree_root,
159 			      struct acpi_namespace_node *namespace_root,
160 			      acpi_owner_id owner_id);
161 
162 void
163 acpi_dm_convert_parse_objects(union acpi_parse_object *parse_tree_root,
164 			      struct acpi_namespace_node *namespace_root);
165 
166 /*
167  * adfile
168  */
169 acpi_status ad_initialize(void);
170 
171 char *fl_generate_filename(char *input_filename, char *suffix);
172 
173 acpi_status
174 fl_split_input_pathname(char *input_path,
175 			char **out_directory_path, char **out_filename);
176 
177 char *ad_generate_filename(char *prefix, char *table_id);
178 
179 void
180 ad_write_table(struct acpi_table_header *table,
181 	       u32 length, char *table_name, char *oem_table_id);
182 
183 #endif				/* _ACAPPS */
184