diff options
-rw-r--r-- | drivers/acpi/processor_idle.c | 43 |
1 files changed, 6 insertions, 37 deletions
diff --git a/drivers/acpi/processor_idle.c b/drivers/acpi/processor_idle.c index eaa32586f89c..58113a6fa1d3 100644 --- a/drivers/acpi/processor_idle.c +++ b/drivers/acpi/processor_idle.c | |||
@@ -704,34 +704,6 @@ static void acpi_idle_do_entry(struct acpi_processor_cx *cx) | |||
704 | } | 704 | } |
705 | 705 | ||
706 | /** | 706 | /** |
707 | * acpi_idle_enter_c1 - enters an ACPI C1 state-type | ||
708 | * @dev: the target CPU | ||
709 | * @drv: cpuidle driver containing cpuidle state info | ||
710 | * @index: index of target state | ||
711 | * | ||
712 | * This is equivalent to the HALT instruction. | ||
713 | */ | ||
714 | static int acpi_idle_enter_c1(struct cpuidle_device *dev, | ||
715 | struct cpuidle_driver *drv, int index) | ||
716 | { | ||
717 | struct acpi_processor *pr; | ||
718 | struct acpi_processor_cx *cx = per_cpu(acpi_cstate[index], dev->cpu); | ||
719 | |||
720 | pr = __this_cpu_read(processors); | ||
721 | |||
722 | if (unlikely(!pr)) | ||
723 | return -EINVAL; | ||
724 | |||
725 | lapic_timer_state_broadcast(pr, cx, 1); | ||
726 | acpi_idle_do_entry(cx); | ||
727 | |||
728 | lapic_timer_state_broadcast(pr, cx, 0); | ||
729 | |||
730 | return index; | ||
731 | } | ||
732 | |||
733 | |||
734 | /** | ||
735 | * acpi_idle_play_dead - enters an ACPI state for long-term idle (i.e. off-lining) | 707 | * acpi_idle_play_dead - enters an ACPI state for long-term idle (i.e. off-lining) |
736 | * @dev: the target CPU | 708 | * @dev: the target CPU |
737 | * @index: the index of suggested state | 709 | * @index: the index of suggested state |
@@ -766,7 +738,7 @@ static bool acpi_idle_fallback_to_c1(struct acpi_processor *pr) | |||
766 | } | 738 | } |
767 | 739 | ||
768 | /** | 740 | /** |
769 | * acpi_idle_enter_simple - enters an ACPI state without BM handling | 741 | * acpi_idle_enter_simple - enters a CPU idle state without BM handling |
770 | * @dev: the target CPU | 742 | * @dev: the target CPU |
771 | * @drv: cpuidle driver with cpuidle state information | 743 | * @drv: cpuidle driver with cpuidle state information |
772 | * @index: the index of suggested state | 744 | * @index: the index of suggested state |
@@ -782,8 +754,10 @@ static int acpi_idle_enter_simple(struct cpuidle_device *dev, | |||
782 | if (unlikely(!pr)) | 754 | if (unlikely(!pr)) |
783 | return -EINVAL; | 755 | return -EINVAL; |
784 | 756 | ||
785 | if (acpi_idle_fallback_to_c1(pr)) | 757 | if (cx->type != ACPI_STATE_C1 && acpi_idle_fallback_to_c1(pr)) { |
786 | return acpi_idle_enter_c1(dev, drv, CPUIDLE_DRIVER_STATE_START); | 758 | index = CPUIDLE_DRIVER_STATE_START; |
759 | cx = per_cpu(acpi_cstate[index], dev->cpu); | ||
760 | } | ||
787 | 761 | ||
788 | lapic_timer_state_broadcast(pr, cx, 1); | 762 | lapic_timer_state_broadcast(pr, cx, 1); |
789 | 763 | ||
@@ -819,7 +793,7 @@ static int acpi_idle_enter_bm(struct cpuidle_device *dev, | |||
819 | return -EINVAL; | 793 | return -EINVAL; |
820 | 794 | ||
821 | if (acpi_idle_fallback_to_c1(pr)) | 795 | if (acpi_idle_fallback_to_c1(pr)) |
822 | return acpi_idle_enter_c1(dev, drv, CPUIDLE_DRIVER_STATE_START); | 796 | return acpi_idle_enter_simple(dev, drv, CPUIDLE_DRIVER_STATE_START); |
823 | 797 | ||
824 | if (!cx->bm_sts_skip && acpi_idle_bm_check()) { | 798 | if (!cx->bm_sts_skip && acpi_idle_bm_check()) { |
825 | if (drv->safe_state_index >= 0) { | 799 | if (drv->safe_state_index >= 0) { |
@@ -967,11 +941,6 @@ static int acpi_processor_setup_cpuidle_states(struct acpi_processor *pr) | |||
967 | switch (cx->type) { | 941 | switch (cx->type) { |
968 | 942 | ||
969 | case ACPI_STATE_C1: | 943 | case ACPI_STATE_C1: |
970 | state->enter = acpi_idle_enter_c1; | ||
971 | state->enter_dead = acpi_idle_play_dead; | ||
972 | drv->safe_state_index = count; | ||
973 | break; | ||
974 | |||
975 | case ACPI_STATE_C2: | 944 | case ACPI_STATE_C2: |
976 | state->enter = acpi_idle_enter_simple; | 945 | state->enter = acpi_idle_enter_simple; |
977 | state->enter_dead = acpi_idle_play_dead; | 946 | state->enter_dead = acpi_idle_play_dead; |