diff options
author | Bob Moore <robert.moore@intel.com> | 2012-02-14 05:57:13 -0500 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2012-03-22 01:45:05 -0400 |
commit | 72a8887a356076dfa39bd6691c52446f90a50480 (patch) | |
tree | 6cdf2e3f228b8482273029066554d57c7095a405 /drivers/acpi | |
parent | 709585765734e90d9fe0a2dc9c6f4e49eff5c6ec (diff) |
ACPICA: Add table-driven dispatch for sleep/wake functions
Simplifies the code, especially the compile-time
ACPI_REDUCED_HARDWARE option.
Signed-off-by: Bob Moore <robert.moore@intel.com>
Signed-off-by: Lin Ming <ming.m.lin@intel.com>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'drivers/acpi')
-rw-r--r-- | drivers/acpi/acpica/acmacros.h | 6 | ||||
-rw-r--r-- | drivers/acpi/acpica/hwxfsleep.c | 136 |
2 files changed, 88 insertions, 54 deletions
diff --git a/drivers/acpi/acpica/acmacros.h b/drivers/acpi/acpica/acmacros.h index ef338a96f5b2..f119f473f71a 100644 --- a/drivers/acpi/acpica/acmacros.h +++ b/drivers/acpi/acpica/acmacros.h | |||
@@ -516,6 +516,12 @@ | |||
516 | 516 | ||
517 | #endif /* ACPI_DEBUG_OUTPUT */ | 517 | #endif /* ACPI_DEBUG_OUTPUT */ |
518 | 518 | ||
519 | #if (!ACPI_REDUCED_HARDWARE) | ||
520 | #define ACPI_HW_OPTIONAL_FUNCTION(addr) addr | ||
521 | #else | ||
522 | #define ACPI_HW_OPTIONAL_FUNCTION(addr) NULL | ||
523 | #endif | ||
524 | |||
519 | /* | 525 | /* |
520 | * Some code only gets executed when the debugger is built in. | 526 | * Some code only gets executed when the debugger is built in. |
521 | * Note that this is entirely independent of whether the | 527 | * Note that this is entirely independent of whether the |
diff --git a/drivers/acpi/acpica/hwxfsleep.c b/drivers/acpi/acpica/hwxfsleep.c index ff2055804809..b711f97c9a87 100644 --- a/drivers/acpi/acpica/hwxfsleep.c +++ b/drivers/acpi/acpica/hwxfsleep.c | |||
@@ -48,6 +48,34 @@ | |||
48 | #define _COMPONENT ACPI_HARDWARE | 48 | #define _COMPONENT ACPI_HARDWARE |
49 | ACPI_MODULE_NAME("hwxfsleep") | 49 | ACPI_MODULE_NAME("hwxfsleep") |
50 | 50 | ||
51 | /* Local prototypes */ | ||
52 | static acpi_status acpi_hw_sleep_dispatch(u8 sleep_state, u32 function_id); | ||
53 | |||
54 | /* | ||
55 | * Dispatch table used to efficiently branch to the various sleep | ||
56 | * functions. | ||
57 | */ | ||
58 | #define ACPI_SLEEP_FUNCTION 0 | ||
59 | #define ACPI_WAKE_PREP_FUNCTION 1 | ||
60 | #define ACPI_WAKE_FUNCTION 2 | ||
61 | |||
62 | /* Legacy functions are optional, based upon ACPI_REDUCED_HARDWARE */ | ||
63 | |||
64 | static struct acpi_sleep_functions acpi_sleep_dispatch[] = { | ||
65 | {ACPI_HW_OPTIONAL_FUNCTION(acpi_hw_legacy_sleep), | ||
66 | acpi_hw_extended_sleep}, | ||
67 | {ACPI_HW_OPTIONAL_FUNCTION(acpi_hw_legacy_wake_prep), | ||
68 | acpi_hw_extended_wake_prep}, | ||
69 | {ACPI_HW_OPTIONAL_FUNCTION(acpi_hw_legacy_wake), acpi_hw_extended_wake} | ||
70 | }; | ||
71 | |||
72 | /* | ||
73 | * These functions are removed for the ACPI_REDUCED_HARDWARE case: | ||
74 | * acpi_set_firmware_waking_vector | ||
75 | * acpi_set_firmware_waking_vector64 | ||
76 | * acpi_enter_sleep_state_s4bios | ||
77 | */ | ||
78 | |||
51 | #if (!ACPI_REDUCED_HARDWARE) | 79 | #if (!ACPI_REDUCED_HARDWARE) |
52 | /******************************************************************************* | 80 | /******************************************************************************* |
53 | * | 81 | * |
@@ -61,6 +89,7 @@ ACPI_MODULE_NAME("hwxfsleep") | |||
61 | * DESCRIPTION: Sets the 32-bit firmware_waking_vector field of the FACS | 89 | * DESCRIPTION: Sets the 32-bit firmware_waking_vector field of the FACS |
62 | * | 90 | * |
63 | ******************************************************************************/ | 91 | ******************************************************************************/ |
92 | |||
64 | acpi_status acpi_set_firmware_waking_vector(u32 physical_address) | 93 | acpi_status acpi_set_firmware_waking_vector(u32 physical_address) |
65 | { | 94 | { |
66 | ACPI_FUNCTION_TRACE(acpi_set_firmware_waking_vector); | 95 | ACPI_FUNCTION_TRACE(acpi_set_firmware_waking_vector); |
@@ -193,18 +222,65 @@ ACPI_EXPORT_SYMBOL(acpi_enter_sleep_state_s4bios) | |||
193 | #endif /* !ACPI_REDUCED_HARDWARE */ | 222 | #endif /* !ACPI_REDUCED_HARDWARE */ |
194 | /******************************************************************************* | 223 | /******************************************************************************* |
195 | * | 224 | * |
225 | * FUNCTION: acpi_hw_sleep_dispatch | ||
226 | * | ||
227 | * PARAMETERS: sleep_state - Which sleep state to enter/exit | ||
228 | * function_id - Sleep, wake_prep, or Wake | ||
229 | * | ||
230 | * RETURN: Status from the invoked sleep handling function. | ||
231 | * | ||
232 | * DESCRIPTION: Dispatch a sleep/wake request to the appropriate handling | ||
233 | * function. | ||
234 | * | ||
235 | ******************************************************************************/ | ||
236 | static acpi_status acpi_hw_sleep_dispatch(u8 sleep_state, u32 function_id) | ||
237 | { | ||
238 | acpi_status status; | ||
239 | struct acpi_sleep_functions *sleep_functions = | ||
240 | &acpi_sleep_dispatch[function_id]; | ||
241 | |||
242 | #if (!ACPI_REDUCED_HARDWARE) | ||
243 | |||
244 | /* | ||
245 | * If the Hardware Reduced flag is set (from the FADT), we must | ||
246 | * use the extended sleep registers | ||
247 | */ | ||
248 | if (acpi_gbl_reduced_hardware || acpi_gbl_FADT.sleep_control.address) { | ||
249 | status = sleep_functions->extended_function(sleep_state); | ||
250 | } else { | ||
251 | /* Legacy sleep */ | ||
252 | |||
253 | status = sleep_functions->legacy_function(sleep_state); | ||
254 | } | ||
255 | |||
256 | return (status); | ||
257 | |||
258 | #else | ||
259 | /* | ||
260 | * For the case where reduced-hardware-only code is being generated, | ||
261 | * we know that only the extended sleep registers are available | ||
262 | */ | ||
263 | status = sleep_functions->extended_function(sleep_state); | ||
264 | return (status); | ||
265 | |||
266 | #endif /* !ACPI_REDUCED_HARDWARE */ | ||
267 | } | ||
268 | |||
269 | /******************************************************************************* | ||
270 | * | ||
196 | * FUNCTION: acpi_enter_sleep_state_prep | 271 | * FUNCTION: acpi_enter_sleep_state_prep |
197 | * | 272 | * |
198 | * PARAMETERS: sleep_state - Which sleep state to enter | 273 | * PARAMETERS: sleep_state - Which sleep state to enter |
199 | * | 274 | * |
200 | * RETURN: Status | 275 | * RETURN: Status |
201 | * | 276 | * |
202 | * DESCRIPTION: Prepare to enter a system sleep state (see ACPI 2.0 spec p 231) | 277 | * DESCRIPTION: Prepare to enter a system sleep state. |
203 | * This function must execute with interrupts enabled. | 278 | * This function must execute with interrupts enabled. |
204 | * We break sleeping into 2 stages so that OSPM can handle | 279 | * We break sleeping into 2 stages so that OSPM can handle |
205 | * various OS-specific tasks between the two steps. | 280 | * various OS-specific tasks between the two steps. |
206 | * | 281 | * |
207 | ******************************************************************************/ | 282 | ******************************************************************************/ |
283 | |||
208 | acpi_status acpi_enter_sleep_state_prep(u8 sleep_state) | 284 | acpi_status acpi_enter_sleep_state_prep(u8 sleep_state) |
209 | { | 285 | { |
210 | acpi_status status; | 286 | acpi_status status; |
@@ -291,23 +367,8 @@ acpi_status asmlinkage acpi_enter_sleep_state(u8 sleep_state) | |||
291 | acpi_gbl_sleep_type_a, acpi_gbl_sleep_type_b)); | 367 | acpi_gbl_sleep_type_a, acpi_gbl_sleep_type_b)); |
292 | return_ACPI_STATUS(AE_AML_OPERAND_VALUE); | 368 | return_ACPI_STATUS(AE_AML_OPERAND_VALUE); |
293 | } | 369 | } |
294 | #if (!ACPI_REDUCED_HARDWARE) | ||
295 | |||
296 | /* If Hardware Reduced flag is set, must use the extended sleep registers */ | ||
297 | |||
298 | if (acpi_gbl_reduced_hardware || acpi_gbl_FADT.sleep_control.address) { | ||
299 | status = acpi_hw_extended_sleep(sleep_state); | ||
300 | } else { | ||
301 | /* Legacy sleep */ | ||
302 | |||
303 | status = acpi_hw_legacy_sleep(sleep_state); | ||
304 | } | ||
305 | |||
306 | #else | ||
307 | status = acpi_hw_extended_sleep(sleep_state); | ||
308 | |||
309 | #endif /* !ACPI_REDUCED_HARDWARE */ | ||
310 | 370 | ||
371 | status = acpi_hw_sleep_dispatch(sleep_state, ACPI_SLEEP_FUNCTION); | ||
311 | return_ACPI_STATUS(status); | 372 | return_ACPI_STATUS(status); |
312 | } | 373 | } |
313 | 374 | ||
@@ -330,26 +391,9 @@ acpi_status acpi_leave_sleep_state_prep(u8 sleep_state) | |||
330 | { | 391 | { |
331 | acpi_status status; | 392 | acpi_status status; |
332 | 393 | ||
333 | ACPI_FUNCTION_TRACE(acpi_leave_sleep_state); | 394 | ACPI_FUNCTION_TRACE(acpi_leave_sleep_state_prep); |
334 | |||
335 | |||
336 | #if (!ACPI_REDUCED_HARDWARE) | ||
337 | |||
338 | /* If Hardware Reduced flag is set, must use the extended sleep registers */ | ||
339 | |||
340 | if (acpi_gbl_reduced_hardware || acpi_gbl_FADT.sleep_control.address) { | ||
341 | status = acpi_hw_extended_wake_prep(sleep_state); | ||
342 | } else { | ||
343 | /* Legacy sleep */ | ||
344 | |||
345 | status = acpi_hw_legacy_wake_prep(sleep_state); | ||
346 | } | ||
347 | #else | ||
348 | status = acpi_hw_extended_wake_prep(sleep_state); | ||
349 | |||
350 | #endif /* !ACPI_REDUCED_HARDWARE */ | ||
351 | |||
352 | 395 | ||
396 | status = acpi_hw_sleep_dispatch(sleep_state, ACPI_WAKE_PREP_FUNCTION); | ||
353 | return_ACPI_STATUS(status); | 397 | return_ACPI_STATUS(status); |
354 | } | 398 | } |
355 | 399 | ||
@@ -359,7 +403,7 @@ ACPI_EXPORT_SYMBOL(acpi_leave_sleep_state_prep) | |||
359 | * | 403 | * |
360 | * FUNCTION: acpi_leave_sleep_state | 404 | * FUNCTION: acpi_leave_sleep_state |
361 | * | 405 | * |
362 | * PARAMETERS: sleep_state - Which sleep state we just exited | 406 | * PARAMETERS: sleep_state - Which sleep state we are exiting |
363 | * | 407 | * |
364 | * RETURN: Status | 408 | * RETURN: Status |
365 | * | 409 | * |
@@ -374,23 +418,7 @@ acpi_status acpi_leave_sleep_state(u8 sleep_state) | |||
374 | ACPI_FUNCTION_TRACE(acpi_leave_sleep_state); | 418 | ACPI_FUNCTION_TRACE(acpi_leave_sleep_state); |
375 | 419 | ||
376 | 420 | ||
377 | #if (!ACPI_REDUCED_HARDWARE) | 421 | status = acpi_hw_sleep_dispatch(sleep_state, ACPI_WAKE_FUNCTION); |
378 | |||
379 | /* If Hardware Reduced flag is set, must use the extended sleep registers */ | ||
380 | |||
381 | if (acpi_gbl_reduced_hardware || acpi_gbl_FADT.sleep_control.address) { | ||
382 | status = acpi_hw_extended_wake(sleep_state); | ||
383 | } else { | ||
384 | /* Legacy sleep */ | ||
385 | |||
386 | status = acpi_hw_legacy_wake(sleep_state); | ||
387 | } | ||
388 | |||
389 | #else | ||
390 | status = acpi_hw_extended_wake(sleep_state); | ||
391 | |||
392 | #endif /* !ACPI_REDUCED_HARDWARE */ | ||
393 | |||
394 | return_ACPI_STATUS(status); | 422 | return_ACPI_STATUS(status); |
395 | } | 423 | } |
396 | 424 | ||