aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/x86/kernel/apic_32.c29
-rw-r--r--arch/x86/kernel/apic_64.c19
2 files changed, 33 insertions, 15 deletions
diff --git a/arch/x86/kernel/apic_32.c b/arch/x86/kernel/apic_32.c
index 3131603a4d6a..3d40213d3af2 100644
--- a/arch/x86/kernel/apic_32.c
+++ b/arch/x86/kernel/apic_32.c
@@ -1606,16 +1606,21 @@ static int lapic_resume(struct sys_device *dev)
1606 1606
1607 local_irq_save(flags); 1607 local_irq_save(flags);
1608 1608
1609 /* 1609#ifdef CONFIG_X86_64
1610 * Make sure the APICBASE points to the right address 1610 if (x2apic)
1611 * 1611 enable_x2apic();
1612 * FIXME! This will be wrong if we ever support suspend on 1612 else
1613 * SMP! We'll need to do this as part of the CPU restore! 1613#endif
1614 */ 1614 /*
1615 rdmsr(MSR_IA32_APICBASE, l, h); 1615 * Make sure the APICBASE points to the right address
1616 l &= ~MSR_IA32_APICBASE_BASE; 1616 *
1617 l |= MSR_IA32_APICBASE_ENABLE | mp_lapic_addr; 1617 * FIXME! This will be wrong if we ever support suspend on
1618 wrmsr(MSR_IA32_APICBASE, l, h); 1618 * SMP! We'll need to do this as part of the CPU restore!
1619 */
1620 rdmsr(MSR_IA32_APICBASE, l, h);
1621 l &= ~MSR_IA32_APICBASE_BASE;
1622 l |= MSR_IA32_APICBASE_ENABLE | mp_lapic_addr;
1623 wrmsr(MSR_IA32_APICBASE, l, h);
1619 1624
1620 apic_write(APIC_LVTERR, ERROR_APIC_VECTOR | APIC_LVT_MASKED); 1625 apic_write(APIC_LVTERR, ERROR_APIC_VECTOR | APIC_LVT_MASKED);
1621 apic_write(APIC_ID, apic_pm_state.apic_id); 1626 apic_write(APIC_ID, apic_pm_state.apic_id);
@@ -1625,7 +1630,7 @@ static int lapic_resume(struct sys_device *dev)
1625 apic_write(APIC_SPIV, apic_pm_state.apic_spiv); 1630 apic_write(APIC_SPIV, apic_pm_state.apic_spiv);
1626 apic_write(APIC_LVT0, apic_pm_state.apic_lvt0); 1631 apic_write(APIC_LVT0, apic_pm_state.apic_lvt0);
1627 apic_write(APIC_LVT1, apic_pm_state.apic_lvt1); 1632 apic_write(APIC_LVT1, apic_pm_state.apic_lvt1);
1628#ifdef CONFIG_X86_MCE_P4THERMAL 1633#if defined(CONFIG_X86_MCE_P4THERMAL) || defined(CONFIG_X86_MCE_INTEL)
1629 if (maxlvt >= 5) 1634 if (maxlvt >= 5)
1630 apic_write(APIC_LVTTHMR, apic_pm_state.apic_thmr); 1635 apic_write(APIC_LVTTHMR, apic_pm_state.apic_thmr);
1631#endif 1636#endif
@@ -1639,7 +1644,9 @@ static int lapic_resume(struct sys_device *dev)
1639 apic_write(APIC_LVTERR, apic_pm_state.apic_lvterr); 1644 apic_write(APIC_LVTERR, apic_pm_state.apic_lvterr);
1640 apic_write(APIC_ESR, 0); 1645 apic_write(APIC_ESR, 0);
1641 apic_read(APIC_ESR); 1646 apic_read(APIC_ESR);
1647
1642 local_irq_restore(flags); 1648 local_irq_restore(flags);
1649
1643 return 0; 1650 return 0;
1644} 1651}
1645 1652
diff --git a/arch/x86/kernel/apic_64.c b/arch/x86/kernel/apic_64.c
index d834b7583624..e542a2d08de5 100644
--- a/arch/x86/kernel/apic_64.c
+++ b/arch/x86/kernel/apic_64.c
@@ -1412,13 +1412,22 @@ static int lapic_resume(struct sys_device *dev)
1412 maxlvt = lapic_get_maxlvt(); 1412 maxlvt = lapic_get_maxlvt();
1413 1413
1414 local_irq_save(flags); 1414 local_irq_save(flags);
1415 if (!x2apic) { 1415
1416#ifdef CONFIG_X86_64
1417 if (x2apic)
1418 enable_x2apic();
1419 else
1420#endif
1421 /*
1422 * Make sure the APICBASE points to the right address
1423 *
1424 * FIXME! This will be wrong if we ever support suspend on
1425 * SMP! We'll need to do this as part of the CPU restore!
1426 */
1416 rdmsr(MSR_IA32_APICBASE, l, h); 1427 rdmsr(MSR_IA32_APICBASE, l, h);
1417 l &= ~MSR_IA32_APICBASE_BASE; 1428 l &= ~MSR_IA32_APICBASE_BASE;
1418 l |= MSR_IA32_APICBASE_ENABLE | mp_lapic_addr; 1429 l |= MSR_IA32_APICBASE_ENABLE | mp_lapic_addr;
1419 wrmsr(MSR_IA32_APICBASE, l, h); 1430 wrmsr(MSR_IA32_APICBASE, l, h);
1420 } else
1421 enable_x2apic();
1422 1431
1423 apic_write(APIC_LVTERR, ERROR_APIC_VECTOR | APIC_LVT_MASKED); 1432 apic_write(APIC_LVTERR, ERROR_APIC_VECTOR | APIC_LVT_MASKED);
1424 apic_write(APIC_ID, apic_pm_state.apic_id); 1433 apic_write(APIC_ID, apic_pm_state.apic_id);
@@ -1428,7 +1437,7 @@ static int lapic_resume(struct sys_device *dev)
1428 apic_write(APIC_SPIV, apic_pm_state.apic_spiv); 1437 apic_write(APIC_SPIV, apic_pm_state.apic_spiv);
1429 apic_write(APIC_LVT0, apic_pm_state.apic_lvt0); 1438 apic_write(APIC_LVT0, apic_pm_state.apic_lvt0);
1430 apic_write(APIC_LVT1, apic_pm_state.apic_lvt1); 1439 apic_write(APIC_LVT1, apic_pm_state.apic_lvt1);
1431#ifdef CONFIG_X86_MCE_INTEL 1440#if defined(CONFIG_X86_MCE_P4THERMAL) || defined(CONFIG_X86_MCE_INTEL)
1432 if (maxlvt >= 5) 1441 if (maxlvt >= 5)
1433 apic_write(APIC_LVTTHMR, apic_pm_state.apic_thmr); 1442 apic_write(APIC_LVTTHMR, apic_pm_state.apic_thmr);
1434#endif 1443#endif
@@ -1442,7 +1451,9 @@ static int lapic_resume(struct sys_device *dev)
1442 apic_write(APIC_LVTERR, apic_pm_state.apic_lvterr); 1451 apic_write(APIC_LVTERR, apic_pm_state.apic_lvterr);
1443 apic_write(APIC_ESR, 0); 1452 apic_write(APIC_ESR, 0);
1444 apic_read(APIC_ESR); 1453 apic_read(APIC_ESR);
1454
1445 local_irq_restore(flags); 1455 local_irq_restore(flags);
1456
1446 return 0; 1457 return 0;
1447} 1458}
1448 1459