aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/acpi/acpica/tbxface.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/acpi/acpica/tbxface.c')
-rw-r--r--drivers/acpi/acpica/tbxface.c165
1 files changed, 1 insertions, 164 deletions
diff --git a/drivers/acpi/acpica/tbxface.c b/drivers/acpi/acpica/tbxface.c
index abcc6412c244..472a91ccde95 100644
--- a/drivers/acpi/acpica/tbxface.c
+++ b/drivers/acpi/acpica/tbxface.c
@@ -1,7 +1,6 @@
1/****************************************************************************** 1/******************************************************************************
2 * 2 *
3 * Module Name: tbxface - Public interfaces to the ACPI subsystem 3 * Module Name: tbxface - ACPI table oriented external interfaces
4 * ACPI table oriented interfaces
5 * 4 *
6 *****************************************************************************/ 5 *****************************************************************************/
7 6
@@ -51,11 +50,6 @@
51#define _COMPONENT ACPI_TABLES 50#define _COMPONENT ACPI_TABLES
52ACPI_MODULE_NAME("tbxface") 51ACPI_MODULE_NAME("tbxface")
53 52
54/* Local prototypes */
55static acpi_status acpi_tb_load_namespace(void);
56
57static int no_auto_ssdt;
58
59/******************************************************************************* 53/*******************************************************************************
60 * 54 *
61 * FUNCTION: acpi_allocate_root_table 55 * FUNCTION: acpi_allocate_root_table
@@ -69,7 +63,6 @@ static int no_auto_ssdt;
69 * acpi_initialize_tables. 63 * acpi_initialize_tables.
70 * 64 *
71 ******************************************************************************/ 65 ******************************************************************************/
72
73acpi_status acpi_allocate_root_table(u32 initial_table_count) 66acpi_status acpi_allocate_root_table(u32 initial_table_count)
74{ 67{
75 68
@@ -502,150 +495,6 @@ acpi_get_table_by_index(u32 table_index, struct acpi_table_header **table)
502 495
503ACPI_EXPORT_SYMBOL(acpi_get_table_by_index) 496ACPI_EXPORT_SYMBOL(acpi_get_table_by_index)
504 497
505/*******************************************************************************
506 *
507 * FUNCTION: acpi_tb_load_namespace
508 *
509 * PARAMETERS: None
510 *
511 * RETURN: Status
512 *
513 * DESCRIPTION: Load the namespace from the DSDT and all SSDTs/PSDTs found in
514 * the RSDT/XSDT.
515 *
516 ******************************************************************************/
517static acpi_status acpi_tb_load_namespace(void)
518{
519 acpi_status status;
520 u32 i;
521 struct acpi_table_header *new_dsdt;
522
523 ACPI_FUNCTION_TRACE(tb_load_namespace);
524
525 (void)acpi_ut_acquire_mutex(ACPI_MTX_TABLES);
526
527 /*
528 * Load the namespace. The DSDT is required, but any SSDT and
529 * PSDT tables are optional. Verify the DSDT.
530 */
531 if (!acpi_gbl_root_table_list.current_table_count ||
532 !ACPI_COMPARE_NAME(&
533 (acpi_gbl_root_table_list.
534 tables[ACPI_TABLE_INDEX_DSDT].signature),
535 ACPI_SIG_DSDT)
536 ||
537 ACPI_FAILURE(acpi_tb_verify_table
538 (&acpi_gbl_root_table_list.
539 tables[ACPI_TABLE_INDEX_DSDT]))) {
540 status = AE_NO_ACPI_TABLES;
541 goto unlock_and_exit;
542 }
543
544 /*
545 * Save the DSDT pointer for simple access. This is the mapped memory
546 * address. We must take care here because the address of the .Tables
547 * array can change dynamically as tables are loaded at run-time. Note:
548 * .Pointer field is not validated until after call to acpi_tb_verify_table.
549 */
550 acpi_gbl_DSDT =
551 acpi_gbl_root_table_list.tables[ACPI_TABLE_INDEX_DSDT].pointer;
552
553 /*
554 * Optionally copy the entire DSDT to local memory (instead of simply
555 * mapping it.) There are some BIOSs that corrupt or replace the original
556 * DSDT, creating the need for this option. Default is FALSE, do not copy
557 * the DSDT.
558 */
559 if (acpi_gbl_copy_dsdt_locally) {
560 new_dsdt = acpi_tb_copy_dsdt(ACPI_TABLE_INDEX_DSDT);
561 if (new_dsdt) {
562 acpi_gbl_DSDT = new_dsdt;
563 }
564 }
565
566 /*
567 * Save the original DSDT header for detection of table corruption
568 * and/or replacement of the DSDT from outside the OS.
569 */
570 ACPI_MEMCPY(&acpi_gbl_original_dsdt_header, acpi_gbl_DSDT,
571 sizeof(struct acpi_table_header));
572
573 (void)acpi_ut_release_mutex(ACPI_MTX_TABLES);
574
575 /* Load and parse tables */
576
577 status = acpi_ns_load_table(ACPI_TABLE_INDEX_DSDT, acpi_gbl_root_node);
578 if (ACPI_FAILURE(status)) {
579 return_ACPI_STATUS(status);
580 }
581
582 /* Load any SSDT or PSDT tables. Note: Loop leaves tables locked */
583
584 (void)acpi_ut_acquire_mutex(ACPI_MTX_TABLES);
585 for (i = 0; i < acpi_gbl_root_table_list.current_table_count; ++i) {
586 if ((!ACPI_COMPARE_NAME
587 (&(acpi_gbl_root_table_list.tables[i].signature),
588 ACPI_SIG_SSDT)
589 &&
590 !ACPI_COMPARE_NAME(&
591 (acpi_gbl_root_table_list.tables[i].
592 signature), ACPI_SIG_PSDT))
593 ||
594 ACPI_FAILURE(acpi_tb_verify_table
595 (&acpi_gbl_root_table_list.tables[i]))) {
596 continue;
597 }
598
599 if (no_auto_ssdt) {
600 printk(KERN_WARNING "ACPI: SSDT ignored due to \"acpi_no_auto_ssdt\"\n");
601 continue;
602 }
603
604 /* Ignore errors while loading tables, get as many as possible */
605
606 (void)acpi_ut_release_mutex(ACPI_MTX_TABLES);
607 (void)acpi_ns_load_table(i, acpi_gbl_root_node);
608 (void)acpi_ut_acquire_mutex(ACPI_MTX_TABLES);
609 }
610
611 ACPI_DEBUG_PRINT((ACPI_DB_INIT, "ACPI Tables successfully acquired\n"));
612
613 unlock_and_exit:
614 (void)acpi_ut_release_mutex(ACPI_MTX_TABLES);
615 return_ACPI_STATUS(status);
616}
617
618/*******************************************************************************
619 *
620 * FUNCTION: acpi_load_tables
621 *
622 * PARAMETERS: None
623 *
624 * RETURN: Status
625 *
626 * DESCRIPTION: Load the ACPI tables from the RSDT/XSDT
627 *
628 ******************************************************************************/
629
630acpi_status acpi_load_tables(void)
631{
632 acpi_status status;
633
634 ACPI_FUNCTION_TRACE(acpi_load_tables);
635
636 /* Load the namespace from the tables */
637
638 status = acpi_tb_load_namespace();
639 if (ACPI_FAILURE(status)) {
640 ACPI_EXCEPTION((AE_INFO, status,
641 "While loading namespace from ACPI tables"));
642 }
643
644 return_ACPI_STATUS(status);
645}
646
647ACPI_EXPORT_SYMBOL(acpi_load_tables)
648
649 498
650/******************************************************************************* 499/*******************************************************************************
651 * 500 *
@@ -734,15 +583,3 @@ acpi_status acpi_remove_table_handler(acpi_tbl_handler handler)
734} 583}
735 584
736ACPI_EXPORT_SYMBOL(acpi_remove_table_handler) 585ACPI_EXPORT_SYMBOL(acpi_remove_table_handler)
737
738
739static int __init acpi_no_auto_ssdt_setup(char *s) {
740
741 printk(KERN_NOTICE "ACPI: SSDT auto-load disabled\n");
742
743 no_auto_ssdt = 1;
744
745 return 1;
746}
747
748__setup("acpi_no_auto_ssdt", acpi_no_auto_ssdt_setup);