| /* system/debuggerd/utility.h | 
 | ** | 
 | ** Copyright 2008, The Android Open Source Project | 
 | ** | 
 | ** Licensed under the Apache License, Version 2.0 (the "License");  | 
 | ** you may not use this file except in compliance with the License.  | 
 | ** You may obtain a copy of the License at  | 
 | ** | 
 | **     http://www.apache.org/licenses/LICENSE-2.0  | 
 | ** | 
 | ** Unless required by applicable law or agreed to in writing, software  | 
 | ** distributed under the License is distributed on an "AS IS" BASIS,  | 
 | ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  | 
 | ** See the License for the specific language governing permissions and  | 
 | ** limitations under the License. | 
 | */ | 
 |  | 
 | #ifndef _DEBUGGERD_UTILITY_H | 
 | #define _DEBUGGERD_UTILITY_H | 
 |  | 
 | #include <stddef.h> | 
 | #include <stdbool.h> | 
 |  | 
 | typedef struct { | 
 |     /* tombstone file descriptor */ | 
 |     int tfd; | 
 |     /* Activity Manager socket file descriptor */ | 
 |     int amfd; | 
 |     /* if true, does not log anything to the Android logcat or Activity Manager */ | 
 |     bool quiet; | 
 | } log_t; | 
 |  | 
 | /* Log information onto the tombstone.  scopeFlags is a bitmask of the flags defined | 
 |  * here. */ | 
 | void _LOG(log_t* log, int scopeFlags, const char *fmt, ...) | 
 |         __attribute__ ((format(printf, 3, 4))); | 
 |  | 
 | /* The message pertains specifically to the faulting thread / process */ | 
 | #define SCOPE_AT_FAULT (1 << 0) | 
 | /* The message contains sensitive information such as RAM contents */ | 
 | #define SCOPE_SENSITIVE  (1 << 1) | 
 |  | 
 | #define IS_AT_FAULT(x)    (((x) & SCOPE_AT_FAULT) != 0) | 
 | #define IS_SENSITIVE(x)    (((x) & SCOPE_SENSITIVE) != 0) | 
 |  | 
 | /* Further helpful macros */ | 
 | #define LOG(fmt...) _LOG(NULL, SCOPE_AT_FAULT, fmt) | 
 |  | 
 | /* Set to 1 for normal debug traces */ | 
 | #if 0 | 
 | #define XLOG(fmt...) _LOG(NULL, SCOPE_AT_FAULT, fmt) | 
 | #else | 
 | #define XLOG(fmt...) do {} while(0) | 
 | #endif | 
 |  | 
 | /* Set to 1 for chatty debug traces. Includes all resolved dynamic symbols */ | 
 | #if 0 | 
 | #define XLOG2(fmt...) _LOG(NULL, SCOPE_AT_FAULT, fmt) | 
 | #else | 
 | #define XLOG2(fmt...) do {} while(0) | 
 | #endif | 
 |  | 
 | int wait_for_signal(pid_t tid, int* total_sleep_time_usec); | 
 | void wait_for_stop(pid_t tid, int* total_sleep_time_usec); | 
 |  | 
 | #endif // _DEBUGGERD_UTILITY_H |