|  | /****************************************************************************** | 
|  | * | 
|  | * Name: acoutput.h -- debug output | 
|  | * | 
|  | *****************************************************************************/ | 
|  |  | 
|  | /* | 
|  | * Copyright (C) 2000 - 2008, Intel Corp. | 
|  | * 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. | 
|  | */ | 
|  |  | 
|  | #ifndef __ACOUTPUT_H__ | 
|  | #define __ACOUTPUT_H__ | 
|  |  | 
|  | /* | 
|  | * Debug levels and component IDs.  These are used to control the | 
|  | * granularity of the output of the DEBUG_PRINT macro -- on a per- | 
|  | * component basis and a per-exception-type basis. | 
|  | */ | 
|  |  | 
|  | /* Component IDs are used in the global "DebugLayer" */ | 
|  |  | 
|  | #define ACPI_UTILITIES              0x00000001 | 
|  | #define ACPI_HARDWARE               0x00000002 | 
|  | #define ACPI_EVENTS                 0x00000004 | 
|  | #define ACPI_TABLES                 0x00000008 | 
|  | #define ACPI_NAMESPACE              0x00000010 | 
|  | #define ACPI_PARSER                 0x00000020 | 
|  | #define ACPI_DISPATCHER             0x00000040 | 
|  | #define ACPI_EXECUTER               0x00000080 | 
|  | #define ACPI_RESOURCES              0x00000100 | 
|  | #define ACPI_CA_DEBUGGER            0x00000200 | 
|  | #define ACPI_OS_SERVICES            0x00000400 | 
|  | #define ACPI_CA_DISASSEMBLER        0x00000800 | 
|  |  | 
|  | /* Component IDs for ACPI tools and utilities */ | 
|  |  | 
|  | #define ACPI_COMPILER               0x00001000 | 
|  | #define ACPI_TOOLS                  0x00002000 | 
|  |  | 
|  | #define ACPI_ALL_COMPONENTS         0x00003FFF | 
|  | #define ACPI_COMPONENT_DEFAULT      (ACPI_ALL_COMPONENTS) | 
|  |  | 
|  | /* Component IDs reserved for ACPI drivers */ | 
|  |  | 
|  | #define ACPI_ALL_DRIVERS            0xFFFF0000 | 
|  |  | 
|  | /* | 
|  | * Raw debug output levels, do not use these in the DEBUG_PRINT macros | 
|  | */ | 
|  | #define ACPI_LV_INIT                0x00000001 | 
|  | #define ACPI_LV_DEBUG_OBJECT        0x00000002 | 
|  | #define ACPI_LV_INFO                0x00000004 | 
|  | #define ACPI_LV_ALL_EXCEPTIONS      0x00000007 | 
|  |  | 
|  | /* Trace verbosity level 1 [Standard Trace Level] */ | 
|  |  | 
|  | #define ACPI_LV_INIT_NAMES          0x00000020 | 
|  | #define ACPI_LV_PARSE               0x00000040 | 
|  | #define ACPI_LV_LOAD                0x00000080 | 
|  | #define ACPI_LV_DISPATCH            0x00000100 | 
|  | #define ACPI_LV_EXEC                0x00000200 | 
|  | #define ACPI_LV_NAMES               0x00000400 | 
|  | #define ACPI_LV_OPREGION            0x00000800 | 
|  | #define ACPI_LV_BFIELD              0x00001000 | 
|  | #define ACPI_LV_TABLES              0x00002000 | 
|  | #define ACPI_LV_VALUES              0x00004000 | 
|  | #define ACPI_LV_OBJECTS             0x00008000 | 
|  | #define ACPI_LV_RESOURCES           0x00010000 | 
|  | #define ACPI_LV_USER_REQUESTS       0x00020000 | 
|  | #define ACPI_LV_PACKAGE             0x00040000 | 
|  | #define ACPI_LV_VERBOSITY1          0x0007FF40 | ACPI_LV_ALL_EXCEPTIONS | 
|  |  | 
|  | /* Trace verbosity level 2 [Function tracing and memory allocation] */ | 
|  |  | 
|  | #define ACPI_LV_ALLOCATIONS         0x00100000 | 
|  | #define ACPI_LV_FUNCTIONS           0x00200000 | 
|  | #define ACPI_LV_OPTIMIZATIONS       0x00400000 | 
|  | #define ACPI_LV_VERBOSITY2          0x00700000 | ACPI_LV_VERBOSITY1 | 
|  | #define ACPI_LV_ALL                 ACPI_LV_VERBOSITY2 | 
|  |  | 
|  | /* Trace verbosity level 3 [Threading, I/O, and Interrupts] */ | 
|  |  | 
|  | #define ACPI_LV_MUTEX               0x01000000 | 
|  | #define ACPI_LV_THREADS             0x02000000 | 
|  | #define ACPI_LV_IO                  0x04000000 | 
|  | #define ACPI_LV_INTERRUPTS          0x08000000 | 
|  | #define ACPI_LV_VERBOSITY3          0x0F000000 | ACPI_LV_VERBOSITY2 | 
|  |  | 
|  | /* Exceptionally verbose output -- also used in the global "DebugLevel"  */ | 
|  |  | 
|  | #define ACPI_LV_AML_DISASSEMBLE     0x10000000 | 
|  | #define ACPI_LV_VERBOSE_INFO        0x20000000 | 
|  | #define ACPI_LV_FULL_TABLES         0x40000000 | 
|  | #define ACPI_LV_EVENTS              0x80000000 | 
|  | #define ACPI_LV_VERBOSE             0xF0000000 | 
|  |  | 
|  | /* | 
|  | * Debug level macros that are used in the DEBUG_PRINT macros | 
|  | */ | 
|  | #define ACPI_DEBUG_LEVEL(dl)        (u32) dl,ACPI_DEBUG_PARAMETERS | 
|  |  | 
|  | /* | 
|  | * Exception level -- used in the global "DebugLevel" | 
|  | * | 
|  | * Note: For errors, use the ACPI_ERROR or ACPI_EXCEPTION interfaces. | 
|  | * For warnings, use ACPI_WARNING. | 
|  | */ | 
|  | #define ACPI_DB_INIT                ACPI_DEBUG_LEVEL (ACPI_LV_INIT) | 
|  | #define ACPI_DB_DEBUG_OBJECT        ACPI_DEBUG_LEVEL (ACPI_LV_DEBUG_OBJECT) | 
|  | #define ACPI_DB_INFO                ACPI_DEBUG_LEVEL (ACPI_LV_INFO) | 
|  | #define ACPI_DB_ALL_EXCEPTIONS      ACPI_DEBUG_LEVEL (ACPI_LV_ALL_EXCEPTIONS) | 
|  |  | 
|  | /* Trace level -- also used in the global "DebugLevel" */ | 
|  |  | 
|  | #define ACPI_DB_INIT_NAMES          ACPI_DEBUG_LEVEL (ACPI_LV_INIT_NAMES) | 
|  | #define ACPI_DB_THREADS             ACPI_DEBUG_LEVEL (ACPI_LV_THREADS) | 
|  | #define ACPI_DB_PARSE               ACPI_DEBUG_LEVEL (ACPI_LV_PARSE) | 
|  | #define ACPI_DB_DISPATCH            ACPI_DEBUG_LEVEL (ACPI_LV_DISPATCH) | 
|  | #define ACPI_DB_LOAD                ACPI_DEBUG_LEVEL (ACPI_LV_LOAD) | 
|  | #define ACPI_DB_EXEC                ACPI_DEBUG_LEVEL (ACPI_LV_EXEC) | 
|  | #define ACPI_DB_NAMES               ACPI_DEBUG_LEVEL (ACPI_LV_NAMES) | 
|  | #define ACPI_DB_OPREGION            ACPI_DEBUG_LEVEL (ACPI_LV_OPREGION) | 
|  | #define ACPI_DB_BFIELD              ACPI_DEBUG_LEVEL (ACPI_LV_BFIELD) | 
|  | #define ACPI_DB_TABLES              ACPI_DEBUG_LEVEL (ACPI_LV_TABLES) | 
|  | #define ACPI_DB_FUNCTIONS           ACPI_DEBUG_LEVEL (ACPI_LV_FUNCTIONS) | 
|  | #define ACPI_DB_OPTIMIZATIONS       ACPI_DEBUG_LEVEL (ACPI_LV_OPTIMIZATIONS) | 
|  | #define ACPI_DB_VALUES              ACPI_DEBUG_LEVEL (ACPI_LV_VALUES) | 
|  | #define ACPI_DB_OBJECTS             ACPI_DEBUG_LEVEL (ACPI_LV_OBJECTS) | 
|  | #define ACPI_DB_ALLOCATIONS         ACPI_DEBUG_LEVEL (ACPI_LV_ALLOCATIONS) | 
|  | #define ACPI_DB_RESOURCES           ACPI_DEBUG_LEVEL (ACPI_LV_RESOURCES) | 
|  | #define ACPI_DB_IO                  ACPI_DEBUG_LEVEL (ACPI_LV_IO) | 
|  | #define ACPI_DB_INTERRUPTS          ACPI_DEBUG_LEVEL (ACPI_LV_INTERRUPTS) | 
|  | #define ACPI_DB_USER_REQUESTS       ACPI_DEBUG_LEVEL (ACPI_LV_USER_REQUESTS) | 
|  | #define ACPI_DB_PACKAGE             ACPI_DEBUG_LEVEL (ACPI_LV_PACKAGE) | 
|  | #define ACPI_DB_MUTEX               ACPI_DEBUG_LEVEL (ACPI_LV_MUTEX) | 
|  | #define ACPI_DB_EVENTS              ACPI_DEBUG_LEVEL (ACPI_LV_EVENTS) | 
|  |  | 
|  | #define ACPI_DB_ALL                 ACPI_DEBUG_LEVEL (ACPI_LV_ALL) | 
|  |  | 
|  | /* Defaults for debug_level, debug and normal */ | 
|  |  | 
|  | #define ACPI_DEBUG_DEFAULT          (ACPI_LV_INIT | ACPI_LV_DEBUG_OBJECT) | 
|  | #define ACPI_NORMAL_DEFAULT         (ACPI_LV_INIT | ACPI_LV_DEBUG_OBJECT) | 
|  | #define ACPI_DEBUG_ALL              (ACPI_LV_AML_DISASSEMBLE | ACPI_LV_ALL_EXCEPTIONS | ACPI_LV_ALL) | 
|  |  | 
|  | #endif				/* __ACOUTPUT_H__ */ |