radiolog不全的问题

本文分析了MTK设备上TelephonyFramework日志缺失的原因,深入探讨了Rlog及其实现原理,并给出了调试建议。

最近遇到一个bug,发现radio log中大部分信息是没有的,问题根本无法排查。

从telephony framework最常用的Rlog开始分析

frameworks/base/telephony/java/android/telephony/Rlog.java

    public static int d(String tag, String msg) {
        return Log.println_native(Log.LOG_ID_RADIO, Log.DEBUG, tag, msg);
    }
跳转到C++代码

frameworks/base/core/jni/android_util_Log.cpp

static JNINativeMethod gMethods[] = {
    /* name, signature, funcPtr */
    { "isLoggable",      "(Ljava/lang/String;I)Z", (void*) android_util_Log_isLoggable },
    { "println_native",  "(IILjava/lang/String;Ljava/lang/String;)I", (void*) android_util_Log_println_native },
};
对应方法是android_util_Log_println_native

static jint android_util_Log_println_native(JNIEnv* env, jobject clazz,
        jint bufID, jint priority, jstring tagObj, jstring msgObj)
{
    ...
#ifdef HAVE_XLOG_FEATURE
    if (flag_m == 1) {
        if (xlogf_java_xtag_is_on(new_tag, (android_LogPriority)priority)) {
            res = __android_log_buf_write(bufID, (android_LogPriority)priority, new_tag, msg);
        }
    } else if (xlogf_java_tag_is_on(tag, (android_LogPriority)priority)) {
      res = __android_log_buf_write(bufID, (android_LogPriority)priority, tag, msg);
    }
#else
    if (flag_m == 1) {
       res = __android_log_buf_write(bufID, (android_LogPriority)priority, new_tag, msg);
    } else {
       res = __android_log_buf_write(bufID, (android_LogPriority)priority, tag, msg);
    }
#endif
    ...
}
结合日志、代码和测试ROM版本(user版)可以推测出xlogf_java_xtag_is_on是依据优先级判断日志是否输出的,error级别的信息是能够输出的,Debug级别的就无法输出了。参见 android toolbox 中log 工具源码分析,xlogf_java_xtag_is_on是mtk提供的,没有开放源码。所以测问题还是要debug版本的rom啊,或者rilc中直接使用原生的输出方法打印日志,不使用mtk封装的日志方法。


--------------------------------------------------------------------

更新,代码找到了

lib库的在vendor/mediatek/proprietary/external/libxlog

kernal的位置在/drivers/misc/mediatek/xlog

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值