Lines Matching +full:no +full:- +full:tick +full:- +full:in +full:- +full:suspend

1 // SPDX-License-Identifier: GPL-2.0-only
13 * Mikael Pettersson : Power Management for UP-APIC.
44 #include <asm/pc-conf-reg.h>
65 #include <asm/intel-family.h>
84 * Hypervisor supports 15 bits of APIC ID in MSI Extended Destination ID
124 * +1=force-enable
156 /* Local APIC timer works in C2 */
214 * so apic->write/read doesn't do anything
242 * lapic_get_maxlvt - get the maximum number of local vector table entries
247 * - we always have APIC integrated on 64bit mode in lapic_get_maxlvt()
248 * - 82489DXs do not report # of LVT entries in lapic_get_maxlvt()
287 * in the SDM. No problem though. i82489DX equipped systems do not in __setup_APIC_LVTT()
300 * See Intel SDM: TSC-Deadline Mode chapter. In xAPIC mode, in __setup_APIC_LVTT()
330 * of the LVT offsets in software and reserve the offset for the same
334 * If the BIOS is right, there should be no conflicts. Otherwise a
389 "vector 0x%x, but the register is already in use for " in setup_APIC_eilvt()
392 return -EINVAL; in setup_APIC_eilvt()
397 "vector 0x%x, but the register is already in use for " in setup_APIC_eilvt()
400 return -EBUSY; in setup_APIC_eilvt()
437 if (evt->features & CLOCK_EVT_FEAT_DUMMY) in lapic_timer_shutdown()
463 if (evt->features & CLOCK_EVT_FEAT_DUMMY) in lapic_timer_set_periodic_oneshot()
507 .irq = -1,
556 rev = (u32)m->driver_data; in apic_validate_deadline_timer()
569 * of the boot CPU and register the clock event in the framework.
582 levt->cpumask = cpumask_of(smp_processor_id()); in setup_APIC_timer()
585 levt->name = "lapic-deadline"; in setup_APIC_timer()
586 levt->features &= ~(CLOCK_EVT_FEAT_PERIODIC | in setup_APIC_timer()
588 levt->set_next_event = lapic_next_deadline; in setup_APIC_timer()
613 * The clockevent device's ->mult and ->shift can both be in lapic_update_tsc_freq()
614 * changed. In order to avoid races, schedule the frequency in lapic_update_tsc_freq()
621 * In this functions we calibrate APIC bus clocks to the external timer.
628 * around to find out, that a tick has elapsed. I have a box, where the PIT
638 * back to normal later in the boot process).
643 static __initdata int lapic_cal_loops = -1;
689 return -1; in calibrate_by_pmtimer()
692 apic_pr_verbose("... PM-Timer delta = %u\n", deltapm); in calibrate_by_pmtimer()
696 return -1; in calibrate_by_pmtimer()
700 if (deltapm > (pm_100ms - pm_thresh) && in calibrate_by_pmtimer()
702 apic_pr_verbose("... PM-Timer result ok\n"); in calibrate_by_pmtimer()
708 pr_warn("APIC calibration not consistent with PM-Timer: %ldms instead of 100ms\n", in calibrate_by_pmtimer()
714 pr_info("APIC delta adjusted to PM-Timer: " in calibrate_by_pmtimer()
722 apic_pr_verbose("TSC delta adjusted to PM-Timer: %lu (%ld)\n", in calibrate_by_pmtimer()
733 return -1; in lapic_init_clockevent()
774 /* Deadline timer is based on TSC so no further PIT action required */ in apic_needs_pit()
782 * The APIC timer frequency is known already, no PIT calibration in apic_needs_pit()
803 * in the clockevent structure and return. in calibrate_APIC_clock()
809 * local APIC timer, no need for broadcast timer. in calibrate_APIC_clock()
825 * Setup the APIC counter to maximum. There is no way the lapic in calibrate_APIC_clock()
826 * can underflow in the 100ms detection time frame in calibrate_APIC_clock()
843 * Enable interrupts so the tick can fire, if a global in calibrate_APIC_clock()
849 /* Wait for a tick to elapse */ in calibrate_APIC_clock()
853 if ((tsc_now - tsc_start) >= tsc_perj) { in calibrate_APIC_clock()
876 /* Build delta t1-t2 as apic timer counts down */ in calibrate_APIC_clock()
877 delta = lapic_cal_t1 - lapic_cal_t2; in calibrate_APIC_clock()
880 deltatsc = (long)(lapic_cal_tsc2 - lapic_cal_tsc1); in calibrate_APIC_clock()
883 pm_referenced = !calibrate_by_pmtimer(lapic_cal_pm2 - lapic_cal_pm1, in calibrate_APIC_clock()
909 return -1; in calibrate_APIC_clock()
912 levt->features &= ~CLOCK_EVT_FEAT_DUMMY; in calibrate_APIC_clock()
925 levt->event_handler = lapic_cal_handler; in calibrate_APIC_clock()
927 lapic_cal_loops = -1; in calibrate_APIC_clock()
940 deltaj = lapic_cal_j2 - lapic_cal_j1; in calibrate_APIC_clock()
944 if (deltaj >= LAPIC_CAL_LOOPS-2 && deltaj <= LAPIC_CAL_LOOPS+2) in calibrate_APIC_clock()
947 levt->features |= CLOCK_EVT_FEAT_DUMMY; in calibrate_APIC_clock()
951 if (levt->features & CLOCK_EVT_FEAT_DUMMY) { in calibrate_APIC_clock()
953 return -1; in calibrate_APIC_clock()
974 /* No broadcast on UP ! */ in setup_boot_APIC_clock()
983 /* No broadcast on UP ! */ in setup_boot_APIC_clock()
1016 * in some cases like kdump, its possible that there is a pending LAPIC in local_apic_timer_interrupt()
1017 * timer interrupt from previous kernel's context and is delivered in in local_apic_timer_interrupt()
1021 * its possible that when we get here evt->event_handler is NULL. in local_apic_timer_interrupt()
1025 if (!evt->event_handler) { in local_apic_timer_interrupt()
1034 * the NMI deadlock-detector uses this. in local_apic_timer_interrupt()
1038 evt->event_handler(evt); in local_apic_timer_interrupt()
1044 * broadcast interrupts too. [in case the hw doesn't support APIC timers]
1046 * [ if a single-CPU system runs an SMP kernel then we call the local
1066 * clear_local_APIC - shutdown the local APIC
1069 * the local APIC has no dangling leftovers. Also used to cleanout any BIOS
1086 v = ERROR_APIC_VECTOR; /* any non-zero vector will do */ in clear_local_APIC()
1091 * any level-triggered sources. in clear_local_APIC()
1140 * apic_soft_disable - Clears and software disables the local APIC on hotplug
1142 * Contrary to disable_local_APIC() this does not touch the enable bit in
1146 * but it has to be guaranteed that no interrupt is sent to the APIC while
1147 * in that state and it's not clear from the SDM whether it still responds
1163 * disable_local_APIC - clear and disable the local APIC
1189 * re-entering the BIOS on shutdown. Otherwise the BIOS may get confused and
1190 * not power-off. Additionally clear all LVT entries before disable_local_APIC
1214 * sync_Arb_IDs - synchronize APIC bus arbitration IDs
1219 * Unsupported on P4 - see Intel Dev. Manual Vol. 3, Ch. 8.6.1 And not in sync_Arb_IDs()
1246 /* On 64-bit, the APIC must be integrated, Check local APIC only */ in __apic_intr_mode_select()
1253 /* On 32-bit, the APIC may be integrated APIC or 82489DX */ in __apic_intr_mode_select()
1306 * through-I/O-APIC virtual wire mode might be active. in init_bsp_APIC()
1355 pr_info("APIC: Keep in PIC mode(8259)\n"); in apic_intr_mode_init()
1361 pr_info("APIC: Switch to virtual wire mode setup with no configuration\n"); in apic_intr_mode_init()
1368 pr_info("APIC: Switch to symmetric I/O mode setup in no SMP routine\n"); in apic_intr_mode_init()
1387 pr_info("No ESR for 82489DX.\n"); in lapic_setup_esr()
1391 if (apic->disable_esr) { in lapic_setup_esr()
1395 * ESR disabled - we can't do anything useful with the in lapic_setup_esr()
1396 * errors anyway - mbligh in lapic_setup_esr()
1438 irr->regs[i] = apic_read(APIC_IRR + i * 0x10); in apic_check_and_ack()
1442 isr->regs[i] = apic_read(APIC_ISR + i * 0x10); in apic_check_and_ack()
1449 if (!bitmap_empty(isr->map, APIC_IR_BITS)) { in apic_check_and_ack()
1455 for_each_set_bit(bit, isr->map, APIC_IR_BITS) in apic_check_and_ack()
1460 return !bitmap_empty(irr->map, APIC_IR_BITS); in apic_check_and_ack()
1464 * After a crash, we no longer service the interrupts and a pending
1492 * setup_local_APIC - setup the local APIC
1508 * If this comes from kexec/kcrash the APIC might be enabled in in setup_local_APIC()
1516 /* Pound the ESR really hard over the head with a big hammer - mbligh */ in setup_local_APIC()
1517 if (lapic_is_integrated() && apic->disable_esr) { in setup_local_APIC()
1526 * an APIC. See e.g. "AP-388 82489DX User's Manual" (Intel in setup_local_APIC()
1529 * Except for APICs which operate in physical destination mode. in setup_local_APIC()
1531 if (apic->init_apic_ldr) in setup_local_APIC()
1532 apic->init_apic_ldr(); in setup_local_APIC()
1535 * Set Task Priority to 'accept all except vectors 0-31'. An APIC in setup_local_APIC()
1536 * vector in the 16-31 range could be delivered if TPR == 0, but we in setup_local_APIC()
1564 * later IOAPIC line gets 'stuck', no more interrupts are received in setup_local_APIC()
1566 * away, oh well :-( in setup_local_APIC()
1568 * [ This bug can be reproduced easily with a level-triggered in setup_local_APIC()
1575 * like LRU than MRU (the short-term load is more even across CPUs). in setup_local_APIC()
1579 * - enable focus processor (bit==0) in setup_local_APIC()
1580 * - 64bit mode always use processor focus in setup_local_APIC()
1581 * so no need to set it in setup_local_APIC()
1597 * set up through-local-APIC on the boot CPU's LINT0. This is not in setup_local_APIC()
1598 * strictly necessary in pure symmetric-IO mode, but sometimes in setup_local_APIC()
1602 * TODO: set up through-local-APIC from through-I/O-APIC? --macro in setup_local_APIC()
1744 pr_warn("APIC locked in x2apic mode, can't disable\n"); in setup_nox2apic()
1763 * Warn about the mismatch in case a GP fault occurs due to a locked AP in x2apic_setup()
1769 * If x2apic is not in ON or LOCKED state, disable it if already enabled in x2apic_setup()
1830 * on bare metal but may be supported in guests. in try_to_enable_x2apic()
1839 * If the hypervisor supports extended destination ID in in try_to_enable_x2apic()
1841 * used for non-remapped IRQ domains. in try_to_enable_x2apic()
1850 * in physical mode, and CPUs with an APIC ID that cannot in try_to_enable_x2apic()
1898 pr_info("Not enabling interrupt remapping due to skipped IO-APIC setup\n"); in enable_IR_x2apic()
1908 pr_info("Saving IO-APIC state failed: %d\n", ret); in enable_IR_x2apic()
1913 legacy_pic->mask_all(); in enable_IR_x2apic()
1924 legacy_pic->restore_mask(); in enable_IR_x2apic()
1930 * Detect and enable local APICs on non-SMP boards.
1932 * On AMD64 we trust the BIOS - if it says no APIC it is likely
1938 pr_info("No local APIC present\n"); in detect_init_APIC()
1953 * in `cpuid' in apic_verify()
1982 * Some BIOSes disable the local APIC in the APIC_BASE in apic_force_enable()
1983 * MSR. This can only be done in software for Intel P6 or later in apic_force_enable()
1989 pr_info("Local APIC disabled by BIOS -- reenabling.\n"); in apic_force_enable()
2027 * Over-ride BIOS and try to enable the local APIC only if in detect_init_APIC()
2031 pr_info("Local APIC disabled by BIOS -- " in detect_init_APIC()
2047 pr_info("No local APIC present or hardware disabled\n"); in detect_init_APIC()
2053 * init_apic_mappings - initialize APIC mappings
2096 * points below. No point in allowing the compiler to inline it twice.
2117 * If it is a vectored one, verify it's set in the ISR. If set, in handle_spurious_interrupt()
2134 * spurious_interrupt - Catch all for interrupts raised on unused vectors
2171 /* First tickle the hardware, only then report what went on. -- REW */ in DEFINE_IDTENTRY_SYSVEC()
2194 * connect_bsp_APIC - attach the APIC to the interrupt system
2205 * PIC mode, enable APIC mode in the IMCR, i.e. connect BSP's in connect_bsp_APIC()
2215 * disconnect_bsp_APIC - detach the APIC from the interrupt system
2283 msg->arch_addr_lo.base_address = X86_MSI_BASE_ADDRESS_LOW; in __irq_msi_compose_msg()
2284 msg->arch_addr_lo.dest_mode_logical = apic->dest_mode_logical; in __irq_msi_compose_msg()
2285 msg->arch_addr_lo.destid_0_7 = cfg->dest_apicid & 0xFF; in __irq_msi_compose_msg()
2287 msg->arch_data.delivery_mode = APIC_DELIVERY_MODE_FIXED; in __irq_msi_compose_msg()
2288 msg->arch_data.vector = cfg->vector; in __irq_msi_compose_msg()
2290 msg->address_hi = X86_MSI_BASE_ADDRESS_HIGH; in __irq_msi_compose_msg()
2295 * address APICs which can't be addressed in the normal 32-bit in __irq_msi_compose_msg()
2297 * some hypervisors allow the extended destination ID field in bits in __irq_msi_compose_msg()
2298 * 5-11 to be used, giving support for 15 bits of APIC IDs in total. in __irq_msi_compose_msg()
2301 msg->arch_addr_hi.destid_8_31 = cfg->dest_apicid >> 8; in __irq_msi_compose_msg()
2302 else if (virt_ext_dest_id && cfg->dest_apicid < 0x8000) in __irq_msi_compose_msg()
2303 msg->arch_addr_lo.virt_destid_8_14 = cfg->dest_apicid >> 8; in __irq_msi_compose_msg()
2305 WARN_ON_ONCE(cfg->dest_apicid > 0xFF); in __irq_msi_compose_msg()
2310 u32 dest = msg->arch_addr_lo.destid_0_7; in x86_msi_msg_get_destid()
2313 dest |= msg->arch_addr_hi.destid_8_31 << 8; in x86_msi_msg_get_destid()
2324 * apic_bsp_setup - Setup function for local apic and io-apic
2361 * for disabling it before entering apm/acpi suspend
2441 * IO-APIC and PIC have their own resume routines. in lapic_resume()
2444 * and interrupt-remapping. in lapic_resume()
2447 legacy_pic->mask_all(); in lapic_resume()
2455 * FIXME! This will be wrong if we ever support suspend on in lapic_resume()
2500 * This device has no shutdown method - fully functioning local APICs
2506 .suspend = lapic_suspend,
2516 /* XXX: remove suspend/resume procs if !apic_pm_state.active? */ in init_lapic_sysfs()
2541 pr_info("APIC: %s detected, Multi Chassis\n", d->ident); in set_multi()
2568 * apic_is_clustered_box() -- Check if we can expect good TSC
2572 * multi-chassis.
2625 return -EINVAL; in apic_set_verbosity()
2639 return -EINVAL; in apic_set_verbosity()
2650 return -1; in lapic_insert_resource()
2654 lapic_resource.end = lapic_resource.start + PAGE_SIZE - 1; in lapic_insert_resource()
2669 return -EINVAL; in apic_set_extnmi()
2679 return -EINVAL; in apic_set_extnmi()