diff options
Diffstat (limited to 'arch/x86/kernel/acpi/cstate.c')
| -rw-r--r-- | arch/x86/kernel/acpi/cstate.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/arch/x86/kernel/acpi/cstate.c b/arch/x86/kernel/acpi/cstate.c index bbbe4bbb6f34..8c44c232efcb 100644 --- a/arch/x86/kernel/acpi/cstate.c +++ b/arch/x86/kernel/acpi/cstate.c | |||
| @@ -34,12 +34,22 @@ void acpi_processor_power_init_bm_check(struct acpi_processor_flags *flags, | |||
| 34 | flags->bm_check = 1; | 34 | flags->bm_check = 1; |
| 35 | else if (c->x86_vendor == X86_VENDOR_INTEL) { | 35 | else if (c->x86_vendor == X86_VENDOR_INTEL) { |
| 36 | /* | 36 | /* |
| 37 | * Today all CPUs that support C3 share cache. | 37 | * Today all MP CPUs that support C3 share cache. |
| 38 | * TBD: This needs to look at cache shared map, once | 38 | * And caches should not be flushed by software while |
| 39 | * multi-core detection patch makes to the base. | 39 | * entering C3 type state. |
| 40 | */ | 40 | */ |
| 41 | flags->bm_check = 1; | 41 | flags->bm_check = 1; |
| 42 | } | 42 | } |
| 43 | |||
| 44 | /* | ||
| 45 | * On all recent Intel platforms, ARB_DISABLE is a nop. | ||
| 46 | * So, set bm_control to zero to indicate that ARB_DISABLE | ||
| 47 | * is not required while entering C3 type state on | ||
| 48 | * P4, Core and beyond CPUs | ||
| 49 | */ | ||
| 50 | if (c->x86_vendor == X86_VENDOR_INTEL && | ||
| 51 | (c->x86 > 0x6 || (c->x86 == 6 && c->x86_model >= 14))) | ||
| 52 | flags->bm_control = 0; | ||
| 43 | } | 53 | } |
| 44 | EXPORT_SYMBOL(acpi_processor_power_init_bm_check); | 54 | EXPORT_SYMBOL(acpi_processor_power_init_bm_check); |
| 45 | 55 | ||
