diff options
author | Venkatesh Pallipadi <venki@google.com> | 2010-06-02 13:01:09 -0400 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2010-06-04 15:22:28 -0400 |
commit | bceefad59ab66d1b1a815a1738744ea013da966e (patch) | |
tree | 4cd5406c4cf77ac93bcf4fc764105be938628d51 | |
parent | 157317ba3ec3e5a4d9683b8d24ba40b4f8f3296b (diff) |
ACPI: Eliminate us to pm ticks conversion in common path
acpi_enter_[simple|bm] routines does us to pm tick conversion on every
idle wakeup and the value is only used in /proc/acpi display. We can
store the time in us and convert it into pm ticks before printing instead and
avoid the conversion in the common path.
Signed-off-by: Venkatesh Pallipadi <venki@google.com>
Signed-off-by: Len Brown <len.brown@intel.com>
-rw-r--r-- | drivers/acpi/processor_idle.c | 15 |
1 files changed, 5 insertions, 10 deletions
diff --git a/drivers/acpi/processor_idle.c b/drivers/acpi/processor_idle.c index 6b38a6b43ce8..b1b385692f46 100644 --- a/drivers/acpi/processor_idle.c +++ b/drivers/acpi/processor_idle.c | |||
@@ -80,7 +80,7 @@ module_param(nocst, uint, 0000); | |||
80 | static unsigned int latency_factor __read_mostly = 2; | 80 | static unsigned int latency_factor __read_mostly = 2; |
81 | module_param(latency_factor, uint, 0644); | 81 | module_param(latency_factor, uint, 0644); |
82 | 82 | ||
83 | static s64 us_to_pm_timer_ticks(s64 t) | 83 | static u64 us_to_pm_timer_ticks(s64 t) |
84 | { | 84 | { |
85 | return div64_u64(t * PM_TIMER_FREQUENCY, 1000000); | 85 | return div64_u64(t * PM_TIMER_FREQUENCY, 1000000); |
86 | } | 86 | } |
@@ -731,10 +731,10 @@ static int acpi_processor_power_seq_show(struct seq_file *seq, void *offset) | |||
731 | 731 | ||
732 | seq_puts(seq, "demotion[--] "); | 732 | seq_puts(seq, "demotion[--] "); |
733 | 733 | ||
734 | seq_printf(seq, "latency[%03d] usage[%08d] duration[%020llu]\n", | 734 | seq_printf(seq, "latency[%03d] usage[%08d] duration[%020Lu]\n", |
735 | pr->power.states[i].latency, | 735 | pr->power.states[i].latency, |
736 | pr->power.states[i].usage, | 736 | pr->power.states[i].usage, |
737 | (unsigned long long)pr->power.states[i].time); | 737 | us_to_pm_timer_ticks(pr->power.states[i].time)); |
738 | } | 738 | } |
739 | 739 | ||
740 | end: | 740 | end: |
@@ -861,7 +861,6 @@ static int acpi_idle_enter_simple(struct cpuidle_device *dev, | |||
861 | ktime_t kt1, kt2; | 861 | ktime_t kt1, kt2; |
862 | s64 idle_time_ns; | 862 | s64 idle_time_ns; |
863 | s64 idle_time; | 863 | s64 idle_time; |
864 | s64 sleep_ticks = 0; | ||
865 | 864 | ||
866 | pr = __get_cpu_var(processors); | 865 | pr = __get_cpu_var(processors); |
867 | 866 | ||
@@ -906,8 +905,6 @@ static int acpi_idle_enter_simple(struct cpuidle_device *dev, | |||
906 | idle_time = idle_time_ns; | 905 | idle_time = idle_time_ns; |
907 | do_div(idle_time, NSEC_PER_USEC); | 906 | do_div(idle_time, NSEC_PER_USEC); |
908 | 907 | ||
909 | sleep_ticks = us_to_pm_timer_ticks(idle_time); | ||
910 | |||
911 | /* Tell the scheduler how much we idled: */ | 908 | /* Tell the scheduler how much we idled: */ |
912 | sched_clock_idle_wakeup_event(idle_time_ns); | 909 | sched_clock_idle_wakeup_event(idle_time_ns); |
913 | 910 | ||
@@ -918,7 +915,7 @@ static int acpi_idle_enter_simple(struct cpuidle_device *dev, | |||
918 | cx->usage++; | 915 | cx->usage++; |
919 | 916 | ||
920 | lapic_timer_state_broadcast(pr, cx, 0); | 917 | lapic_timer_state_broadcast(pr, cx, 0); |
921 | cx->time += sleep_ticks; | 918 | cx->time += idle_time; |
922 | return idle_time; | 919 | return idle_time; |
923 | } | 920 | } |
924 | 921 | ||
@@ -940,7 +937,6 @@ static int acpi_idle_enter_bm(struct cpuidle_device *dev, | |||
940 | ktime_t kt1, kt2; | 937 | ktime_t kt1, kt2; |
941 | s64 idle_time_ns; | 938 | s64 idle_time_ns; |
942 | s64 idle_time; | 939 | s64 idle_time; |
943 | s64 sleep_ticks = 0; | ||
944 | 940 | ||
945 | 941 | ||
946 | pr = __get_cpu_var(processors); | 942 | pr = __get_cpu_var(processors); |
@@ -1026,7 +1022,6 @@ static int acpi_idle_enter_bm(struct cpuidle_device *dev, | |||
1026 | idle_time = idle_time_ns; | 1022 | idle_time = idle_time_ns; |
1027 | do_div(idle_time, NSEC_PER_USEC); | 1023 | do_div(idle_time, NSEC_PER_USEC); |
1028 | 1024 | ||
1029 | sleep_ticks = us_to_pm_timer_ticks(idle_time); | ||
1030 | /* Tell the scheduler how much we idled: */ | 1025 | /* Tell the scheduler how much we idled: */ |
1031 | sched_clock_idle_wakeup_event(idle_time_ns); | 1026 | sched_clock_idle_wakeup_event(idle_time_ns); |
1032 | 1027 | ||
@@ -1037,7 +1032,7 @@ static int acpi_idle_enter_bm(struct cpuidle_device *dev, | |||
1037 | cx->usage++; | 1032 | cx->usage++; |
1038 | 1033 | ||
1039 | lapic_timer_state_broadcast(pr, cx, 0); | 1034 | lapic_timer_state_broadcast(pr, cx, 0); |
1040 | cx->time += sleep_ticks; | 1035 | cx->time += idle_time; |
1041 | return idle_time; | 1036 | return idle_time; |
1042 | } | 1037 | } |
1043 | 1038 | ||