aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/acpi/events/evrgnini.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/acpi/events/evrgnini.c')
-rw-r--r--drivers/acpi/events/evrgnini.c315
1 files changed, 155 insertions, 160 deletions
diff --git a/drivers/acpi/events/evrgnini.c b/drivers/acpi/events/evrgnini.c
index 95bc09c73a6a..a1bd2da27c45 100644
--- a/drivers/acpi/events/evrgnini.c
+++ b/drivers/acpi/events/evrgnini.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/acevents.h> 45#include <acpi/acevents.h>
47#include <acpi/acnamesp.h> 46#include <acpi/acnamesp.h>
48 47
49#define _COMPONENT ACPI_EVENTS 48#define _COMPONENT ACPI_EVENTS
50 ACPI_MODULE_NAME ("evrgnini") 49ACPI_MODULE_NAME("evrgnini")
51
52 50
53/******************************************************************************* 51/*******************************************************************************
54 * 52 *
@@ -64,34 +62,31 @@
64 * DESCRIPTION: Setup a system_memory operation region 62 * DESCRIPTION: Setup a system_memory operation region
65 * 63 *
66 ******************************************************************************/ 64 ******************************************************************************/
67
68acpi_status 65acpi_status
69acpi_ev_system_memory_region_setup ( 66acpi_ev_system_memory_region_setup(acpi_handle handle,
70 acpi_handle handle, 67 u32 function,
71 u32 function, 68 void *handler_context, void **region_context)
72 void *handler_context,
73 void **region_context)
74{ 69{
75 union acpi_operand_object *region_desc = (union acpi_operand_object *) handle; 70 union acpi_operand_object *region_desc =
76 struct acpi_mem_space_context *local_region_context; 71 (union acpi_operand_object *)handle;
77 72 struct acpi_mem_space_context *local_region_context;
78
79 ACPI_FUNCTION_TRACE ("ev_system_memory_region_setup");
80 73
74 ACPI_FUNCTION_TRACE("ev_system_memory_region_setup");
81 75
82 if (function == ACPI_REGION_DEACTIVATE) { 76 if (function == ACPI_REGION_DEACTIVATE) {
83 if (*region_context) { 77 if (*region_context) {
84 ACPI_MEM_FREE (*region_context); 78 ACPI_MEM_FREE(*region_context);
85 *region_context = NULL; 79 *region_context = NULL;
86 } 80 }
87 return_ACPI_STATUS (AE_OK); 81 return_ACPI_STATUS(AE_OK);
88 } 82 }
89 83
90 /* Create a new context */ 84 /* Create a new context */
91 85
92 local_region_context = ACPI_MEM_CALLOCATE (sizeof (struct acpi_mem_space_context)); 86 local_region_context =
87 ACPI_MEM_CALLOCATE(sizeof(struct acpi_mem_space_context));
93 if (!(local_region_context)) { 88 if (!(local_region_context)) {
94 return_ACPI_STATUS (AE_NO_MEMORY); 89 return_ACPI_STATUS(AE_NO_MEMORY);
95 } 90 }
96 91
97 /* Save the region length and address for use in the handler */ 92 /* Save the region length and address for use in the handler */
@@ -100,10 +95,9 @@ acpi_ev_system_memory_region_setup (
100 local_region_context->address = region_desc->region.address; 95 local_region_context->address = region_desc->region.address;
101 96
102 *region_context = local_region_context; 97 *region_context = local_region_context;
103 return_ACPI_STATUS (AE_OK); 98 return_ACPI_STATUS(AE_OK);
104} 99}
105 100
106
107/******************************************************************************* 101/*******************************************************************************
108 * 102 *
109 * FUNCTION: acpi_ev_io_space_region_setup 103 * FUNCTION: acpi_ev_io_space_region_setup
@@ -120,26 +114,21 @@ acpi_ev_system_memory_region_setup (
120 ******************************************************************************/ 114 ******************************************************************************/
121 115
122acpi_status 116acpi_status
123acpi_ev_io_space_region_setup ( 117acpi_ev_io_space_region_setup(acpi_handle handle,
124 acpi_handle handle, 118 u32 function,
125 u32 function, 119 void *handler_context, void **region_context)
126 void *handler_context,
127 void **region_context)
128{ 120{
129 ACPI_FUNCTION_TRACE ("ev_io_space_region_setup"); 121 ACPI_FUNCTION_TRACE("ev_io_space_region_setup");
130
131 122
132 if (function == ACPI_REGION_DEACTIVATE) { 123 if (function == ACPI_REGION_DEACTIVATE) {
133 *region_context = NULL; 124 *region_context = NULL;
134 } 125 } else {
135 else {
136 *region_context = handler_context; 126 *region_context = handler_context;
137 } 127 }
138 128
139 return_ACPI_STATUS (AE_OK); 129 return_ACPI_STATUS(AE_OK);
140} 130}
141 131
142
143/******************************************************************************* 132/*******************************************************************************
144 * 133 *
145 * FUNCTION: acpi_ev_pci_config_region_setup 134 * FUNCTION: acpi_ev_pci_config_region_setup
@@ -158,24 +147,21 @@ acpi_ev_io_space_region_setup (
158 ******************************************************************************/ 147 ******************************************************************************/
159 148
160acpi_status 149acpi_status
161acpi_ev_pci_config_region_setup ( 150acpi_ev_pci_config_region_setup(acpi_handle handle,
162 acpi_handle handle, 151 u32 function,
163 u32 function, 152 void *handler_context, void **region_context)
164 void *handler_context,
165 void **region_context)
166{ 153{
167 acpi_status status = AE_OK; 154 acpi_status status = AE_OK;
168 acpi_integer pci_value; 155 acpi_integer pci_value;
169 struct acpi_pci_id *pci_id = *region_context; 156 struct acpi_pci_id *pci_id = *region_context;
170 union acpi_operand_object *handler_obj; 157 union acpi_operand_object *handler_obj;
171 struct acpi_namespace_node *parent_node; 158 struct acpi_namespace_node *parent_node;
172 struct acpi_namespace_node *pci_root_node; 159 struct acpi_namespace_node *pci_root_node;
173 union acpi_operand_object *region_obj = (union acpi_operand_object *) handle; 160 union acpi_operand_object *region_obj =
174 struct acpi_device_id object_hID; 161 (union acpi_operand_object *)handle;
175 162 struct acpi_device_id object_hID;
176 163
177 ACPI_FUNCTION_TRACE ("ev_pci_config_region_setup"); 164 ACPI_FUNCTION_TRACE("ev_pci_config_region_setup");
178
179 165
180 handler_obj = region_obj->region.handler; 166 handler_obj = region_obj->region.handler;
181 if (!handler_obj) { 167 if (!handler_obj) {
@@ -183,20 +169,21 @@ acpi_ev_pci_config_region_setup (
183 * No installed handler. This shouldn't happen because the dispatch 169 * No installed handler. This shouldn't happen because the dispatch
184 * routine checks before we get here, but we check again just in case. 170 * routine checks before we get here, but we check again just in case.
185 */ 171 */
186 ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION, 172 ACPI_DEBUG_PRINT((ACPI_DB_OPREGION,
187 "Attempting to init a region %p, with no handler\n", region_obj)); 173 "Attempting to init a region %p, with no handler\n",
188 return_ACPI_STATUS (AE_NOT_EXIST); 174 region_obj));
175 return_ACPI_STATUS(AE_NOT_EXIST);
189 } 176 }
190 177
191 *region_context = NULL; 178 *region_context = NULL;
192 if (function == ACPI_REGION_DEACTIVATE) { 179 if (function == ACPI_REGION_DEACTIVATE) {
193 if (pci_id) { 180 if (pci_id) {
194 ACPI_MEM_FREE (pci_id); 181 ACPI_MEM_FREE(pci_id);
195 } 182 }
196 return_ACPI_STATUS (status); 183 return_ACPI_STATUS(status);
197 } 184 }
198 185
199 parent_node = acpi_ns_get_parent_node (region_obj->region.node); 186 parent_node = acpi_ns_get_parent_node(region_obj->region.node);
200 187
201 /* 188 /*
202 * Get the _SEG and _BBN values from the device upon which the handler 189 * Get the _SEG and _BBN values from the device upon which the handler
@@ -216,18 +203,28 @@ acpi_ev_pci_config_region_setup (
216 203
217 pci_root_node = parent_node; 204 pci_root_node = parent_node;
218 while (pci_root_node != acpi_gbl_root_node) { 205 while (pci_root_node != acpi_gbl_root_node) {
219 status = acpi_ut_execute_HID (pci_root_node, &object_hID); 206 status =
220 if (ACPI_SUCCESS (status)) { 207 acpi_ut_execute_HID(pci_root_node, &object_hID);
221 /* Got a valid _HID, check if this is a PCI root */ 208 if (ACPI_SUCCESS(status)) {
222 209 /*
223 if (!(ACPI_STRNCMP (object_hID.value, PCI_ROOT_HID_STRING, 210 * Got a valid _HID string, check if this is a PCI root.
224 sizeof (PCI_ROOT_HID_STRING)))) { 211 * New for ACPI 3.0: check for a PCI Express root also.
212 */
213 if (!
214 (ACPI_STRNCMP
215 (object_hID.value, PCI_ROOT_HID_STRING,
216 sizeof(PCI_ROOT_HID_STRING))
217 ||
218 !(ACPI_STRNCMP
219 (object_hID.value,
220 PCI_EXPRESS_ROOT_HID_STRING,
221 sizeof(PCI_EXPRESS_ROOT_HID_STRING)))))
222 {
225 /* Install a handler for this PCI root bridge */ 223 /* Install a handler for this PCI root bridge */
226 224
227 status = acpi_install_address_space_handler ((acpi_handle) pci_root_node, 225 status =
228 ACPI_ADR_SPACE_PCI_CONFIG, 226 acpi_install_address_space_handler((acpi_handle) pci_root_node, ACPI_ADR_SPACE_PCI_CONFIG, ACPI_DEFAULT_HANDLER, NULL, NULL);
229 ACPI_DEFAULT_HANDLER, NULL, NULL); 227 if (ACPI_FAILURE(status)) {
230 if (ACPI_FAILURE (status)) {
231 if (status == AE_SAME_HANDLER) { 228 if (status == AE_SAME_HANDLER) {
232 /* 229 /*
233 * It is OK if the handler is already installed on the root 230 * It is OK if the handler is already installed on the root
@@ -235,23 +232,19 @@ acpi_ev_pci_config_region_setup (
235 * new PCI_Config operation region, however. 232 * new PCI_Config operation region, however.
236 */ 233 */
237 status = AE_OK; 234 status = AE_OK;
238 } 235 } else {
239 else { 236 ACPI_REPORT_ERROR(("Could not install pci_config handler for Root Bridge %4.4s, %s\n", acpi_ut_get_node_name(pci_root_node), acpi_format_exception(status)));
240 ACPI_REPORT_ERROR ((
241 "Could not install pci_config handler for Root Bridge %4.4s, %s\n",
242 acpi_ut_get_node_name (pci_root_node), acpi_format_exception (status)));
243 } 237 }
244 } 238 }
245 break; 239 break;
246 } 240 }
247 } 241 }
248 242
249 pci_root_node = acpi_ns_get_parent_node (pci_root_node); 243 pci_root_node = acpi_ns_get_parent_node(pci_root_node);
250 } 244 }
251 245
252 /* PCI root bridge not found, use namespace root node */ 246 /* PCI root bridge not found, use namespace root node */
253 } 247 } else {
254 else {
255 pci_root_node = handler_obj->address_space.node; 248 pci_root_node = handler_obj->address_space.node;
256 } 249 }
257 250
@@ -260,14 +253,14 @@ acpi_ev_pci_config_region_setup (
260 * (install_address_space_handler could have initialized it) 253 * (install_address_space_handler could have initialized it)
261 */ 254 */
262 if (region_obj->region.flags & AOPOBJ_SETUP_COMPLETE) { 255 if (region_obj->region.flags & AOPOBJ_SETUP_COMPLETE) {
263 return_ACPI_STATUS (AE_OK); 256 return_ACPI_STATUS(AE_OK);
264 } 257 }
265 258
266 /* Region is still not initialized. Create a new context */ 259 /* Region is still not initialized. Create a new context */
267 260
268 pci_id = ACPI_MEM_CALLOCATE (sizeof (struct acpi_pci_id)); 261 pci_id = ACPI_MEM_CALLOCATE(sizeof(struct acpi_pci_id));
269 if (!pci_id) { 262 if (!pci_id) {
270 return_ACPI_STATUS (AE_NO_MEMORY); 263 return_ACPI_STATUS(AE_NO_MEMORY);
271 } 264 }
272 265
273 /* 266 /*
@@ -279,40 +272,45 @@ acpi_ev_pci_config_region_setup (
279 * Get the PCI device and function numbers from the _ADR object 272 * Get the PCI device and function numbers from the _ADR object
280 * contained in the parent's scope. 273 * contained in the parent's scope.
281 */ 274 */
282 status = acpi_ut_evaluate_numeric_object (METHOD_NAME__ADR, parent_node, &pci_value); 275 status =
276 acpi_ut_evaluate_numeric_object(METHOD_NAME__ADR, parent_node,
277 &pci_value);
283 278
284 /* 279 /*
285 * The default is zero, and since the allocation above zeroed 280 * The default is zero, and since the allocation above zeroed
286 * the data, just do nothing on failure. 281 * the data, just do nothing on failure.
287 */ 282 */
288 if (ACPI_SUCCESS (status)) { 283 if (ACPI_SUCCESS(status)) {
289 pci_id->device = ACPI_HIWORD (ACPI_LODWORD (pci_value)); 284 pci_id->device = ACPI_HIWORD(ACPI_LODWORD(pci_value));
290 pci_id->function = ACPI_LOWORD (ACPI_LODWORD (pci_value)); 285 pci_id->function = ACPI_LOWORD(ACPI_LODWORD(pci_value));
291 } 286 }
292 287
293 /* The PCI segment number comes from the _SEG method */ 288 /* The PCI segment number comes from the _SEG method */
294 289
295 status = acpi_ut_evaluate_numeric_object (METHOD_NAME__SEG, pci_root_node, &pci_value); 290 status =
296 if (ACPI_SUCCESS (status)) { 291 acpi_ut_evaluate_numeric_object(METHOD_NAME__SEG, pci_root_node,
297 pci_id->segment = ACPI_LOWORD (pci_value); 292 &pci_value);
293 if (ACPI_SUCCESS(status)) {
294 pci_id->segment = ACPI_LOWORD(pci_value);
298 } 295 }
299 296
300 /* The PCI bus number comes from the _BBN method */ 297 /* The PCI bus number comes from the _BBN method */
301 298
302 status = acpi_ut_evaluate_numeric_object (METHOD_NAME__BBN, pci_root_node, &pci_value); 299 status =
303 if (ACPI_SUCCESS (status)) { 300 acpi_ut_evaluate_numeric_object(METHOD_NAME__BBN, pci_root_node,
304 pci_id->bus = ACPI_LOWORD (pci_value); 301 &pci_value);
302 if (ACPI_SUCCESS(status)) {
303 pci_id->bus = ACPI_LOWORD(pci_value);
305 } 304 }
306 305
307 /* Complete this device's pci_id */ 306 /* Complete this device's pci_id */
308 307
309 acpi_os_derive_pci_id (pci_root_node, region_obj->region.node, &pci_id); 308 acpi_os_derive_pci_id(pci_root_node, region_obj->region.node, &pci_id);
310 309
311 *region_context = pci_id; 310 *region_context = pci_id;
312 return_ACPI_STATUS (AE_OK); 311 return_ACPI_STATUS(AE_OK);
313} 312}
314 313
315
316/******************************************************************************* 314/*******************************************************************************
317 * 315 *
318 * FUNCTION: acpi_ev_pci_bar_region_setup 316 * FUNCTION: acpi_ev_pci_bar_region_setup
@@ -331,19 +329,15 @@ acpi_ev_pci_config_region_setup (
331 ******************************************************************************/ 329 ******************************************************************************/
332 330
333acpi_status 331acpi_status
334acpi_ev_pci_bar_region_setup ( 332acpi_ev_pci_bar_region_setup(acpi_handle handle,
335 acpi_handle handle, 333 u32 function,
336 u32 function, 334 void *handler_context, void **region_context)
337 void *handler_context,
338 void **region_context)
339{ 335{
340 ACPI_FUNCTION_TRACE ("ev_pci_bar_region_setup"); 336 ACPI_FUNCTION_TRACE("ev_pci_bar_region_setup");
341
342 337
343 return_ACPI_STATUS (AE_OK); 338 return_ACPI_STATUS(AE_OK);
344} 339}
345 340
346
347/******************************************************************************* 341/*******************************************************************************
348 * 342 *
349 * FUNCTION: acpi_ev_cmos_region_setup 343 * FUNCTION: acpi_ev_cmos_region_setup
@@ -362,19 +356,15 @@ acpi_ev_pci_bar_region_setup (
362 ******************************************************************************/ 356 ******************************************************************************/
363 357
364acpi_status 358acpi_status
365acpi_ev_cmos_region_setup ( 359acpi_ev_cmos_region_setup(acpi_handle handle,
366 acpi_handle handle, 360 u32 function,
367 u32 function, 361 void *handler_context, void **region_context)
368 void *handler_context,
369 void **region_context)
370{ 362{
371 ACPI_FUNCTION_TRACE ("ev_cmos_region_setup"); 363 ACPI_FUNCTION_TRACE("ev_cmos_region_setup");
372
373 364
374 return_ACPI_STATUS (AE_OK); 365 return_ACPI_STATUS(AE_OK);
375} 366}
376 367
377
378/******************************************************************************* 368/*******************************************************************************
379 * 369 *
380 * FUNCTION: acpi_ev_default_region_setup 370 * FUNCTION: acpi_ev_default_region_setup
@@ -391,26 +381,21 @@ acpi_ev_cmos_region_setup (
391 ******************************************************************************/ 381 ******************************************************************************/
392 382
393acpi_status 383acpi_status
394acpi_ev_default_region_setup ( 384acpi_ev_default_region_setup(acpi_handle handle,
395 acpi_handle handle, 385 u32 function,
396 u32 function, 386 void *handler_context, void **region_context)
397 void *handler_context,
398 void **region_context)
399{ 387{
400 ACPI_FUNCTION_TRACE ("ev_default_region_setup"); 388 ACPI_FUNCTION_TRACE("ev_default_region_setup");
401
402 389
403 if (function == ACPI_REGION_DEACTIVATE) { 390 if (function == ACPI_REGION_DEACTIVATE) {
404 *region_context = NULL; 391 *region_context = NULL;
405 } 392 } else {
406 else {
407 *region_context = handler_context; 393 *region_context = handler_context;
408 } 394 }
409 395
410 return_ACPI_STATUS (AE_OK); 396 return_ACPI_STATUS(AE_OK);
411} 397}
412 398
413
414/******************************************************************************* 399/*******************************************************************************
415 * 400 *
416 * FUNCTION: acpi_ev_initialize_region 401 * FUNCTION: acpi_ev_initialize_region
@@ -434,37 +419,34 @@ acpi_ev_default_region_setup (
434 ******************************************************************************/ 419 ******************************************************************************/
435 420
436acpi_status 421acpi_status
437acpi_ev_initialize_region ( 422acpi_ev_initialize_region(union acpi_operand_object *region_obj,
438 union acpi_operand_object *region_obj, 423 u8 acpi_ns_locked)
439 u8 acpi_ns_locked)
440{ 424{
441 union acpi_operand_object *handler_obj; 425 union acpi_operand_object *handler_obj;
442 union acpi_operand_object *obj_desc; 426 union acpi_operand_object *obj_desc;
443 acpi_adr_space_type space_id; 427 acpi_adr_space_type space_id;
444 struct acpi_namespace_node *node; 428 struct acpi_namespace_node *node;
445 acpi_status status; 429 acpi_status status;
446 struct acpi_namespace_node *method_node; 430 struct acpi_namespace_node *method_node;
447 acpi_name *reg_name_ptr = (acpi_name *) METHOD_NAME__REG; 431 acpi_name *reg_name_ptr = (acpi_name *) METHOD_NAME__REG;
448 union acpi_operand_object *region_obj2; 432 union acpi_operand_object *region_obj2;
449
450
451 ACPI_FUNCTION_TRACE_U32 ("ev_initialize_region", acpi_ns_locked);
452 433
434 ACPI_FUNCTION_TRACE_U32("ev_initialize_region", acpi_ns_locked);
453 435
454 if (!region_obj) { 436 if (!region_obj) {
455 return_ACPI_STATUS (AE_BAD_PARAMETER); 437 return_ACPI_STATUS(AE_BAD_PARAMETER);
456 } 438 }
457 439
458 if (region_obj->common.flags & AOPOBJ_OBJECT_INITIALIZED) { 440 if (region_obj->common.flags & AOPOBJ_OBJECT_INITIALIZED) {
459 return_ACPI_STATUS (AE_OK); 441 return_ACPI_STATUS(AE_OK);
460 } 442 }
461 443
462 region_obj2 = acpi_ns_get_secondary_object (region_obj); 444 region_obj2 = acpi_ns_get_secondary_object(region_obj);
463 if (!region_obj2) { 445 if (!region_obj2) {
464 return_ACPI_STATUS (AE_NOT_EXIST); 446 return_ACPI_STATUS(AE_NOT_EXIST);
465 } 447 }
466 448
467 node = acpi_ns_get_parent_node (region_obj->region.node); 449 node = acpi_ns_get_parent_node(region_obj->region.node);
468 space_id = region_obj->region.space_id; 450 space_id = region_obj->region.space_id;
469 451
470 /* Setup defaults */ 452 /* Setup defaults */
@@ -476,9 +458,9 @@ acpi_ev_initialize_region (
476 458
477 /* Find any "_REG" method associated with this region definition */ 459 /* Find any "_REG" method associated with this region definition */
478 460
479 status = acpi_ns_search_node (*reg_name_ptr, node, 461 status = acpi_ns_search_node(*reg_name_ptr, node,
480 ACPI_TYPE_METHOD, &method_node); 462 ACPI_TYPE_METHOD, &method_node);
481 if (ACPI_SUCCESS (status)) { 463 if (ACPI_SUCCESS(status)) {
482 /* 464 /*
483 * The _REG method is optional and there can be only one per region 465 * The _REG method is optional and there can be only one per region
484 * definition. This will be executed when the handler is attached 466 * definition. This will be executed when the handler is attached
@@ -495,7 +477,7 @@ acpi_ev_initialize_region (
495 /* Check to see if a handler exists */ 477 /* Check to see if a handler exists */
496 478
497 handler_obj = NULL; 479 handler_obj = NULL;
498 obj_desc = acpi_ns_get_attached_object (node); 480 obj_desc = acpi_ns_get_attached_object(node);
499 if (obj_desc) { 481 if (obj_desc) {
500 /* Can only be a handler if the object exists */ 482 /* Can only be a handler if the object exists */
501 483
@@ -523,37 +505,50 @@ acpi_ev_initialize_region (
523 while (handler_obj) { 505 while (handler_obj) {
524 /* Is this handler of the correct type? */ 506 /* Is this handler of the correct type? */
525 507
526 if (handler_obj->address_space.space_id == space_id) { 508 if (handler_obj->address_space.space_id ==
509 space_id) {
527 /* Found correct handler */ 510 /* Found correct handler */
528 511
529 ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION, 512 ACPI_DEBUG_PRINT((ACPI_DB_OPREGION,
530 "Found handler %p for region %p in obj %p\n", 513 "Found handler %p for region %p in obj %p\n",
531 handler_obj, region_obj, obj_desc)); 514 handler_obj,
515 region_obj,
516 obj_desc));
532 517
533 status = acpi_ev_attach_region (handler_obj, region_obj, 518 status =
534 acpi_ns_locked); 519 acpi_ev_attach_region(handler_obj,
520 region_obj,
521 acpi_ns_locked);
535 522
536 /* 523 /*
537 * Tell all users that this region is usable by running the _REG 524 * Tell all users that this region is usable by running the _REG
538 * method 525 * method
539 */ 526 */
540 if (acpi_ns_locked) { 527 if (acpi_ns_locked) {
541 status = acpi_ut_release_mutex (ACPI_MTX_NAMESPACE); 528 status =
542 if (ACPI_FAILURE (status)) { 529 acpi_ut_release_mutex
543 return_ACPI_STATUS (status); 530 (ACPI_MTX_NAMESPACE);
531 if (ACPI_FAILURE(status)) {
532 return_ACPI_STATUS
533 (status);
544 } 534 }
545 } 535 }
546 536
547 status = acpi_ev_execute_reg_method (region_obj, 1); 537 status =
538 acpi_ev_execute_reg_method
539 (region_obj, 1);
548 540
549 if (acpi_ns_locked) { 541 if (acpi_ns_locked) {
550 status = acpi_ut_acquire_mutex (ACPI_MTX_NAMESPACE); 542 status =
551 if (ACPI_FAILURE (status)) { 543 acpi_ut_acquire_mutex
552 return_ACPI_STATUS (status); 544 (ACPI_MTX_NAMESPACE);
545 if (ACPI_FAILURE(status)) {
546 return_ACPI_STATUS
547 (status);
553 } 548 }
554 } 549 }
555 550
556 return_ACPI_STATUS (AE_OK); 551 return_ACPI_STATUS(AE_OK);
557 } 552 }
558 553
559 /* Try next handler in the list */ 554 /* Try next handler in the list */
@@ -566,15 +561,15 @@ acpi_ev_initialize_region (
566 * This node does not have the handler we need; 561 * This node does not have the handler we need;
567 * Pop up one level 562 * Pop up one level
568 */ 563 */
569 node = acpi_ns_get_parent_node (node); 564 node = acpi_ns_get_parent_node(node);
570 } 565 }
571 566
572 /* If we get here, there is no handler for this region */ 567 /* If we get here, there is no handler for this region */
573 568
574 ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION, 569 ACPI_DEBUG_PRINT((ACPI_DB_OPREGION,
575 "No handler for region_type %s(%X) (region_obj %p)\n", 570 "No handler for region_type %s(%X) (region_obj %p)\n",
576 acpi_ut_get_region_name (space_id), space_id, region_obj)); 571 acpi_ut_get_region_name(space_id), space_id,
572 region_obj));
577 573
578 return_ACPI_STATUS (AE_NOT_EXIST); 574 return_ACPI_STATUS(AE_NOT_EXIST);
579} 575}
580