ACPICA: Tables: Add an error message complaining driver bugs
authorLv Zheng <lv.zheng@intel.com>
Wed, 30 Nov 2016 07:21:34 +0000 (15:21 +0800)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Thu, 1 Dec 2016 13:28:23 +0000 (14:28 +0100)
ACPICA commit 68af3c3aa238dd8040e846ac6b4827a016434d8d

During early OS boot stage, drivers that have mapped system memory should
unmap it during the same stage. Linux kernel has an error message
indicating the unbalanced early memory mappings.

This patch back ports such error message into ACPICA for the early table
mappings, so that ACPICA development environment is also aware of this OS
specific requirement and thus is able to ensure the consistent quality
locally. Lv Zheng.

Link: https://github.com/acpica/acpica/commit/68af3c3a
Signed-off-by: Lv Zheng <lv.zheng@intel.com>
Signed-off-by: Bob Moore <robert.moore@intel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/acpi/acpica/tbxface.c

index 4ab6b9cd0aec0e28f8d701f803f066b25c1c2402..d5adb7ac468430c82c4c1d7a1d7c75be6be40c5e 100644 (file)
@@ -167,6 +167,7 @@ ACPI_EXPORT_SYMBOL_INIT(acpi_initialize_tables)
 acpi_status ACPI_INIT_FUNCTION acpi_reallocate_root_table(void)
 {
        acpi_status status;
+       u32 i;
 
        ACPI_FUNCTION_TRACE(acpi_reallocate_root_table);
 
@@ -178,6 +179,21 @@ acpi_status ACPI_INIT_FUNCTION acpi_reallocate_root_table(void)
                return_ACPI_STATUS(AE_SUPPORT);
        }
 
+       /*
+        * Ensure OS early boot logic, which is required by some hosts. If the
+        * table state is reported to be wrong, developers should fix the
+        * issue by invoking acpi_put_table() for the reported table during the
+        * early stage.
+        */
+       for (i = 0; i < acpi_gbl_root_table_list.current_table_count; ++i) {
+               if (acpi_gbl_root_table_list.tables[i].pointer) {
+                       ACPI_ERROR((AE_INFO,
+                                   "Table [%4.4s] is not invalidated during early boot stage",
+                                   acpi_gbl_root_table_list.tables[i].
+                                   signature.ascii));
+               }
+       }
+
        acpi_gbl_root_table_list.flags |= ACPI_ROOT_ALLOW_RESIZE;
 
        status = acpi_tb_resize_root_table_list();