userdebug版本开机串口log打开

本文介绍如何在mt_boot.c文件中修改代码,通过设置printk.disable_uart参数为0来启用UART打印功能,这对于调试嵌入式系统非常重要。

在/bootable/bootloader/lk/app/mt_boot/mt_boot.c里修改:
if (!has_set_p2u) {
#ifdef USER_BUILD
sprintf(cmdline,"%s%s",cmdline," printk.disable_uart=1"); // printk.disable_uart=1 改为0
#else
sprintf(cmdline,"%s%s",cmdline," printk.disable_uart=0 ddebug_query=\"file *mediatek* +p ; file *gpu* =_\"");
#endif

转载于:https://www.cnblogs.com/Ph-one/p/5945005.html

<think>嗯,用户想在MTK Android平台上配置DebugLoggerUI,实现开机后自动抓取日志。我需要先回忆一下之前相关的引用资料,看看有没有相关的配置方法。 根据引用[1]提到在Android10下拿掉DebugLoggerUI的方法,可能需要修改工程模式相关的代码。而引用[4]中的DebugLoggerUI设置,用户需要开启mobilelog并删除旧日志。不过用户现在需要的是开机自动抓log,这可能涉及到系统默认配置的修改。 引用[3]提到在userdebug和eng版本中默认开启串口日志,可能需要检查内核配置。但用户可能是在user版本上操作,这时候可能需要通过暗码或者修改系统属性来开启。 然后引用[2]是关于在user版本打开MtkLog功能,通过修改AndroidManifest.xml添加暗码入口。这可能和自动启动相关,但用户需要的是自动抓取,而不是手动输入暗码进入。 可能需要找到系统启动时自动启用DebugLoggerUI的机制。例如,是否有系统属性或者配置文件可以设置自动启动日志记录。另外,检查是否有init.rc脚本或者服务负责启动日志服务,可以在这里添加启动命令。 另外,用户可能需要修改系统属性persist.sys.debuglogger.autostart或者类似的属性,设为1来启用自动启动。同时,确保日志路径正确,并且有足够的存储空间。 可能还需要在设备启动后自动执行adb命令来启动日志记录,但需要考虑权限问题,尤其是在user版本上可能需要签名或者系统权限。 总结一下,步骤可能包括:修改系统属性、配置init脚本、调整内核参数,以及处理权限问题。需要确保每一步都正确,并且适用于目标设备的Android版本和MTK平台。</think>### MTK Android DebugLoggerUI 开机自动抓Log配置方法 #### 一、内核配置调整 对于MTK平台,首先需确保内核层已启用UART日志输出功能: ```makefile # kernel-5.10/arch/$(ARCH)/configs/mgk_xxxx_defconfig CONFIG_MTK_PRINTK_UART_CONSOLE=y CONFIG_LOG_BUF_SHIFT=19 ``` 该配置确保系统启动阶段即开启日志缓冲[^3] #### 二、系统属性配置 在`/vendor/default.prop`或`/system/build.prop`中添加: ``` persist.sys.debuglogger.enable=1 persist.sys.debuglogger.autostart=1 persist.logd.logpersistd=logcatd ``` 该属性设置会触发init进程自动加载日志服务[^2] #### 三、EngineerMode模块修改 1. 修改工程模式入口配置: ```xml <!-- vendor/mediatek/proprietary/packages/apps/EngineerMode/AndroidManifest.xml --> <intent-filter> <data android:scheme="android_secret_code" android:host="3646633" /> <data android:scheme="android_secret_code" android:host="9527686" /> </intent-filter> ``` 2. 在`/vendor/mediatek/proprietary/packages/apps/EngineerMode/src/com/mediatek/engineermode/debuglogger/DebugLoggerUi.java`中添加: ```java @Override protected void onResume() { super.onResume(); if (getIntent().getAction().equals(Intent.ACTION_BOOT_COMPLETED)) { startLoggingAutomatically(); } } ``` #### 四、日志存储配置 在`/vendor/mediatek/proprietary/external/mtklog/LogPlot/DebugLoggerService.java`中设置: ```java private static final String AUTO_START_FLAG = "persist.debuglogger.autostart"; private static final String LOG_PATH = "/sdcard/mtklog/mobilelog"; ``` #### 五、SELinux权限配置 在`/device/mediatek/sepolicy/vendor/debuglogger.te`添加: ``` allow debuglogger system_file:dir { search write }; allow debuglogger sdcardfs:file { create write }; ``` #### 六、验证方法 开机后执行: ```bash adb shell dumpsys activity service DebugLoggerService ``` 应看到`isAutoStart=true`和`currentLogPath=/sdcard/mtklog/mobilelog`状态
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值