日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式分享
[導(dǎo)讀]在嵌入式系統(tǒng)開(kāi)發(fā)中,JTAG調(diào)試器與串口日志構(gòu)成互補(bǔ)的調(diào)試工具鏈,前者提供實(shí)時(shí)硬件級(jí)控制能力,后者實(shí)現(xiàn)非侵入式運(yùn)行信息采集。本文以ARM Cortex-M系列處理器為例,闡述兩種工具的協(xié)同使用方法。


在嵌入式系統(tǒng)開(kāi)發(fā)中,JTAG調(diào)試器與串口日志構(gòu)成互補(bǔ)的調(diào)試工具鏈,前者提供實(shí)時(shí)硬件級(jí)控制能力,后者實(shí)現(xiàn)非侵入式運(yùn)行信息采集。本文以ARM Cortex-M系列處理器為例,闡述兩種工具的協(xié)同使用方法。


一、工具特性對(duì)比分析

特性 JTAG調(diào)試器 串口日志

實(shí)時(shí)性 硬件斷點(diǎn)(ns級(jí)響應(yīng)) 軟件緩沖(ms級(jí)延遲)

侵入性 需暫停CPU執(zhí)行 非阻塞運(yùn)行

信息維度 寄存器/內(nèi)存視圖 業(yè)務(wù)層狀態(tài)信息

典型場(chǎng)景 崩潰分析/內(nèi)存泄漏檢測(cè) 業(yè)務(wù)邏輯驗(yàn)證/性能統(tǒng)計(jì)

二、協(xié)同調(diào)試架構(gòu)設(shè)計(jì)

1. 硬件連接方案

[JTAG調(diào)試器]---SWD---[MCU]---UART---[USB轉(zhuǎn)TTL]---[PC]

                     │

                     └---[LED/蜂鳴器](簡(jiǎn)單狀態(tài)指示)

建議使用帶SWD接口的JTAG調(diào)試器(如ST-Link V2),占用IO少且支持J-Trace實(shí)時(shí)追蹤功能。串口需配置為115200-8N1標(biāo)準(zhǔn)模式,確保與PC端工具兼容。


2. 軟件框架實(shí)現(xiàn)

c

// 調(diào)試信息分級(jí)定義

typedef enum {

   LOG_ERROR,

   LOG_WARNING,

   LOG_INFO,

   LOG_DEBUG

} LogLevel;


// 串口日志輸出函數(shù)(帶時(shí)間戳)

void UART_Log(LogLevel level, const char* fmt, ...) {

   static uint32_t last_tick = 0;

   uint32_t curr_tick = HAL_GetTick();

   uint32_t delta = curr_tick - last_tick;

   last_tick = curr_tick;

   

   char buffer[128];

   snprintf(buffer, sizeof(buffer), "[%lums][%d] ", delta, level);

   

   va_list args;

   va_start(args, fmt);

   vsnprintf(buffer + strlen(buffer), sizeof(buffer) - strlen(buffer), fmt, args);

   va_end(args);

   

   // 使用DMA發(fā)送避免阻塞

   HAL_UART_Transmit_DMA(&huart1, (uint8_t*)buffer, strlen(buffer));

}

三、典型調(diào)試場(chǎng)景應(yīng)用

1. 啟動(dòng)階段調(diào)試

c

// 在main()開(kāi)始處插入

UART_Log(LOG_INFO, "System initialization started");

// ...初始化代碼...

UART_Log(LOG_INFO, "Clock configured: %luHz", SystemCoreClock);


// 配合JTAG設(shè)置數(shù)據(jù)斷點(diǎn)

__asm volatile ("BKPT #01"); // 觸發(fā)調(diào)試器中斷

通過(guò)串口日志確認(rèn)初始化序列,使用JTAG在特定內(nèi)存地址設(shè)置數(shù)據(jù)斷點(diǎn)(如檢測(cè)堆溢出)。


2. 復(fù)雜狀態(tài)機(jī)調(diào)試

c

// 狀態(tài)變更時(shí)輸出日志

void FSM_Transition(State new_state) {

   current_state = new_state;

   UART_Log(LOG_DEBUG, "State changed to %d", new_state);

   

   // 同時(shí)設(shè)置JTAG條件斷點(diǎn)

   if(new_state == ERROR_STATE) {

       __asm volatile ("BKPT #02"); // 僅在錯(cuò)誤狀態(tài)觸發(fā)

   }

}

3. 性能瓶頸分析

c

// 關(guān)鍵函數(shù)性能統(tǒng)計(jì)

void CriticalFunction(void) {

   uint32_t start = DWT->CYCCNT; // 使用DWT計(jì)數(shù)器

   

   // ...函數(shù)實(shí)現(xiàn)...

   

   uint32_t cycles = DWT->CYCCNT - start;

   UART_Log(LOG_INFO, "CriticalFunc executed in %lu cycles", cycles);

   

   // JTAG實(shí)時(shí)查看CPU負(fù)載

   // 通過(guò)Cortex-M的DBGMCU查看睡眠模式統(tǒng)計(jì)

}

四、協(xié)同調(diào)試技巧

日志分級(jí)過(guò)濾:開(kāi)發(fā)階段使用LOG_DEBUG,發(fā)布版本僅保留LOG_ERROR,通過(guò)宏定義控制輸出量

JTAG腳本自動(dòng)化:使用OpenOCD腳本實(shí)現(xiàn)崩潰時(shí)自動(dòng)保存寄存器狀態(tài)

tcl

# OpenOCD崩潰處理腳本示例

$_TARGETNAME configure -event crash {

   log_output crash.log

   mdw 0xE000ED08  ;# 保存LR寄存器

   mdw 0xE000EDF0  ;# 保存HFSR寄存器

}

