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

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

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

如何讓調(diào)試過(guò)程清晰可循

技術(shù)讓夢(mèng)想更偉大 ? 來(lái)源:技術(shù)讓夢(mèng)想更偉大 ? 2024-04-17 12:30 ? 次閱讀

1、問(wèn)題背景:如何保證發(fā)布出去的bin文件是最終測(cè)試通過(guò)的版本?

一般的來(lái)講,代碼到了測(cè)試后期,master分支就不會(huì)頻繁的提交了,并且提交也會(huì)更加謹(jǐn)慎。

但是人為操作總會(huì)出現(xiàn)紕漏,希望只要代碼被重新編譯過(guò),那么bin文件就包含新的時(shí)間信息,而這個(gè)信息是可以從外部通信或printf來(lái)查看的。

嵌入式開(kāi)發(fā)中,版本號(hào)一般的都是一個(gè)int變量或字符串變量。但是若修改了代碼而沒(méi)有改version變量或宏定義,那么從version上就看不出來(lái)文件的變化。

那么最終編譯的版本到底是哪個(gè)版本,是否與測(cè)試的版本完全一致,這個(gè)問(wèn)題尤為突出。

目標(biāo)文件中帶有編譯時(shí)間可以防止代碼被改動(dòng)過(guò),只要代碼被重新編譯,那么就生成新的時(shí)間信息。

git能夠記錄文件修改信息,但是調(diào)試信息或工程配置等,很多文件都是ignore的,這些信息代表著最終的bin文件的運(yùn)行環(huán)境。

某些復(fù)雜bug情況下,只有運(yùn)行環(huán)境一致,仿真器才能attach到目標(biāo)文件。

2. 如何獲取時(shí)間:__DATA__ , __ TIME__

這兩個(gè)宏是日期和時(shí)間,格式如下。如果把這兩個(gè)宏加入到代碼,那么就得到了時(shí)間的字符串信息。

//Exampleof__DATE__string:"Dec272017"
//Exampleof__TIME__string:"1519"
constchar*BuildInfo="Version:"VERSION""__DATE__""__TIME__;

代碼實(shí)現(xiàn)獲取日期和時(shí)間的方法很多,比如:

unsignedintmk_Build_Date(void)
{
intyear=0,month=0,day=0;
inthour=0,minute=0,seconds=0;
charm[4]={0};

sscanf(__DATE__,"%3s%2d%4d",m,&day,&year);

for(month=0;month

把上面的函數(shù)加入到代碼中,就能獲取工程編譯的時(shí)間。

但是如果該代碼所在的文件沒(méi)有被修改,在非build-all情況下,編譯器不會(huì)再次編譯此文件,所以時(shí)間信息也就不會(huì)被更新。

如果每次都使用re-build all,一來(lái)繁瑣,二來(lái)也不能保證每次都會(huì)記得點(diǎn)擊build all按鈕,靠技術(shù)手段來(lái)保證每次build都更新時(shí)間信息才是正道。

3. 如何保證時(shí)間每次編譯都更新:使用預(yù)編譯指令,每次更新包含時(shí)間宏的文件或?qū)?yīng)的鏈接文件。

在IAR環(huán)境下,官方已經(jīng)給出了解決的方法(Using pre-build actions for time stamping)。

https://www.iar.com/support/tech-notes/ide/build-actions-pre-build-and-post-build/

方法1:修改文件的時(shí)間,引起編譯器對(duì)文件進(jìn)行重新編譯。

cmd/c"touch/cygdrive/d/test.c"

方法雖好,可惜IAR用戶大多數(shù)是Windows用戶,包括我在內(nèi),touch是linux命令,必須Cywin環(huán)境。如果安裝過(guò)這個(gè)環(huán)境的話,那就大功告成了。

Cygwintouchcommand

Youcanenter"cygwin-application.exe"onthepre-andpost-buildcommandlines,iftheenvironmentvariablePATHincludesthedirectorywherethe"cygwin-application.exe"islocated.

YoucanruntheCygwincommand"touch"onthepre-buildcommandline,butifyouaddafilepath,forexample"touchd:/test.c",thefilepathisnotacceptedbyCygwin.

CygwinexpectsthePOSIXpath/cygdrive/d/test.csotheresultingcommandlinewouldbe"touch/cygdrive/d/test.c",howeverthiscommandcannotbeexecuteddirectlyonthepre-andpost-buildcommand.Insteadyouhavetorunindirectlyusing:

cmd/c"touch/cygdrive/d/test.c"
The.batfile(locatedinprojectdirectory)alternativewouldlooklike:

Pre-buildcommandline:

$PROJ_DIR$pre-build.bat
Filepre-build.bat:

touch/cygdrive/d/test.c

方法2:修改文件對(duì)應(yīng)的鏈接文件,觸發(fā)編譯器重新編譯該文件,生成新的鏈接文件,那么就會(huì)生成新的帶有時(shí)間信息的目標(biāo)文件。

