Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 117291
b: refs/heads/master
c: e56f561
h: refs/heads/master
i:
  117289: 09532c1
  117287: a176fa2
v: v3
  • Loading branch information
Bob Moore authored and Len Brown committed Oct 23, 2008
1 parent 7e1cde0 commit 8c2f0bf
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 8 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 237a927682a63f02adb542dbdaafe8a81566451d
refs/heads/master: e56f561736e340a4e923b0db65f65dabf5d94823
49 changes: 42 additions & 7 deletions trunk/drivers/acpi/tables/tbinstal.c
Original file line number Diff line number Diff line change
Expand Up @@ -145,6 +145,8 @@ acpi_tb_add_table(struct acpi_table_desc *table_desc, u32 *table_index)
}
}

/* Check for a table match on the entire table length */

length = ACPI_MIN(table_desc->length,
acpi_gbl_root_table_list.tables[i].length);
if (ACPI_MEMCMP(table_desc->pointer,
Expand All @@ -153,24 +155,57 @@ acpi_tb_add_table(struct acpi_table_desc *table_desc, u32 *table_index)
continue;
}

/* Table is already registered */

/*
* Note: the current mechanism does not unregister a table if it is
* dynamically unloaded. The related namespace entries are deleted,
* but the table remains in the root table list.
*
* The assumption here is that the number of different tables that
* will be loaded is actually small, and there is minimal overhead
* in just keeping the table in case it is needed again.
*
* If this assumption changes in the future (perhaps on large
* machines with many table load/unload operations), tables will
* need to be unregistered when they are unloaded, and slots in the
* root table list should be reused when empty.
*/

/*
* Table is already registered.
* We can delete the table that was passed as a parameter.
*/
acpi_tb_delete_table(table_desc);
*table_index = i;
status = AE_ALREADY_EXISTS;
goto release;

if (acpi_gbl_root_table_list.tables[i].
flags & ACPI_TABLE_IS_LOADED) {

/* Table is still loaded, this is an error */

status = AE_ALREADY_EXISTS;
goto release;
} else {
/* Table was unloaded, allow it to be reloaded */

table_desc->pointer =
acpi_gbl_root_table_list.tables[i].pointer;
table_desc->address =
acpi_gbl_root_table_list.tables[i].address;
status = AE_OK;
goto print_header;
}
}

/*
* Add the table to the global table list
*/
/* Add the table to the global root table list */

status = acpi_tb_store_table(table_desc->address, table_desc->pointer,
table_desc->length, table_desc->flags,
table_index);
if (ACPI_FAILURE(status)) {
goto release;
}

print_header:
acpi_tb_print_table_header(table_desc->address, table_desc->pointer);

release:
Expand Down

0 comments on commit 8c2f0bf

Please sign in to comment.