0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Kernel Exception(KE)概述

哆啦安全 ? 來源:哆啦安全 ? 2023-07-16 16:38 ? 次閱讀

一、Kernel Exception(KE)概述

Android OS由3層組成,最底層是Kernel,上面是Native bin/lib,最上層是Java層:

ac1f09be-239a-11ee-962d-dac502259ad0.jpg

Android OS 3層結(jié)構(gòu)

任何軟件都有可能發(fā)生異常,比如野指針,跑飛、死鎖等等。

當(dāng)異常發(fā)生在kernel層,我們就叫它為KE(kernel exception),同理,發(fā)生在Native就是NE,Java層就是JE。這篇文章僅關(guān)注底層的KE。

1. KE類別

kernel有以下2種(oops、panic崩潰類別

  1. oops (類似assert,有機(jī)會(huì)恢復(fù))

oops是美國人比較常有的口語。就是有點(diǎn)意外,吃驚,或突然的意思。內(nèi)核行為表現(xiàn)為通知感興趣模塊,打印各種信息,如寄存器值,堆棧信息…

當(dāng)出現(xiàn)oops時(shí),我們就可以根據(jù)寄存器等信息調(diào)試并解決問題。

/proc/sys/kernel/panic_on_oops為1時(shí)導(dǎo)致panic。我們默認(rèn)設(shè)置為1,即oops會(huì)發(fā)生panic。

  • Panic – 困惑,恐慌,它表示Linux kernel遇到了一個(gè)不知道該怎么繼續(xù)的情況。內(nèi)核行為表現(xiàn)為通知感興趣模塊,死機(jī)或者重啟。
    在kernel代碼里,有些代碼加了錯(cuò)誤檢查,發(fā)現(xiàn)錯(cuò)誤可能直接調(diào)用了panic(),并輸出信息提供調(diào)試

  1. panic

2. KE常用調(diào)試方法

凡是程序就有bug。bug總是出現(xiàn)在預(yù)料之外的地方。據(jù)說世界上第一個(gè)bug是繼電器式計(jì)算機(jī)中飛進(jìn)一只蛾子,倒霉的飛蛾夾在繼電器之間導(dǎo)致了計(jì)算機(jī)故障。由于這個(gè)小蟲子,程序中的錯(cuò)誤就被稱為了bug。

有Bug就需要Debug,而調(diào)試是一種很個(gè)性化的工作,十個(gè)人可能有十種調(diào)試方法。但從手段上來講,大致可分為兩類,在線調(diào)試 (Online Debug) 和離線調(diào)試 (Offline Debug).

3.在線調(diào)試

Online debug, 指的是在程序的運(yùn)行過程中監(jiān)視程序的行為,分析是否符合預(yù)期。通常會(huì)借助一些工具,如GDB和Trace32等。有時(shí)候也會(huì)借助一些硬件設(shè)備的協(xié)助,如仿真器/JTAG,但是準(zhǔn)備環(huán)境非常困難,而且用起來也很麻煩,除非一些runtime問題需要外很少使用。

4.離線調(diào)試,

Offline debug, 指的是在程序的運(yùn)行中收集需要的信息,在Bug發(fā)生后根據(jù)收集到的信息來分析的一種手段。通常也分為兩種方式,一種是Logging,一種是Memory Dump。

Logging
日志或者相關(guān)信息的收集,可以比較清晰的看到代碼的執(zhí)行過程,對于邏輯問題是一種有效的分析手段,由于其簡單易操作,也是最為重要的一種分析手法。

Memory Dump
翻譯過來叫做內(nèi)存轉(zhuǎn)儲(chǔ),指的是在異常發(fā)生的時(shí)刻將內(nèi)存信息全部轉(zhuǎn)儲(chǔ)到外部存儲(chǔ)器,即將異常現(xiàn)場信息備份下來以供事后分析。是針對CPU執(zhí)行異常的一種非常有效的分析手段。在Windows平臺(tái),程序異常發(fā)生之后可以選擇啟動(dòng)調(diào)試器來馬上調(diào)試。在Linux平臺(tái),程序發(fā)生異常之后會(huì)轉(zhuǎn)儲(chǔ)core dump,而此coredump可以用調(diào)試器GDB來進(jìn)行調(diào)試。而內(nèi)核的異常也可以進(jìn)行類似的轉(zhuǎn)儲(chǔ)。

二、Kernel空間布局

在分析KE前,你要了解kernel內(nèi)存布局,才知道哪些地址用來做什么,可能會(huì)是什么問題。

在內(nèi)核空間中存在如下重要的段:

1. vmlinux代碼/數(shù)據(jù)段:

任何程序都有TEXT(可執(zhí)行代碼),RW(數(shù)據(jù)段),ZI段(未初始化數(shù)據(jù)段),kernel也有,對應(yīng)的是.text,.data,.bss

2.module區(qū)域:

kernel可以支持ko(模塊),因此需要一段空間用于存儲(chǔ)代碼和數(shù)據(jù)段。

3. vmalloc區(qū)域:

kernel除了可以申請連續(xù)物理地址的內(nèi)存外,還可以申請不連續(xù)的內(nèi)存(虛擬地址是連續(xù)的),可以避免內(nèi)存碎片化而申請不到內(nèi)存。

4. io map區(qū)域:

留給io寄存器映射的區(qū)域,有些版本沒有io map區(qū)域而是直接用vmalloc區(qū)域了。

5.memmap:

kernel是通過page結(jié)構(gòu)體描述內(nèi)存的,每一個(gè)頁框都有對應(yīng)的page結(jié)構(gòu)體,而memmap就是page結(jié)構(gòu)體數(shù)組。

還有其他段小的段沒有列出來,可能根據(jù)不同的版本而差別。

6. ARM64bit kernel布局

目前智能機(jī)已進(jìn)入64bit,因此就存在32bit布局和64bit布局,下面一一講解。

ARM64可以使用多達(dá)48bit物理、虛擬地址(擴(kuò)充成64bit,高位全為1或0)。對linux kernel來講,目前配置為39bit的kernel空間。

由于多達(dá)512GB的空間,因此完全可以將整個(gè)RAM映射進(jìn)來,0xFFFFFFC000000000之后就是一一映射了,就無所謂high memory了。

vmalloc區(qū)域功能除了外設(shè)寄存器也直接映射到vmalloc了,就沒有32bit布局里的IO map space了。

不同版本的kernel,布局稍有差別:

  • kernel-3.10

ac347092-239a-11ee-962d-dac502259ad0.jpg

kernel-3.10

  • = kernel-3.18 && < kernel-4.6

ac6b427a-239a-11ee-962d-dac502259ad0.jpg

>= kernel-3.18 && < kernel-4.6

  • = kernel-4.6/N0.MP8 kernel-4.4(patch back)

ac846570-239a-11ee-962d-dac502259ad0.jpg

>= kernel-4.6/N0.MP8 kernel-4.4(patch back)

7. ARM32bit kernel布局

這是一張示意圖(有些地址可能會(huì)有差異)

ac9b4f74-239a-11ee-962d-dac502259ad0.jpg

ARM32bit kernel布局

整個(gè)地址空間是4G,kernel被配置為1G,程序占3G。

內(nèi)核代碼開始的地址是0xC0008000,前面放頁表(起始地址為0xC0004000),如果支持模塊(*.ko)那么地址在0xBF000000。

由于kernel沒辦法將所有內(nèi)存都映射進(jìn)來,畢竟kernel自己只占1G,如果RAM超過1G,就無法全部映射。怎么辦呢?只能先映射一部分了,這部分叫l(wèi)ow memory。其他的就按需映射,VMALLOC區(qū)域就是用于按需映射的。

ARM的外設(shè)寄存器和內(nèi)存一樣,都統(tǒng)一地址編碼,因此0xF0000000以上的一段空間用于映射外設(shè)寄存器,便于操作硬件模塊。

0xFFFF0000是特殊地址,CPU用于存放異常向量表,kernel異常絕大部分都是CPU異常(MMU發(fā)出的abort/undef inst.等異常)。

以上是粗略的說明,還需查看代碼獲取完整的分析信息(內(nèi)核在不停演進(jìn),有些部分可能還會(huì)變化)

三、printk 概述

1. kernel log

最初學(xué)編程時(shí),大家一定用過printf(),在kernel里有對應(yīng)的函數(shù),叫printk()。

最簡單的調(diào)試方法就是用printk()印出你想知道的信息了,而前面章節(jié)講到oops/panic時(shí),它們就通過printk()將寄存器信息/堆棧信息打印到kernel log buffer里。

可以看到kernel log可以通過串口輸出,也可以在發(fā)生oops/panic后將buffer保存成文件打包到db里,然后拿到串口log或db對kernel進(jìn)行調(diào)試分析了。

通常手機(jī)會(huì)保留串口測試點(diǎn),但要抓串口log一般都要拆機(jī),比較麻煩。前面講到可以將kernel log保存成文件打包在db里,db是什么東西?

四、AEE db log機(jī)制

db是叫AEE(Android Exception Engine,集成在Mediatek手機(jī)軟件里)的模塊檢查到異常并收集異常信息生成的文件,里面包含調(diào)試所需的log等關(guān)鍵信息。db有點(diǎn)像飛機(jī)的黑匣子。

對于KE來說,db里包含了如下文件(db可以通過GAT工具解開,請參考附錄里的FAQ):

  • __exp_main.txt:異常類型,調(diào)用棧等關(guān)鍵信息。

  • _exp_detail.txt:詳細(xì)異常信息

  • SYS_ANDROID_LOG:android main log

  • SYS_KERNEL_LOG:kernel log

  • SYS_LAST_KMSG:上次重啟前的kernel log

  • SYS_MINI_RDUMP:類似coredump,可以用gdb/trace32調(diào)試

  • SYS_REBOOT_REASON:重啟時(shí)的硬件記錄的信息。

  • SYS_VERSION_INFO:kernel版本,用于和vmlinux對比,只有匹配的vmlinux才能用于分析這個(gè)異常。

  • SYS_WDT_LOG:看門狗復(fù)位信息

以上這些文件一般足以調(diào)試KE了,除非一些特別的問題需要其他信息,比如串口log等等。

1. 系統(tǒng)重啟時(shí)關(guān)鍵信息

ram console除了保持last kmsg外,還有重要的系統(tǒng)信息,這些非常有助于我們調(diào)試。這些信息保存在ram console的頭部ram_console_buffer里。

acb714d4-239a-11ee-962d-dac502259ad0.jpg

ram console

這個(gè)結(jié)構(gòu)體里的off_linux指向了struct last_reboot_reason,里面保存了重要的信息:

acd4590e-239a-11ee-962d-dac502259ad0.jpg

ram console

以上重要的信息在重啟后將被打包到db里的SYS_REBOOT_REASON文件里。對這只文件的各個(gè)欄位解讀請查看:

五、前期異常處理

1.CPU異常捕獲

對于野指針、跑飛之類的異常會(huì)被MMU攔截并報(bào)告給CPU,這一系列都是硬件行為。

這類問題比較難定位,也是占KE比例的大頭,原因通常是內(nèi)存被踩壞、指針use atfer free等多種因素,在當(dāng)時(shí)可能不會(huì)立即出現(xiàn)異常,而是到使用這塊內(nèi)存才有可能崩潰。

2.軟件異常捕獲

在kernel代碼里,一般會(huì)通過BUG(),BUG_ON(),panic()來攔截超出預(yù)期的行為,這是軟件主動(dòng)回報(bào)異常的功能。

在內(nèi)核調(diào)用可以用來方便標(biāo)記bug,提供斷言并輸出信息。最常用的兩個(gè)是BUG()和BUG_ON()。當(dāng)被調(diào)用的時(shí)候,它們會(huì)引發(fā)oops,導(dǎo)致棧的回溯和錯(cuò)誤信息的打印。使用方式如下

if (condition)
   BUG();
或者 :
BUG_ON(condition); //只是在BUG基礎(chǔ)上多層封存而已:
` #define BUG_ON(condition) do { if (unlikely(condition)) BUG(); } while(0)`

3. 32bit kernel:

BUG() 的實(shí)現(xiàn)采用了埋入未定義指令(0xE7F001F2,記住這個(gè)值,log里看到這個(gè)值,你就應(yīng)該知道是調(diào)用了BUG()/BUG_ON()了)的方式

acef5236-239a-11ee-962d-dac502259ad0.jpg

64bit kernel:

原生的kernel,BUG()是直接調(diào)用panic()的:

ad111cc2-239a-11ee-962d-dac502259ad0.jpg

不過Mediatek修改了BUG()的實(shí)現(xiàn),這樣有更多的調(diào)試信息輸出(die()有寄存器等信息輸出)

ad33f1fc-239a-11ee-962d-dac502259ad0.jpg

MTK 修改

當(dāng)你看到如下log時(shí),就應(yīng)該知道是BUG()/BUG_ON()引起的了!

[ 147.234926]<0>-(0)[122:kworker/u8:3]Unable to handle kernel paging request at virtual address 0000dead

六、die()流程

經(jīng)過前面的流程,走到了die()函數(shù),該函數(shù)主要輸出便于調(diào)試的寄存器信息/堆棧信息等重要資料,我們通過log分析KE就是分析這些資料,因此要知道整個(gè)流程。die() => panic()的大致流程如下:

ad5a0694-239a-11ee-962d-dac502259ad0.jpg

die()流程圖

在學(xué)習(xí)這些流程時(shí),建議結(jié)合代碼和KE的log一起看,你就知道log里那些信息在代碼哪處打印出來的了。

1.die()總流程

先從die()入手,看下die()總流程:

ad7aae1c-239a-11ee-962d-dac502259ad0.jpg

die()總流程

走到debug_locks_off()就有l(wèi)og輸出了,如下:

ad96ed02-239a-11ee-962d-dac502259ad0.jpg

debug_locks_off() log輸出

如果這個(gè)異常是代碼里調(diào)用BUG()/BUG_ON()引起,那么有額外log說明

adaded7c-239a-11ee-962d-dac502259ad0.jpg

輸出的log大致如下:

adc1e278-239a-11ee-962d-dac502259ad0.jpg

log

2. __die()流程

絕大部分的關(guān)鍵信息是由__die()函數(shù)輸出的,流程如下:

add94224-239a-11ee-962d-dac502259ad0.jpg

__die()流程

異常類型信息

開始印出異常類型等信息,看一份kernel log有沒有oops,直接搜索關(guān)鍵字Internal error就可以了:

adf1feae-239a-11ee-962d-dac502259ad0.jpg

輸出的信息大致如下:

ae0754c0-239a-11ee-962d-dac502259ad0.jpg

log

3. module信息

接下來是module信息,不過我們不建議使用module,這邊也不打算介紹了。

4.CPU寄存器信息

然后是重要的CPU寄存器信息(32bit的代碼,64bit類同):

ae184960-239a-11ee-962d-dac502259ad0.jpg

CPU信息

輸出的信息大致如下:

ae3c30e6-239a-11ee-962d-dac502259ad0.jpg

log信息

5.寄存器附近的內(nèi)存

有助于我們分析問題的內(nèi)存信息,問題很可能就出在里面。

ae61fb96-239a-11ee-962d-dac502259ad0.jpg

輸出的信息大致如下:

ae968546-239a-11ee-962d-dac502259ad0.jpg

6. 調(diào)用棧

有時(shí)問題可以直接從調(diào)用棧看出來,由此可見調(diào)用棧是多么重要。

aeb3345c-239a-11ee-962d-dac502259ad0.jpg

輸出的信息大致如下:

aed3b556-239a-11ee-962d-dac502259ad0.jpg

7.PC附近指令

可以看到PC附近的指令:

af0a8946-239a-11ee-962d-dac502259ad0.jpg

輸出的信息大致如下:

af1cecbc-239a-11ee-962d-dac502259ad0.jpg

8.分析log

到這里die()函數(shù)就完成了它的使命,將重要信息輸出來了。接下來你要如何調(diào)試呢?這個(gè)就看個(gè)人的功力了,你可以:

  • 通過PC指向的函數(shù),用addr2line(后面的GNU tools有介紹)定位到哪只文件的哪一行,大致可以知道發(fā)生了什么,如果無法一下子定位,也可以通過結(jié)合printk()多次觀察KE時(shí)的log排查。如果是由BUG()/BUG_ON()引起的KE,則就可以著手修復(fù)問題了。

  • 查看調(diào)用棧,有些時(shí)候調(diào)用??梢哉f明流程,看看代碼是否有按預(yù)期跑,如果沒有,可以結(jié)合printk()定位問題。

  • 如果你想看函數(shù)參數(shù)或全局變量信息,那么你需要用《進(jìn)階篇: ramdump分析》的知識調(diào)試了。

七、panic()流程

流程走到panic()就里死(異常重啟)不遠(yuǎn)了,關(guān)鍵的信息已輸出到kernel log。那么panic()做了什么呢?

1. panic()流程

af31a5a8-239a-11ee-962d-dac502259ad0.jpg

panic()流程

panic()有標(biāo)志性的log輸出,大致如下:

af54adaa-239a-11ee-962d-dac502259ad0.jpg

kernel panic 異常

因此我們也可以通過搜索關(guān)鍵字Kernel panic查找是否有panic發(fā)生。

2. panic通知鏈

panic()會(huì)調(diào)用棧通知鏈上的回調(diào)函數(shù)同時(shí)感興趣的模塊,比如我們的aee注冊了回調(diào)函數(shù),用于保存kernel log/mini dump等關(guān)鍵信息,并將其保存到emmc的expdb分區(qū),等等重啟后將其回讀并保存成KE db。

3. expdb

重啟過程DRAM會(huì)丟失,因此信息只能保存在flash上了,在分區(qū)表里有一項(xiàng)就是expdb了:

af737c9e-239a-11ee-962d-dac502259ad0.jpg

流程大致如下(版本不停演進(jìn),可能有很大變化,僅供參考):

af9a8c1c-239a-11ee-962d-dac502259ad0.jpg

重啟后,aee將回讀aeedb分區(qū)資料并轉(zhuǎn)化為KE db。

八、nested panic

有時(shí)die()/panic()流程不一定能正常走完,可能走到某一步又發(fā)生了異常,則就形成了嵌套,這種情況,我們一般不會(huì)關(guān)注后面的異常,而是關(guān)注最開始的那個(gè)異常。

為了避免異常嵌套,在發(fā)生第2次異常時(shí),我們就攔截下來,我們在3個(gè)地方用于攔截nested panic:

  • do_PrefetchAbort()

  • do_DataAbort()

  • do_undefinstr()

afc85e94-239a-11ee-962d-dac502259ad0.jpg

攔截后不走die()/panic()流程,因?yàn)檫@些流程可能會(huì)再次發(fā)生異常,走我們寫的函數(shù)aee_stop_nested_panic()函數(shù):

