diff options
| author | Yinghai Lu <yhlu.kernel@gmail.com> | 2009-02-07 15:39:41 -0800 | 
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2009-02-09 13:35:07 +0100 | 
| commit | 7d97277b754d3ee098a5ec69b6aaafb00c94e2f2 (patch) | |
| tree | 457ff6256a2da2f39f93500453a6a643ab29ef2b /arch/x86/kernel/acpi/boot.c | |
| parent | 05876f88ed9a66b26af613e222795ae790616252 (diff) | |
| download | olio-linux-3.10-7d97277b754d3ee098a5ec69b6aaafb00c94e2f2.tar.xz olio-linux-3.10-7d97277b754d3ee098a5ec69b6aaafb00c94e2f2.zip  | |
acpi/x86: introduce __apci_map_table, v4
to prevent wrongly overwriting fixmap that still want to use.
ACPI used to rely on low mappings being all linearly mapped and
grew a habit: it never really unmapped certain kinds of tables
after use.
This can cause problems - for example the hypothetical case
when some spurious access still references it.
v2: remove prev_map and prev_size in __apci_map_table
v3: let acpi_os_unmap_memory() call early_iounmap too, so remove extral calling to
early_acpi_os_unmap_memory
v4: fix typo in one acpi_get_table_with_size calling
Signed-off-by: Yinghai Lu <yhlu.kernel@gmail.com>
Acked-by: Len Brown <len.brown@intel.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/acpi/boot.c')
| -rw-r--r-- | arch/x86/kernel/acpi/boot.c | 17 | 
1 files changed, 7 insertions, 10 deletions
diff --git a/arch/x86/kernel/acpi/boot.c b/arch/x86/kernel/acpi/boot.c index 7217834f6b1..4c2aaea4293 100644 --- a/arch/x86/kernel/acpi/boot.c +++ b/arch/x86/kernel/acpi/boot.c @@ -121,21 +121,18 @@ enum acpi_irq_model_id acpi_irq_model = ACPI_IRQ_MODEL_PIC;   */  char *__init __acpi_map_table(unsigned long phys, unsigned long size)  { -	static char *prev_map; -	static unsigned long prev_size; - -	if (prev_map) { -		early_iounmap(prev_map, prev_size); -		prev_map = NULL; -	}  	if (!phys || !size)  		return NULL; -	prev_size = size; -	prev_map = early_ioremap(phys, size); +	return early_ioremap(phys, size); +} +void __init __acpi_unmap_table(char *map, unsigned long size) +{ +	if (!map || !size) +		return; -	return prev_map; +	early_iounmap(map, size);  }  #ifdef CONFIG_PCI_MMCONFIG  |