diff options
Diffstat (limited to 'include/acpi')
-rw-r--r-- | include/acpi/acoutput.h | 36 |
1 files changed, 20 insertions, 16 deletions
diff --git a/include/acpi/acoutput.h b/include/acpi/acoutput.h index 23db272e0bff..b48cb3459778 100644 --- a/include/acpi/acoutput.h +++ b/include/acpi/acoutput.h | |||
@@ -281,7 +281,16 @@ | |||
281 | * debug message outside of the print function itself. This improves overall | 281 | * debug message outside of the print function itself. This improves overall |
282 | * performance at a relatively small code cost. Implementation involves the | 282 | * performance at a relatively small code cost. Implementation involves the |
283 | * use of variadic macros supported by C99. | 283 | * use of variadic macros supported by C99. |
284 | * | ||
285 | * Note: the ACPI_DO_WHILE0 macro is used to prevent some compilers from | ||
286 | * complaining about these constructs. On other compilers the do...while | ||
287 | * adds some extra code, so this feature is optional. | ||
284 | */ | 288 | */ |
289 | #ifdef ACPI_USE_DO_WHILE_0 | ||
290 | #define ACPI_DO_WHILE0(a) do a while(0) | ||
291 | #else | ||
292 | #define ACPI_DO_WHILE0(a) a | ||
293 | #endif | ||
285 | 294 | ||
286 | /* DEBUG_PRINT functions */ | 295 | /* DEBUG_PRINT functions */ |
287 | 296 | ||
@@ -290,17 +299,21 @@ | |||
290 | 299 | ||
291 | /* Helper macros for DEBUG_PRINT */ | 300 | /* Helper macros for DEBUG_PRINT */ |
292 | 301 | ||
293 | #define ACPI_DEBUG(function, level, line, filename, modulename, component, ...) \ | 302 | #define ACPI_DO_DEBUG_PRINT(function, level, line, filename, modulename, component, ...) \ |
294 | if (ACPI_IS_DEBUG_ENABLED (level, component)) \ | 303 | ACPI_DO_WHILE0 ({ \ |
295 | { \ | 304 | if (ACPI_IS_DEBUG_ENABLED (level, component)) \ |
296 | function (level, line, filename, modulename, component, __VA_ARGS__); \ | 305 | { \ |
297 | } | 306 | function (level, line, filename, modulename, component, __VA_ARGS__); \ |
307 | } \ | ||
308 | }) | ||
298 | 309 | ||
299 | #define ACPI_ACTUAL_DEBUG(level, line, filename, modulename, component, ...) \ | 310 | #define ACPI_ACTUAL_DEBUG(level, line, filename, modulename, component, ...) \ |
300 | ACPI_DEBUG (acpi_debug_print, level, line, filename, modulename, component, __VA_ARGS__) | 311 | ACPI_DO_DEBUG_PRINT (acpi_debug_print, level, line, \ |
312 | filename, modulename, component, __VA_ARGS__) | ||
301 | 313 | ||
302 | #define ACPI_ACTUAL_DEBUG_RAW(level, line, filename, modulename, component, ...) \ | 314 | #define ACPI_ACTUAL_DEBUG_RAW(level, line, filename, modulename, component, ...) \ |
303 | ACPI_DEBUG (acpi_debug_print_raw, level, line, filename, modulename, component, __VA_ARGS__) | 315 | ACPI_DO_DEBUG_PRINT (acpi_debug_print_raw, level, line, \ |
316 | filename, modulename, component, __VA_ARGS__) | ||
304 | 317 | ||
305 | /* | 318 | /* |
306 | * Function entry tracing | 319 | * Function entry tracing |
@@ -342,16 +355,7 @@ | |||
342 | * | 355 | * |
343 | * One of the FUNCTION_TRACE macros above must be used in conjunction | 356 | * One of the FUNCTION_TRACE macros above must be used in conjunction |
344 | * with these macros so that "_AcpiFunctionName" is defined. | 357 | * with these macros so that "_AcpiFunctionName" is defined. |
345 | * | ||
346 | * Note: the DO_WHILE0 macro is used to prevent some compilers from | ||
347 | * complaining about these constructs. On other compilers the do...while | ||
348 | * adds some extra code, so this feature is optional. | ||
349 | */ | 358 | */ |
350 | #ifdef ACPI_USE_DO_WHILE_0 | ||
351 | #define ACPI_DO_WHILE0(a) do a while(0) | ||
352 | #else | ||
353 | #define ACPI_DO_WHILE0(a) a | ||
354 | #endif | ||
355 | 359 | ||
356 | /* Exit trace helper macro */ | 360 | /* Exit trace helper macro */ |
357 | 361 | ||