2009-03-04 11:32:55 +08:00
|
|
|
/* 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.
|
|
|
|
*/
|
|
|
|
|
2011-10-22 03:14:56 +08:00
|
|
|
#ifndef _DEBUGGERD_UTILITY_H
|
|
|
|
#define _DEBUGGERD_UTILITY_H
|
2009-03-04 11:32:55 +08:00
|
|
|
|
2013-12-19 00:44:24 +08:00
|
|
|
#include <inttypes.h>
|
2009-03-04 11:32:55 +08:00
|
|
|
#include <stdbool.h>
|
2013-12-19 00:44:24 +08:00
|
|
|
#include <stddef.h>
|
2012-06-07 07:25:03 +08:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
/* tombstone file descriptor */
|
|
|
|
int tfd;
|
2013-03-20 04:12:23 +08:00
|
|
|
/* Activity Manager socket file descriptor */
|
|
|
|
int amfd;
|
|
|
|
/* if true, does not log anything to the Android logcat or Activity Manager */
|
2012-06-07 07:25:03 +08:00
|
|
|
bool quiet;
|
|
|
|
} log_t;
|
2009-03-04 11:32:55 +08:00
|
|
|
|
2013-04-03 05:00:27 +08:00
|
|
|
/* Log information onto the tombstone. scopeFlags is a bitmask of the flags defined
|
|
|
|
* here. */
|
|
|
|
void _LOG(log_t* log, int scopeFlags, const char *fmt, ...)
|
2011-10-22 03:14:56 +08:00
|
|
|
__attribute__ ((format(printf, 3, 4)));
|
2011-09-23 07:37:06 +08:00
|
|
|
|
2013-04-03 05:00:27 +08:00
|
|
|
/* 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)
|
2011-01-26 22:11:04 +08:00
|
|
|
|
|
|
|
/* Set to 1 for normal debug traces */
|
2010-10-14 05:21:30 +08:00
|
|
|
#if 0
|
2013-04-03 05:00:27 +08:00
|
|
|
#define XLOG(fmt...) _LOG(NULL, SCOPE_AT_FAULT, fmt)
|
2010-10-14 05:21:30 +08:00
|
|
|
#else
|
|
|
|
#define XLOG(fmt...) do {} while(0)
|
|
|
|
#endif
|
|
|
|
|
2011-01-26 22:11:04 +08:00
|
|
|
/* Set to 1 for chatty debug traces. Includes all resolved dynamic symbols */
|
|
|
|
#if 0
|
2013-04-03 05:00:27 +08:00
|
|
|
#define XLOG2(fmt...) _LOG(NULL, SCOPE_AT_FAULT, fmt)
|
2011-01-26 22:11:04 +08:00
|
|
|
#else
|
|
|
|
#define XLOG2(fmt...) do {} while(0)
|
|
|
|
#endif
|
|
|
|
|
2013-12-19 00:44:24 +08:00
|
|
|
#if __LP64__
|
|
|
|
#define PRIPTR "016" PRIxPTR
|
|
|
|
typedef uint64_t word_t;
|
|
|
|
#else
|
|
|
|
#define PRIPTR "08" PRIxPTR
|
|
|
|
typedef uint32_t word_t;
|
|
|
|
#endif
|
|
|
|
|
2012-06-07 07:25:03 +08:00
|
|
|
int wait_for_signal(pid_t tid, int* total_sleep_time_usec);
|
|
|
|
void wait_for_stop(pid_t tid, int* total_sleep_time_usec);
|
2011-10-22 03:14:56 +08:00
|
|
|
|
2013-12-19 00:44:24 +08:00
|
|
|
void dump_memory(log_t* log, pid_t tid, uintptr_t addr, int scope_flags);
|
|
|
|
|
2011-10-22 03:14:56 +08:00
|
|
|
#endif // _DEBUGGERD_UTILITY_H
|