diff options
Diffstat (limited to 'drivers/acpi/parser/psutils.c')
-rw-r--r-- | drivers/acpi/parser/psutils.c | 105 |
1 files changed, 34 insertions, 71 deletions
diff --git a/drivers/acpi/parser/psutils.c b/drivers/acpi/parser/psutils.c index 4221b41ae1a6..2075efbb4324 100644 --- a/drivers/acpi/parser/psutils.c +++ b/drivers/acpi/parser/psutils.c | |||
@@ -41,14 +41,12 @@ | |||
41 | * POSSIBILITY OF SUCH DAMAGES. | 41 | * POSSIBILITY OF SUCH DAMAGES. |
42 | */ | 42 | */ |
43 | 43 | ||
44 | |||
45 | #include <acpi/acpi.h> | 44 | #include <acpi/acpi.h> |
46 | #include <acpi/acparser.h> | 45 | #include <acpi/acparser.h> |
47 | #include <acpi/amlcode.h> | 46 | #include <acpi/amlcode.h> |
48 | 47 | ||
49 | #define _COMPONENT ACPI_PARSER | 48 | #define _COMPONENT ACPI_PARSER |
50 | ACPI_MODULE_NAME ("psutils") | 49 | ACPI_MODULE_NAME("psutils") |
51 | |||
52 | 50 | ||
53 | /******************************************************************************* | 51 | /******************************************************************************* |
54 | * | 52 | * |
@@ -61,15 +59,11 @@ | |||
61 | * DESCRIPTION: Create a Scope and associated namepath op with the root name | 59 | * DESCRIPTION: Create a Scope and associated namepath op with the root name |
62 | * | 60 | * |
63 | ******************************************************************************/ | 61 | ******************************************************************************/ |
64 | 62 | union acpi_parse_object *acpi_ps_create_scope_op(void) | |
65 | union acpi_parse_object * | ||
66 | acpi_ps_create_scope_op ( | ||
67 | void) | ||
68 | { | 63 | { |
69 | union acpi_parse_object *scope_op; | 64 | union acpi_parse_object *scope_op; |
70 | 65 | ||
71 | 66 | scope_op = acpi_ps_alloc_op(AML_SCOPE_OP); | |
72 | scope_op = acpi_ps_alloc_op (AML_SCOPE_OP); | ||
73 | if (!scope_op) { | 67 | if (!scope_op) { |
74 | return (NULL); | 68 | return (NULL); |
75 | } | 69 | } |
@@ -78,7 +72,6 @@ acpi_ps_create_scope_op ( | |||
78 | return (scope_op); | 72 | return (scope_op); |
79 | } | 73 | } |
80 | 74 | ||
81 | |||
82 | /******************************************************************************* | 75 | /******************************************************************************* |
83 | * | 76 | * |
84 | * FUNCTION: acpi_ps_init_op | 77 | * FUNCTION: acpi_ps_init_op |
@@ -92,23 +85,19 @@ acpi_ps_create_scope_op ( | |||
92 | * | 85 | * |
93 | ******************************************************************************/ | 86 | ******************************************************************************/ |
94 | 87 | ||
95 | void | 88 | void acpi_ps_init_op(union acpi_parse_object *op, u16 opcode) |
96 | acpi_ps_init_op ( | ||
97 | union acpi_parse_object *op, | ||
98 | u16 opcode) | ||
99 | { | 89 | { |
100 | ACPI_FUNCTION_ENTRY (); | 90 | ACPI_FUNCTION_ENTRY(); |
101 | |||
102 | 91 | ||
103 | op->common.data_type = ACPI_DESC_TYPE_PARSER; | 92 | op->common.data_type = ACPI_DESC_TYPE_PARSER; |
104 | op->common.aml_opcode = opcode; | 93 | op->common.aml_opcode = opcode; |
105 | 94 | ||
106 | ACPI_DISASM_ONLY_MEMBERS (ACPI_STRNCPY (op->common.aml_op_name, | 95 | ACPI_DISASM_ONLY_MEMBERS(ACPI_STRNCPY(op->common.aml_op_name, |
107 | (acpi_ps_get_opcode_info (opcode))->name, | 96 | (acpi_ps_get_opcode_info |
108 | sizeof (op->common.aml_op_name))); | 97 | (opcode))->name, |
98 | sizeof(op->common.aml_op_name))); | ||
109 | } | 99 | } |
110 | 100 | ||
111 | |||
112 | /******************************************************************************* | 101 | /******************************************************************************* |
113 | * | 102 | * |
114 | * FUNCTION: acpi_ps_alloc_op | 103 | * FUNCTION: acpi_ps_alloc_op |
@@ -123,29 +112,23 @@ acpi_ps_init_op ( | |||
123 | * | 112 | * |
124 | ******************************************************************************/ | 113 | ******************************************************************************/ |
125 | 114 | ||
126 | union acpi_parse_object* | 115 | union acpi_parse_object *acpi_ps_alloc_op(u16 opcode) |
127 | acpi_ps_alloc_op ( | ||
128 | u16 opcode) | ||
129 | { | 116 | { |
130 | union acpi_parse_object *op; | 117 | union acpi_parse_object *op; |
131 | const struct acpi_opcode_info *op_info; | 118 | const struct acpi_opcode_info *op_info; |
132 | u8 flags = ACPI_PARSEOP_GENERIC; | 119 | u8 flags = ACPI_PARSEOP_GENERIC; |
133 | |||
134 | |||
135 | ACPI_FUNCTION_ENTRY (); | ||
136 | 120 | ||
121 | ACPI_FUNCTION_ENTRY(); | ||
137 | 122 | ||
138 | op_info = acpi_ps_get_opcode_info (opcode); | 123 | op_info = acpi_ps_get_opcode_info(opcode); |
139 | 124 | ||
140 | /* Determine type of parse_op required */ | 125 | /* Determine type of parse_op required */ |
141 | 126 | ||
142 | if (op_info->flags & AML_DEFER) { | 127 | if (op_info->flags & AML_DEFER) { |
143 | flags = ACPI_PARSEOP_DEFERRED; | 128 | flags = ACPI_PARSEOP_DEFERRED; |
144 | } | 129 | } else if (op_info->flags & AML_NAMED) { |
145 | else if (op_info->flags & AML_NAMED) { | ||
146 | flags = ACPI_PARSEOP_NAMED; | 130 | flags = ACPI_PARSEOP_NAMED; |
147 | } | 131 | } else if (opcode == AML_INT_BYTELIST_OP) { |
148 | else if (opcode == AML_INT_BYTELIST_OP) { | ||
149 | flags = ACPI_PARSEOP_BYTELIST; | 132 | flags = ACPI_PARSEOP_BYTELIST; |
150 | } | 133 | } |
151 | 134 | ||
@@ -154,27 +137,25 @@ acpi_ps_alloc_op ( | |||
154 | if (flags == ACPI_PARSEOP_GENERIC) { | 137 | if (flags == ACPI_PARSEOP_GENERIC) { |
155 | /* The generic op (default) is by far the most common (16 to 1) */ | 138 | /* The generic op (default) is by far the most common (16 to 1) */ |
156 | 139 | ||
157 | op = acpi_os_acquire_object (acpi_gbl_ps_node_cache); | 140 | op = acpi_os_acquire_object(acpi_gbl_ps_node_cache); |
158 | memset(op, 0, sizeof(struct acpi_parse_obj_common)); | 141 | memset(op, 0, sizeof(struct acpi_parse_obj_common)); |
159 | } | 142 | } else { |
160 | else { | ||
161 | /* Extended parseop */ | 143 | /* Extended parseop */ |
162 | 144 | ||
163 | op = acpi_os_acquire_object (acpi_gbl_ps_node_ext_cache); | 145 | op = acpi_os_acquire_object(acpi_gbl_ps_node_ext_cache); |
164 | memset(op, 0, sizeof(struct acpi_parse_obj_named)); | 146 | memset(op, 0, sizeof(struct acpi_parse_obj_named)); |
165 | } | 147 | } |
166 | 148 | ||
167 | /* Initialize the Op */ | 149 | /* Initialize the Op */ |
168 | 150 | ||
169 | if (op) { | 151 | if (op) { |
170 | acpi_ps_init_op (op, opcode); | 152 | acpi_ps_init_op(op, opcode); |
171 | op->common.flags = flags; | 153 | op->common.flags = flags; |
172 | } | 154 | } |
173 | 155 | ||
174 | return (op); | 156 | return (op); |
175 | } | 157 | } |
176 | 158 | ||
177 | |||
178 | /******************************************************************************* | 159 | /******************************************************************************* |
179 | * | 160 | * |
180 | * FUNCTION: acpi_ps_free_op | 161 | * FUNCTION: acpi_ps_free_op |
@@ -188,26 +169,22 @@ acpi_ps_alloc_op ( | |||
188 | * | 169 | * |
189 | ******************************************************************************/ | 170 | ******************************************************************************/ |
190 | 171 | ||
191 | void | 172 | void acpi_ps_free_op(union acpi_parse_object *op) |
192 | acpi_ps_free_op ( | ||
193 | union acpi_parse_object *op) | ||
194 | { | 173 | { |
195 | ACPI_FUNCTION_NAME ("ps_free_op"); | 174 | ACPI_FUNCTION_NAME("ps_free_op"); |
196 | |||
197 | 175 | ||
198 | if (op->common.aml_opcode == AML_INT_RETURN_VALUE_OP) { | 176 | if (op->common.aml_opcode == AML_INT_RETURN_VALUE_OP) { |
199 | ACPI_DEBUG_PRINT ((ACPI_DB_ALLOCATIONS, "Free retval op: %p\n", op)); | 177 | ACPI_DEBUG_PRINT((ACPI_DB_ALLOCATIONS, "Free retval op: %p\n", |
178 | op)); | ||
200 | } | 179 | } |
201 | 180 | ||
202 | if (op->common.flags & ACPI_PARSEOP_GENERIC) { | 181 | if (op->common.flags & ACPI_PARSEOP_GENERIC) { |
203 | (void) acpi_os_release_object (acpi_gbl_ps_node_cache, op); | 182 | (void)acpi_os_release_object(acpi_gbl_ps_node_cache, op); |
204 | } | 183 | } else { |
205 | else { | 184 | (void)acpi_os_release_object(acpi_gbl_ps_node_ext_cache, op); |
206 | (void) acpi_os_release_object (acpi_gbl_ps_node_ext_cache, op); | ||
207 | } | 185 | } |
208 | } | 186 | } |
209 | 187 | ||
210 | |||
211 | /******************************************************************************* | 188 | /******************************************************************************* |
212 | * | 189 | * |
213 | * FUNCTION: Utility functions | 190 | * FUNCTION: Utility functions |
@@ -216,36 +193,27 @@ acpi_ps_free_op ( | |||
216 | * | 193 | * |
217 | ******************************************************************************/ | 194 | ******************************************************************************/ |
218 | 195 | ||
219 | |||
220 | /* | 196 | /* |
221 | * Is "c" a namestring lead character? | 197 | * Is "c" a namestring lead character? |
222 | */ | 198 | */ |
223 | u8 | 199 | u8 acpi_ps_is_leading_char(u32 c) |
224 | acpi_ps_is_leading_char ( | ||
225 | u32 c) | ||
226 | { | 200 | { |
227 | return ((u8) (c == '_' || (c >= 'A' && c <= 'Z'))); | 201 | return ((u8) (c == '_' || (c >= 'A' && c <= 'Z'))); |
228 | } | 202 | } |
229 | 203 | ||
230 | |||
231 | /* | 204 | /* |
232 | * Is "c" a namestring prefix character? | 205 | * Is "c" a namestring prefix character? |
233 | */ | 206 | */ |
234 | u8 | 207 | u8 acpi_ps_is_prefix_char(u32 c) |
235 | acpi_ps_is_prefix_char ( | ||
236 | u32 c) | ||
237 | { | 208 | { |
238 | return ((u8) (c == '\\' || c == '^')); | 209 | return ((u8) (c == '\\' || c == '^')); |
239 | } | 210 | } |
240 | 211 | ||
241 | |||
242 | /* | 212 | /* |
243 | * Get op's name (4-byte name segment) or 0 if unnamed | 213 | * Get op's name (4-byte name segment) or 0 if unnamed |
244 | */ | 214 | */ |
245 | #ifdef ACPI_FUTURE_USAGE | 215 | #ifdef ACPI_FUTURE_USAGE |
246 | u32 | 216 | u32 acpi_ps_get_name(union acpi_parse_object * op) |
247 | acpi_ps_get_name ( | ||
248 | union acpi_parse_object *op) | ||
249 | { | 217 | { |
250 | 218 | ||
251 | /* The "generic" object has no name associated with it */ | 219 | /* The "generic" object has no name associated with it */ |
@@ -258,16 +226,12 @@ acpi_ps_get_name ( | |||
258 | 226 | ||
259 | return (op->named.name); | 227 | return (op->named.name); |
260 | } | 228 | } |
261 | #endif /* ACPI_FUTURE_USAGE */ | 229 | #endif /* ACPI_FUTURE_USAGE */ |
262 | |||
263 | 230 | ||
264 | /* | 231 | /* |
265 | * Set op's name | 232 | * Set op's name |
266 | */ | 233 | */ |
267 | void | 234 | void acpi_ps_set_name(union acpi_parse_object *op, u32 name) |
268 | acpi_ps_set_name ( | ||
269 | union acpi_parse_object *op, | ||
270 | u32 name) | ||
271 | { | 235 | { |
272 | 236 | ||
273 | /* The "generic" object has no name associated with it */ | 237 | /* The "generic" object has no name associated with it */ |
@@ -278,4 +242,3 @@ acpi_ps_set_name ( | |||
278 | 242 | ||
279 | op->named.name = name; | 243 | op->named.name = name; |
280 | } | 244 | } |
281 | |||