Analternativetothe"touch"commandistohaveapre-buildactionthatdeletestheobjectfile,forexamplethePre-buildcommandline:

cmd/c"del"$OBJ_DIR$	est.o""

在pre-build中加入上面的命令,就會(huì)在編譯前刪除test.o文件。

在這種模式下,工程代碼只要任何位置發(fā)生變化,代碼重新編譯,就會(huì)觸發(fā)刪除test.o,然后鏈接過(guò)程發(fā)現(xiàn)沒(méi)有test.o文件,那么就會(huì)重新編譯一次test.c,那么新的時(shí)間信息就會(huì)記錄下來(lái)了。

雖有些曲線救國(guó)的味道,但還是很順利的實(shí)現(xiàn)了目標(biāo)。

只要工程的任何地方有改動(dòng),生成新的目標(biāo)文件,那么目標(biāo)文件中就會(huì)帶有最新的編譯時(shí)間。

方法3:直接告訴編譯器每次重新編譯某個(gè)文件更直接,MDK支持此功能。

時(shí)隔一年半再次來(lái)這里,發(fā)現(xiàn)當(dāng)時(shí)自己簡(jiǎn)直是小白,還洋洋得意曲線救國(guó),實(shí)際上舍近求遠(yuǎn)罷了。

如果對(duì)工具多一些了解,萬(wàn)萬(wàn)是不會(huì)用上面的方法的,當(dāng)然上面的方法也是通用想法,是通用型知識(shí)點(diǎn),容易想到,也能達(dá)到目標(biāo)。

新的方法,不需要寫(xiě)任何腳本,如果想讓代碼每次都編譯更新DATA 和 TIME兩個(gè)宏,那么讓這個(gè)文件每次都編譯一次就可以了,不需要?jiǎng)h除它的obj文件然后讓編譯器找不到文件而觸發(fā)重新編一次,其實(shí)直接告訴編譯器每次重新編譯更直接,MDK支持此功能。

3d4d9932-fc08-11ee-a297-92fbcf53809c.png

下面是測(cè)試的效果:

3d5e9dc2-fc08-11ee-a297-92fbcf53809c.png

其它資料

https://stackoverflow.com/questions/11697820/how-to-use-date-and-time-predefined-macros-in-as-two-integers-then-stri

審核編輯:黃飛

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

    關(guān)注

    18

    文章

    1012

    瀏覽量

    47435
  • 字符串
    +關(guān)注

    關(guān)注

    1

    文章

    567

    瀏覽量

    20440
  • 變量
    +關(guān)注

    關(guān)注

    0

    文章

    609

    瀏覽量

    28289

原文標(biāo)題:神操作讓你的調(diào)試過(guò)程有跡可循

