Lines Matching full:cx
133 struct acpi_processor_cx *cx) in lapic_timer_check_state() argument
151 if (cx->type >= type) in lapic_timer_check_state()
173 struct acpi_processor_cx *cx) in lapic_timer_needs_broadcast() argument
175 return cx - pr->power.states >= pr->power.timer_broadcast_on_state; in lapic_timer_needs_broadcast()
185 struct acpi_processor_cx *cx) in lapic_timer_needs_broadcast() argument
322 struct acpi_processor_cx *cx) in acpi_processor_power_verify_c3() argument
328 if (!cx->address) in acpi_processor_power_verify_c3()
387 cx->valid = 1; in acpi_processor_power_verify_c3()
431 struct acpi_processor_cx *cx = &pr->power.states[i]; in acpi_processor_power_verify() local
433 switch (cx->type) { in acpi_processor_power_verify()
435 cx->valid = 1; in acpi_processor_power_verify()
439 if (!cx->address) in acpi_processor_power_verify()
441 cx->valid = 1; in acpi_processor_power_verify()
445 acpi_processor_power_verify_c3(pr, cx); in acpi_processor_power_verify()
448 if (!cx->valid) in acpi_processor_power_verify()
450 if (cx->type >= last_type && cx->latency < last_latency) in acpi_processor_power_verify()
452 last_latency = cx->latency; in acpi_processor_power_verify()
453 last_type = cx->type; in acpi_processor_power_verify()
455 lapic_timer_check_state(i, pr, cx); in acpi_processor_power_verify()
456 tsc_check_state(cx->type); in acpi_processor_power_verify()
556 * @cx: cstate data
560 static void __cpuidle acpi_idle_do_entry(struct acpi_processor_cx *cx) in acpi_idle_do_entry() argument
564 if (cx->entry_method == ACPI_CSTATE_FFH) { in acpi_idle_do_entry()
566 acpi_processor_ffh_cstate_enter(cx); in acpi_idle_do_entry()
567 } else if (cx->entry_method == ACPI_CSTATE_HALT) { in acpi_idle_do_entry()
570 io_idle(cx->address); in acpi_idle_do_entry()
583 struct acpi_processor_cx *cx = per_cpu(acpi_cstate[index], dev->cpu); in acpi_idle_play_dead() local
589 if (cx->entry_method == ACPI_CSTATE_HALT) in acpi_idle_play_dead()
591 else if (cx->entry_method == ACPI_CSTATE_SYSTEMIO) { in acpi_idle_play_dead()
592 io_idle(cx->address); in acpi_idle_play_dead()
593 } else if (cx->entry_method == ACPI_CSTATE_FFH) { in acpi_idle_play_dead()
594 acpi_processor_ffh_play_dead(cx); in acpi_idle_play_dead()
613 * @cx: Target state context
618 struct acpi_processor_cx *cx, in acpi_idle_enter_bm() argument
638 if (!cx->bm_sts_skip && acpi_idle_bm_check()) { in acpi_idle_enter_bm()
642 cx = this_cpu_read(acpi_cstate[index]); in acpi_idle_enter_bm()
644 cx = &safe_cx; in acpi_idle_enter_bm()
660 acpi_idle_do_entry(cx); in acpi_idle_enter_bm()
680 struct acpi_processor_cx *cx = per_cpu(acpi_cstate[index], dev->cpu); in acpi_idle_enter() local
687 if (cx->type != ACPI_STATE_C1) { in acpi_idle_enter()
688 if (cx->type == ACPI_STATE_C3 && pr->flags.bm_check) in acpi_idle_enter()
689 return acpi_idle_enter_bm(drv, pr, cx, index); in acpi_idle_enter()
694 cx = per_cpu(acpi_cstate[index], dev->cpu); in acpi_idle_enter()
698 if (cx->type == ACPI_STATE_C3) in acpi_idle_enter()
701 acpi_idle_do_entry(cx); in acpi_idle_enter()
709 struct acpi_processor_cx *cx = per_cpu(acpi_cstate[index], dev->cpu); in acpi_idle_enter_s2idle() local
711 if (cx->type == ACPI_STATE_C3) { in acpi_idle_enter_s2idle()
718 u8 bm_sts_skip = cx->bm_sts_skip; in acpi_idle_enter_s2idle()
721 cx->bm_sts_skip = 1; in acpi_idle_enter_s2idle()
722 acpi_idle_enter_bm(drv, pr, cx, index); in acpi_idle_enter_s2idle()
723 cx->bm_sts_skip = bm_sts_skip; in acpi_idle_enter_s2idle()
730 acpi_idle_do_entry(cx); in acpi_idle_enter_s2idle()
739 struct acpi_processor_cx *cx; in acpi_processor_setup_cpuidle_cx() local
747 cx = &pr->power.states[i]; in acpi_processor_setup_cpuidle_cx()
749 if (!cx->valid) in acpi_processor_setup_cpuidle_cx()
752 per_cpu(acpi_cstate[count], dev->cpu) = cx; in acpi_processor_setup_cpuidle_cx()
754 if (lapic_timer_needs_broadcast(pr, cx)) in acpi_processor_setup_cpuidle_cx()
757 if (cx->type == ACPI_STATE_C3) { in acpi_processor_setup_cpuidle_cx()
777 struct acpi_processor_cx *cx; in acpi_processor_setup_cstates() local
792 cx = &pr->power.states[i]; in acpi_processor_setup_cstates()
794 if (!cx->valid) in acpi_processor_setup_cstates()
799 strscpy(state->desc, cx->desc, CPUIDLE_DESC_LEN); in acpi_processor_setup_cstates()
800 state->exit_latency = cx->latency; in acpi_processor_setup_cstates()
801 state->target_residency = cx->latency * latency_factor; in acpi_processor_setup_cstates()
808 if (cx->type == ACPI_STATE_C1 || cx->type == ACPI_STATE_C2) in acpi_processor_setup_cstates()
818 if (cx->type != ACPI_STATE_C1 && !acpi_idle_fallback_to_c1(pr)) in acpi_processor_setup_cstates()