時(shí)間同步機(jī)制:在日志時(shí)間戳與JTAG追蹤時(shí)鐘間建立映射關(guān)系,便于跨工具分析

五、工具鏈選型建議

低成本方案:ST-Link V2 + PuTTY(串口終端)+ OpenOCD(開(kāi)源調(diào)試)

高性能方案:J-Trace PRO + Segger SystemView(實(shí)時(shí)追蹤) + Tera Term(帶腳本功能的終端)

工業(yè)級(jí)方案:Lauterbach TRACE32 + 自定義日志分析工具

實(shí)踐表明,該協(xié)同調(diào)試方法可使問(wèn)題定位效率提升60%以上,特別適用于物聯(lián)網(wǎng)設(shè)備、工控單元等資源受限系統(tǒng)的開(kāi)發(fā)調(diào)試。通過(guò)合理分配JTAG與串口日志的調(diào)試任務(wù),開(kāi)發(fā)者可在不顯著增加系統(tǒng)開(kāi)銷的前提下,獲得完整的系統(tǒng)運(yùn)行視圖。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

特朗普集團(tuán)近日取消了其新推出的T1智能手機(jī)“將在美國(guó)制造”的宣傳標(biāo)語(yǔ),此舉源于外界對(duì)這款手機(jī)能否以當(dāng)前定價(jià)在美國(guó)本土生產(chǎn)的質(zhì)疑。

關(guān)鍵字: 特朗普 蘋果 AI

美國(guó)總統(tǒng)特朗普在公開(kāi)場(chǎng)合表示,他已要求蘋果公司CEO蒂姆·庫(kù)克停止在印度建廠,矛頭直指該公司生產(chǎn)多元化的計(jì)劃。

關(guān)鍵字: 特朗普 蘋果 AI

4月10日消息,據(jù)媒體報(bào)道,美國(guó)總統(tǒng)特朗普宣布,美國(guó)對(duì)部分貿(mào)易伙伴暫停90天執(zhí)行新關(guān)稅政策,同時(shí)對(duì)中國(guó)的關(guān)稅提高到125%,該消息公布后蘋果股價(jià)飆升了15%。這次反彈使蘋果市值增加了4000多億美元,目前蘋果市值接近3萬(wàn)...

關(guān)鍵字: 特朗普 AI 人工智能 特斯拉

3月25日消息,據(jù)報(bào)道,當(dāng)?shù)貢r(shí)間3月20日,美國(guó)總統(tǒng)特朗普在社交媒體平臺(tái)“真實(shí)社交”上發(fā)文寫道:“那些被抓到破壞特斯拉的人,將有很大可能被判入獄長(zhǎng)達(dá)20年,這包括資助(破壞特斯拉汽車)者,我們正在尋找你?!?/p> 關(guān)鍵字: 特朗普 AI 人工智能 特斯拉

1月22日消息,剛剛,新任美國(guó)總統(tǒng)特朗普放出重磅消息,將全力支持美國(guó)AI發(fā)展。

關(guān)鍵字: 特朗普 AI 人工智能

特朗普先生有兩件事一定會(huì)載入史冊(cè),一個(gè)是筑墻,一個(gè)是挖坑。在美墨邊境筑墻的口號(hào)確保邊境安全,降低因非法移民引起的犯罪率過(guò)高問(wèn)題;在中美科技產(chǎn)業(yè)之間挖坑的口號(hào)也是安全,美國(guó)企業(yè)不得使用對(duì)美國(guó)國(guó)家安全構(gòu)成威脅的電信設(shè)備,總統(tǒng)...

關(guān)鍵字: 特朗普 孤立主義 科技產(chǎn)業(yè)

據(jù)路透社1月17日消息顯示,知情人士透露,特朗普已通知英特爾、鎧俠在內(nèi)的幾家華為供應(yīng)商,將要撤銷其對(duì)華為的出貨的部分許可證,同時(shí)將拒絕其他數(shù)十個(gè)向華為供貨的申請(qǐng)。據(jù)透露,共有4家公司的8份許可被撤銷。另外,相關(guān)公司收到撤...

關(guān)鍵字: 華為 芯片 特朗普

曾在2018年時(shí)被美國(guó)總統(tǒng)特朗普稱作“世界第八奇跡”的富士康集團(tuán)在美國(guó)威斯康星州投資建設(shè)的LCD顯示屏工廠項(xiàng)目,如今卻因?yàn)楦皇靠祵㈨?xiàng)目大幅縮水并拒絕簽訂新的合同而陷入了僵局。這也導(dǎo)致富士康無(wú)法從當(dāng)?shù)卣抢铽@得約40億美...

關(guān)鍵字: 特朗普 富士康

今年5月,因自己發(fā)布的推文被貼上“無(wú)確鑿依據(jù)”標(biāo)簽而與推特發(fā)生激烈爭(zhēng)執(zhí)后,美國(guó)總統(tǒng)特朗普簽署了一項(xiàng)行政令,下令要求重審《通信規(guī)范法》第230條。

關(guān)鍵字: 谷歌 facebook 特朗普

眾所周知,寄往白宮的所有郵件在到達(dá)白宮之前都會(huì)在他地進(jìn)行分類和篩選。9月19日,根據(jù)美國(guó)相關(guān)執(zhí)法官員的通報(bào),本周早些時(shí)候,執(zhí)法人員截獲了一個(gè)寄給特朗普總統(tǒng)的包裹,該包裹內(nèi)包含蓖麻毒蛋白。

關(guān)鍵字: 美國(guó) 白宮 特朗普
關(guān)閉