android 打印机 kernel,android logcat里打印kernel信息

没试过,摘录下来 有空研究下:

1.在Android的源码中(目标路径为:system/core/logcat/logcat.cpp),将其此logcat.cpp文件中的static void readLogLines(int logfd)函数作出如下修改:

2 在如上修改的.cpp文件的头文件中加入如下两个头文件: #include < sys/klog.h> #define KERNEL_TAG "Kernel"

static void readLogLines(int logfd) {

char buffer[256] = {0} ;

while (1) {

unsigned char buf[LOGGER_ENTRY_MAX_LEN + 1] attribute ((aligned(4)));

struct logger_entry *entry = (struct logger_entry *) buf;

int ret;

ret = read(logfd, entry, LOGGER_ENTRY_MAX_LEN);

if (ret < 0) {

if (errno == EINTR)

continue;

if (errno == EAGAIN)

break;

perror("logcat read"); exit(EXIT_FAILURE);

} else if (!ret) {

fprintf(stderr, "read: Unexpected EOF! "); exit(EXIT_FAILURE);

}

/* NOTE: driver guarantees we read exactly one full entry */

entry->msg[entry->len] = '';

if (g_printBinary) {

printBinary(entry);

} else {

(void) processBuffer(entry);

}

/*读入内核调试信息*/ if((ret = klogctl(9, buffer, sizeof(buffer))) > 0) {

if((ret = klogctl(2, buffer, sizeof(buffer))) > 0) {

entry->tid = 0;

entry->pid = getpid();

/*priority*/

entry->msg[0] = ANDROID_LOG_INFO;

/*tag*/

strcpy(entry->msg+1, KERNEL_TAG); /*message*/

strncpy(entry->msg+1+sizeof(KERNEL_TAG), buffer, ret);

entry->len = 1 + sizeof(KERNEL_TAG) + ret + 1;

entry->msg[entry->len] = '';

if (g_printBinary) {

printBinary(entry);

} else {

(void) processBuffer(entry);

}

}

}

}

}

可能要修改init.rc 里的 服务,需要root权限

有空研究一下

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值