DSP編程技巧之2:揭開(kāi)編譯器神秘面紗之處理器選項
也許你已經(jīng)熟練使用了CCS好多年,可是當某一天出現一個(gè)與cl2000有關(guān)的錯誤的時(shí)候,突然間也摸不著(zhù)頭腦了;例如使用老版本的還不支持C2000 FPU的CCS來(lái)編譯28335的程序,cl2000就會(huì )提示你各種不支持然后報錯不運行了。Cl2000.exe是神馬?
本文引用地址:http://dyxdggzs.com/article/198710.htm Cl2000.exe就是和我們的程序編譯密切相關(guān)的編譯器了,使用的方法是:
cl2000 [編譯器選項] [需要編譯的文件] [--運行鏈接器 [鏈接器選項] 目標文件]]
使用方法看起來(lái)很復雜,還好CCS已經(jīng)幫我們調用它了(或者說(shuō)CCS就是一個(gè)框架,它完成的編譯、調試、鏈接等功能幾乎都需要調用一些別的exe來(lái)執行,所以你可能體會(huì )過(guò)升級了一些庫文件、編輯器版本等,界面文件等卻不需要進(jìn)行任何的更改),這些句子會(huì )顯示在工程的屬性里面。當然如果你想親自體驗一把,也可以在ccs安裝目錄下面的toolscompilerc2000_6.1.5bin下面找到它,即cl2000.exe,然后用命令行的方式運行起來(lái))。舉個(gè)簡(jiǎn)單例子:
cl2000 -v28 symtab.c file.c seek.asm --run_linker --library=lnk.cmd
--output_file=myprogram.out
在上面的例子中,如果需要編譯的文件,例如幾個(gè).c或者.asm找不到,CCS就會(huì )提示xxx.c或者xxx.asm找不到或者未定義了;或者你改了目標文件的名字,例如改成了a.out,但是加載程序到DSP中的時(shí)候卻仍然使用更改前的b.out,自然有可能出現預料之外的結果了:在以前幫助網(wǎng)友解決問(wèn)題的時(shí)候,確實(shí)出現過(guò)這樣的狀況。
明白了編譯器的調用方法之后,我們就更進(jìn)一步,揭開(kāi)編譯器中形形色色選項的神秘面紗,從此看到編譯器提示的形形色色的警告和錯誤不再用發(fā)怵。
具體說(shuō)來(lái),編譯器的選項有多大20個(gè)大類(lèi),超過(guò)一百個(gè)具體的選項。當然這些選項是有輕重之分的,有的是必須用到的,例如支持一下FPU等功能;有的則是不常接觸的,例如MISRA這樣的汽車(chē)工業(yè)軟件可靠性檢查,只有在對軟件進(jìn)行標準化時(shí)才會(huì )用到。所以我們首先看一下最常用的選項,例如處理器的選項,它們的意義在于定義了在編譯程序時(shí)CPU的模式。補充一點(diǎn)是,cl2000的幫助里看到的選項都是很長(cháng)的名字,在CCS里面為了書(shū)寫(xiě)方便(因為選項框就那么點(diǎn)面積啊),一般用別名來(lái)代替;沒(méi)有別名的則直接使用選項名字。
c++相關(guān)文章:c++教程
評論