afde8aca-239a-11ee-962d-dac502259ad0.jpg

在里面盡量少用kernel模塊,很有可能也會(huì)發(fā)生異常,僅僅將寄存器等重要信息輸出到ram console就等死(死循環(huán)等等看門狗復(fù)位?。?。這時(shí)你抓回來的db里的SYS_LAST_KMSG就可以看到這些資料,大致如下(不同版本稍有區(qū)別):

affa4166-239a-11ee-962d-dac502259ad0.jpg


里面包含了寄存器信息、堆棧信息和調(diào)用棧,我們就可以通過工具(addr2line)還原當(dāng)時(shí)異常的位置。

不過nested panic能參考的信息很少,不像普通的KE那樣豐富。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5343

    瀏覽量

    120450
  • 存儲(chǔ)器
    +關(guān)注

    關(guān)注

    38

    文章

    7493

    瀏覽量

    163879
  • JAVA
    +關(guān)注

    關(guān)注

    19

    文章

    2969

    瀏覽量

    104789

原文標(biāo)題:八、nested panic

文章出處:【微信號:哆啦安全,微信公眾號:哆啦安全】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    Linux中Kernel的運(yùn)行原理概述

    接觸過Linux的都知道Kernel的含義,在我看來就是操作系統(tǒng)的核心或者最重要的部分。眾所周知的是,幾乎整個(gè)互聯(lián)網(wǎng)都運(yùn)行在 Linux上,從網(wǎng)絡(luò)協(xié)議,到服務(wù)器,到你平常訪問的絕大多數(shù)網(wǎng)站,都能
    發(fā)表于 07-24 07:45

    Real Time Kernel概述

    Real Time Kernel概述DA145x軟件平臺(tái)利用了由Riviera Waves許可的小型高效實(shí)時(shí)內(nèi)核。 內(nèi)核提供以下功能:●任務(wù)創(chuàng)建和狀態(tài)轉(zhuǎn)換?!袢蝿?wù)之間的消息交換?!裼?jì)時(shí)器管理
    發(fā)表于 01-10 08:02

    Linux Kernel Panic的產(chǎn)生的原因?

    是Oops信息輸出) 2. 常見Linux Kernel Panic報(bào)錯(cuò)內(nèi)容: (1) Kernel panic-not syncing fatal exception in interrupt
    發(fā)表于 06-15 06:24

    Java中包、接口與異常處理(exception) 實(shí)驗(yàn)

    實(shí)驗(yàn) 4 包、接口與異常處理(exception) 一、實(shí)驗(yàn)?zāi)康?    了解 Java 中包(package)、接口(interface)和異常處理(exception)的作用,掌握包、接口
    發(fā)表于 09-23 19:00 ?1199次閱讀

    Kernel--Interrupts

    Kernel--Interrupts,好東西,喜歡的朋友可以下載來學(xué)習(xí)。
    發(fā)表于 02-22 15:03 ?0次下載

    KE-25數(shù)據(jù)手冊

    GS 氧氣傳感器 KE-系列
    發(fā)表于 12-25 21:36 ?0次下載

    ESP8266的重啟原因及常見的Fatal Exception的原因的說明

    本文檔的主要內(nèi)容詳細(xì)介紹的是ESP8266的重啟原因及常見的Fatal Exception的原因的官方說明資料免費(fèi)下載。
    發(fā)表于 09-23 08:00 ?28次下載
    ESP8266的重啟原因及常見的Fatal <b class='flag-5'>Exception</b>的原因的說明

    如何自定義Exception Hooks

    【導(dǎo)語】:在日常開發(fā)的過程中,當(dāng)代碼報(bào)錯(cuò)時(shí),我們通常要不斷打印、閱讀traceback提示信息,來調(diào)試代碼,這篇文章介紹了如何實(shí)現(xiàn)一個(gè)Exception Hooks,使得traceback模塊的提示信息更加精確;同時(shí)還介紹了一些第三方庫,這些庫也提供了Exception
    的頭像 發(fā)表于 10-21 12:01 ?901次閱讀

    RKP436KE 數(shù)據(jù)表

    RKP436KE 數(shù)據(jù)表
    發(fā)表于 04-20 18:48 ?0次下載
    RKP436<b class='flag-5'>KE</b> 數(shù)據(jù)表

    RKP453KE 數(shù)據(jù)表

    RKP453KE 數(shù)據(jù)表
    發(fā)表于 04-26 20:38 ?0次下載
    RKP453<b class='flag-5'>KE</b> 數(shù)據(jù)表

    RKP451KE 數(shù)據(jù)表

    RKP451KE 數(shù)據(jù)表
    發(fā)表于 04-26 20:39 ?0次下載
    RKP451<b class='flag-5'>KE</b> 數(shù)據(jù)表

    RKP452KE 數(shù)據(jù)表

    RKP452KE 數(shù)據(jù)表
    發(fā)表于 04-26 20:39 ?0次下載
    RKP452<b class='flag-5'>KE</b> 數(shù)據(jù)表

    RKP450KE 數(shù)據(jù)表

    RKP450KE 數(shù)據(jù)表
    發(fā)表于 04-27 19:06 ?0次下載
    RKP450<b class='flag-5'>KE</b> 數(shù)據(jù)表

    kernel日志寫入logd介紹

    kernel日志寫入logd介紹 通過logcat命令獲取kernel日志比較特殊,故作為一個(gè)例子進(jìn)行梳理。 2.3.1 整體流程 2.3.2 命令打印kernel日志 通過logcat -b
    的頭像 發(fā)表于 11-23 17:11 ?729次閱讀
    <b class='flag-5'>kernel</b>日志寫入logd介紹

    高速FLEX貼片機(jī)KE-2050/KE-2060操作手冊

    電子發(fā)燒友網(wǎng)站提供《高速FLEX貼片機(jī)KE-2050/KE-2060操作手冊.pdf》資料免費(fèi)下載
    發(fā)表于 01-23 10:44 ?3次下載