053b865412
Provides a new mechanism for dumpstate (while running as root) to request that debuggerd dump the stacks of native processes that we care about in bug reports. In this mode, the backtrace is formatted to look similar to a Dalvik backtrace. Moved the tombstone generating code into a separate file to make it easier to maintain. Fixed a bug where sometimes the stack traces would be incomplete because we were not waiting for each thread to stop after issuing PTRACE_ATTACH, only the main thread. So sometimes we were missing traces for some threads. Refactored the logging code to prevent accidentally writing data to logcat when explicitly dumping a tombstone or backtrace from the console. Only root or system server can request to dump backtraces but only root can dump tombstones. Bug: 6615693 Change-Id: Ib3edcc16f9f3a687e414e3f2d250d9500566123b
54 lines
1.5 KiB
C
54 lines
1.5 KiB
C
/* 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;
|
|
/* if true, does not log anything to the Android logcat */
|
|
bool quiet;
|
|
} log_t;
|
|
|
|
/* Log information onto the tombstone. */
|
|
void _LOG(log_t* log, bool in_tombstone_only, const char *fmt, ...)
|
|
__attribute__ ((format(printf, 3, 4)));
|
|
|
|
#define LOG(fmt...) _LOG(NULL, 0, fmt)
|
|
|
|
/* Set to 1 for normal debug traces */
|
|
#if 0
|
|
#define XLOG(fmt...) _LOG(NULL, 0, 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, 0, 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
|