文章出處:【微信號(hào):技術(shù)讓夢(mèng)想更偉大,微信公眾號(hào):技術(shù)讓夢(mèng)想更偉大】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    485程序調(diào)試過(guò)程出現(xiàn)了亂碼

    我的485程序調(diào)試過(guò)程中出現(xiàn)了亂碼是怎么回事?像我它在串口調(diào)試助手上顯示0x00串口上顯示0xc1,我它顯示0x01它顯示0xc1,
    發(fā)表于 09-16 08:54

    USMART調(diào)試過(guò)程是怎樣的

    對(duì)應(yīng)的相關(guān)函數(shù),并執(zhí)行,同時(shí)支持返回結(jié)果。USMART調(diào)試過(guò)程:USMART配置步驟:將USMART包添加到工程中,頭文件要包含到path。添加需要調(diào)用的函數(shù)到usmart_config.c文件中。主函數(shù)中調(diào)用usmart_dev.init函數(shù)初始化usmart。即可通過(guò)助手發(fā)送命令,調(diào)用在usmar
    發(fā)表于 01-13 06:41

    RFID串口調(diào)試過(guò)程是怎樣的?

    RFID串口調(diào)試過(guò)程是怎樣的?
    發(fā)表于 02-09 07:52

    5G14433和MCS-51單片機(jī)接口電路的調(diào)試過(guò)程

    通過(guò)5G14433芯片與MCS一51單片機(jī)接rm電路的實(shí)例,說(shuō)明了硬件電路的調(diào)試過(guò)程。
    發(fā)表于 11-12 14:36 ?23次下載

    簡(jiǎn)化Xilinx和Altera FPGA調(diào)試過(guò)程

    簡(jiǎn)化Xilinx和Altera FPGA調(diào)試過(guò)程:通過(guò)FPGAViewTM 解決方案,如混合信號(hào)示波器(MSO)和邏輯分析儀,您可以在Xilinx 和Altera FPGA 內(nèi)部迅速移動(dòng)探點(diǎn),而無(wú)需重新編譯設(shè)計(jì)方案。能夠把內(nèi)部FPGA
    發(fā)表于 11-20 17:46 ?27次下載

    電源設(shè)計(jì)調(diào)試過(guò)程中的異?,F(xiàn)象分析

    調(diào)試過(guò)程中所看到的一些異常現(xiàn)象,以及后來(lái)的解決辦法。其實(shí)很多工程師認(rèn)為設(shè)計(jì)電源是非常重經(jīng)驗(yàn)的一門(mén)技術(shù),要見(jiàn)多識(shí)廣。這種經(jīng)
    發(fā)表于 10-09 10:49 ?1681次閱讀

    APM四軸 初級(jí)安裝調(diào)試過(guò)程

    ACM四軸 安裝調(diào)試過(guò)程 此教程主要講解軟件調(diào)試 首先要確認(rèn)自己想飛哪種模式,X還是十模式 根據(jù)自己的飛行模式插好線 本章以X模式為例
    發(fā)表于 11-03 10:23 ?6次下載

    單片機(jī)驅(qū)動(dòng)DM9000網(wǎng)卡芯片詳細(xì)調(diào)試過(guò)程

    單片機(jī)驅(qū)動(dòng)DM9000網(wǎng)卡芯片詳細(xì)調(diào)試過(guò)程
    發(fā)表于 11-02 11:03 ?0次下載

    單片機(jī)調(diào)試過(guò)程中的調(diào)試組件導(dǎo)致的問(wèn)題

    單片機(jī)調(diào)試過(guò)程中,經(jīng)常會(huì)遇到類(lèi)似第3只眼的問(wèn)題。何謂第3只眼呢?
    的頭像 發(fā)表于 12-30 17:12 ?7324次閱讀
    單片機(jī)<b class='flag-5'>調(diào)試過(guò)程</b>中的<b class='flag-5'>調(diào)試</b>組件導(dǎo)致的問(wèn)題

    淺析STM32調(diào)試過(guò)程中的幾個(gè)相關(guān)問(wèn)題

    總的來(lái)講,單片機(jī)調(diào)試是單片機(jī)開(kāi)發(fā)工作必不可少的環(huán)節(jié)。不管你愿不愿意,調(diào)試過(guò)程中總會(huì)有各種不期而遇的問(wèn)題出現(xiàn)在我們面前來(lái)磨礪我們。這里分享幾點(diǎn)STM32調(diào)試過(guò)程中與開(kāi)發(fā)工具及IDE有關(guān)的幾個(gè)常見(jiàn)問(wèn)題,以供參考。
    的頭像 發(fā)表于 01-21 13:50 ?5326次閱讀

    GT9271觸控屏芯片移植調(diào)試過(guò)程的詳細(xì)教程說(shuō)明

    本文檔的主要內(nèi)容詳細(xì)介紹的是GT9271觸控屏芯片移植調(diào)試過(guò)程的詳細(xì)教程說(shuō)明
    發(fā)表于 08-05 17:34 ?49次下載
    GT9271觸控屏芯片移植<b class='flag-5'>調(diào)試過(guò)程</b>的詳細(xì)教程說(shuō)明

    直接阻抗匹配的調(diào)試過(guò)程

    直接匹配阻抗,天線與射頻芯片在同一塊板子,調(diào)試步驟與50歐姆阻抗匹配調(diào)試天線參數(shù)差不多,多了一部分射頻芯片端的濾波部分的參數(shù)計(jì)算。下面介紹調(diào)試過(guò)程。
    的頭像 發(fā)表于 10-03 16:18 ?9434次閱讀
    直接阻抗匹配的<b class='flag-5'>調(diào)試過(guò)程</b>

    S7-1200系列PLC調(diào)試過(guò)程小結(jié)

    S7-1200系列PLC調(diào)試過(guò)程小結(jié)
    發(fā)表于 12-20 09:25 ?3次下載

    電磁流量計(jì)調(diào)試過(guò)程中存在的問(wèn)題以及解決措施

    跟其他類(lèi)型的儀表調(diào)試相比,電磁流量計(jì)的調(diào)試方法存在很大的差異性,它的復(fù)雜程度會(huì)更高,稍不注意,調(diào)試過(guò)程中就會(huì)出現(xiàn)人工失誤操作問(wèn)題,影響電磁流量計(jì)的正常運(yùn)行。進(jìn)行電磁流量計(jì)調(diào)試時(shí),工作人
    的頭像 發(fā)表于 10-27 09:08 ?1394次閱讀

    單片機(jī)基本io功能調(diào)試過(guò)程

    單片機(jī)基本IO功能的調(diào)試過(guò)程涉及多個(gè)步驟,旨在確保IO口能夠正確地執(zhí)行輸入和輸出操作。以下是一個(gè)調(diào)試過(guò)程,涵蓋了從準(zhǔn)備階段到實(shí)際測(cè)試的關(guān)鍵步驟: 一、準(zhǔn)備階段 確定單片機(jī)型號(hào)和IO口 : 首先,明確
    的頭像 發(fā)表于 09-14 14:38 ?329次閱讀