Подтвердить что ты не робот

Как получить Verbose logging в logcat для определенного модуля

Один из андроидных модулей (AudioFlinger) поддерживает многостраничное ведение журнала (с помощью Tag = AudioFlinger). Вопрос в том, как я могу увидеть эти журналы в logcat?

Я сделал setprop log.tag.AudioFlinger VERBOSE - но он не работает. Нужно ли мне что-то менять, а затем снова восстановить источник Android?

4b9b3361

Ответ 1

Документация logcat действительно не помогает. Но с большим количеством копаний я смог найти ответ, так как я ожидал, что ведение журнала VERBOSE по умолчанию выключено во время компиляции.

Взгляд на cutils/log.h помогает найти ответ: http://www.netmite.com/android/mydroid/system/core/include/cutils/log.h

/*
 * Normally we strip LOGV (VERBOSE messages) from release builds.
 * You can modify this (for example with "#define LOG_NDEBUG 0"
 * at the top of your source file) to change that behavior.
 */

Итак, чтобы включить VERBOSE для любого исходного файла/модуля: мы должны определить LOG_NDEBUG как 0

Ответ 2

Используйте любой из приведенных ниже методов.

1) Add or uncomment "`#define LOG_NDEBUG 0`" at top of any module file.
2) In Android.mk or <module>.mk file, add `LOCAL_CFLAGS += -DLOG_NDEBUG=0`

In logcat, logcat | grep -E 'tag1|tag2'.