Blame view
drivers/acpi/acpica/hwtimer.c
6.12 KB
1da177e4c
|
1 2 3 4 5 6 7 8 |
/****************************************************************************** * * Name: hwtimer.c - ACPI Power Management Timer Interface * *****************************************************************************/ /* |
75a44ce00
|
9 |
* Copyright (C) 2000 - 2008, Intel Corp. |
1da177e4c
|
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 |
* All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions, and the following disclaimer, * without modification. * 2. Redistributions in binary form must reproduce at minimum a disclaimer * substantially similar to the "NO WARRANTY" disclaimer below * ("Disclaimer") and any redistribution must be conditioned upon * including a substantially similar Disclaimer requirement for further * binary redistribution. * 3. Neither the names of the above-listed copyright holders nor the names * of any contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * Alternatively, this software may be distributed under the terms of the * GNU General Public License ("GPL") version 2 as published by the Free * Software Foundation. * * NO WARRANTY * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGES. */ |
1da177e4c
|
44 |
#include <acpi/acpi.h> |
e2f7a7772
|
45 |
#include "accommon.h" |
1da177e4c
|
46 47 |
#define _COMPONENT ACPI_HARDWARE |
4be44fcd3
|
48 |
ACPI_MODULE_NAME("hwtimer") |
1da177e4c
|
49 50 51 52 53 54 55 56 57 58 59 60 |
/****************************************************************************** * * FUNCTION: acpi_get_timer_resolution * * PARAMETERS: Resolution - Where the resolution is returned * * RETURN: Status and timer resolution * * DESCRIPTION: Obtains resolution of the ACPI PM Timer (24 or 32 bits). * ******************************************************************************/ |
4be44fcd3
|
61 |
acpi_status acpi_get_timer_resolution(u32 * resolution) |
1da177e4c
|
62 |
{ |
b229cf92e
|
63 |
ACPI_FUNCTION_TRACE(acpi_get_timer_resolution); |
1da177e4c
|
64 65 |
if (!resolution) { |
4be44fcd3
|
66 |
return_ACPI_STATUS(AE_BAD_PARAMETER); |
1da177e4c
|
67 |
} |
f3d2e7865
|
68 |
if ((acpi_gbl_FADT.flags & ACPI_FADT_32BIT_TIMER) == 0) { |
1da177e4c
|
69 |
*resolution = 24; |
4be44fcd3
|
70 |
} else { |
1da177e4c
|
71 72 |
*resolution = 32; } |
4be44fcd3
|
73 |
return_ACPI_STATUS(AE_OK); |
1da177e4c
|
74 |
} |
8313524a0
|
75 |
ACPI_EXPORT_SYMBOL(acpi_get_timer_resolution) |
1da177e4c
|
76 77 78 79 80 81 |
/****************************************************************************** * * FUNCTION: acpi_get_timer * * PARAMETERS: Ticks - Where the timer value is returned * |
44f6c0124
|
82 |
* RETURN: Status and current timer value (ticks) |
1da177e4c
|
83 84 85 86 |
* * DESCRIPTION: Obtains current value of ACPI PM Timer (in ticks). * ******************************************************************************/ |
4be44fcd3
|
87 |
acpi_status acpi_get_timer(u32 * ticks) |
1da177e4c
|
88 |
{ |
4be44fcd3
|
89 |
acpi_status status; |
1da177e4c
|
90 |
|
b229cf92e
|
91 |
ACPI_FUNCTION_TRACE(acpi_get_timer); |
1da177e4c
|
92 93 |
if (!ticks) { |
4be44fcd3
|
94 |
return_ACPI_STATUS(AE_BAD_PARAMETER); |
1da177e4c
|
95 |
} |
f3d2e7865
|
96 |
status = |
c6b5774ca
|
97 |
acpi_hw_read(ticks, &acpi_gbl_FADT.xpm_timer_block); |
1da177e4c
|
98 |
|
4be44fcd3
|
99 |
return_ACPI_STATUS(status); |
1da177e4c
|
100 |
} |
1da177e4c
|
101 |
|
8313524a0
|
102 |
ACPI_EXPORT_SYMBOL(acpi_get_timer) |
1da177e4c
|
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 |
/****************************************************************************** * * FUNCTION: acpi_get_timer_duration * * PARAMETERS: start_ticks - Starting timestamp * end_ticks - End timestamp * time_elapsed - Where the elapsed time is returned * * RETURN: Status and time_elapsed * * DESCRIPTION: Computes the time elapsed (in microseconds) between two * PM Timer time stamps, taking into account the possibility of * rollovers, the timer resolution, and timer frequency. * * The PM Timer's clock ticks at roughly 3.6 times per * _microsecond_, and its clock continues through Cx state * transitions (unlike many CPU timestamp counters) -- making it * a versatile and accurate timer. * * Note that this function accommodates only a single timer * rollover. Thus for 24-bit timers, this function should only * be used for calculating durations less than ~4.6 seconds * (~20 minutes for 32-bit timers) -- calculations below: * * 2**24 Ticks / 3,600,000 Ticks/Sec = 4.66 sec * 2**32 Ticks / 3,600,000 Ticks/Sec = 1193 sec or 19.88 minutes * ******************************************************************************/ |
1da177e4c
|
132 |
acpi_status |
4be44fcd3
|
133 |
acpi_get_timer_duration(u32 start_ticks, u32 end_ticks, u32 * time_elapsed) |
1da177e4c
|
134 |
{ |
4be44fcd3
|
135 136 137 |
acpi_status status; u32 delta_ticks; acpi_integer quotient; |
1da177e4c
|
138 |
|
b229cf92e
|
139 |
ACPI_FUNCTION_TRACE(acpi_get_timer_duration); |
1da177e4c
|
140 141 |
if (!time_elapsed) { |
4be44fcd3
|
142 |
return_ACPI_STATUS(AE_BAD_PARAMETER); |
1da177e4c
|
143 144 145 146 147 148 149 150 |
} /* * Compute Tick Delta: * Handle (max one) timer rollovers on 24-bit versus 32-bit timers. */ if (start_ticks < end_ticks) { delta_ticks = end_ticks - start_ticks; |
4be44fcd3
|
151 |
} else if (start_ticks > end_ticks) { |
f3d2e7865
|
152 |
if ((acpi_gbl_FADT.flags & ACPI_FADT_32BIT_TIMER) == 0) { |
52fc0b026
|
153 |
|
1da177e4c
|
154 |
/* 24-bit Timer */ |
4be44fcd3
|
155 156 157 158 |
delta_ticks = (((0x00FFFFFF - start_ticks) + end_ticks) & 0x00FFFFFF); } else { |
1da177e4c
|
159 160 161 162 |
/* 32-bit Timer */ delta_ticks = (0xFFFFFFFF - start_ticks) + end_ticks; } |
4be44fcd3
|
163 |
} else { /* start_ticks == end_ticks */ |
1da177e4c
|
164 |
*time_elapsed = 0; |
4be44fcd3
|
165 |
return_ACPI_STATUS(AE_OK); |
1da177e4c
|
166 167 168 169 170 171 172 |
} /* * Compute Duration (Requires a 64-bit multiply and divide): * * time_elapsed = (delta_ticks * 1000000) / PM_TIMER_FREQUENCY; */ |
4be44fcd3
|
173 174 |
status = acpi_ut_short_divide(((u64) delta_ticks) * 1000000, PM_TIMER_FREQUENCY, "ient, NULL); |
1da177e4c
|
175 176 |
*time_elapsed = (u32) quotient; |
4be44fcd3
|
177 |
return_ACPI_STATUS(status); |
1da177e4c
|
178 |
} |
44f6c0124
|
179 |
|
8313524a0
|
180 |
ACPI_EXPORT_SYMBOL(acpi_get_timer_duration) |