国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

DSP編程技巧之30---答疑解惑哪家強(qiáng)之(5)

發(fā)布時間:2014-12-15 12:04    發(fā)布者:看門狗
關(guān)鍵詞: DSP編程
作者:paradoxfx 來源:電子產(chǎn)品世界

29. 如果不需要printf()/sprintf()的全部特性,怎么樣才能減小代碼體積?

  初學(xué)者往往使用printf打印“Hello World”這樣的方式來完成第一個DSP編程的程序,這種方法雖然是非常直觀明了的,感覺起來功能也是非常簡單的,但是一編譯結(jié)果發(fā)現(xiàn)提示棧的空間不夠,或者有“program will not fit into available memory”之類的錯誤。這是因為標(biāo)準(zhǔn)的printf()/sprintf()提供了非常多的特性支持,造成了在DSP上實現(xiàn)時,產(chǎn)生的代碼尺寸非常大。

  此時我們可以根據(jù)需要調(diào)整不同級別的格式格式限定符,例如通過鏈接器的選項,我們可以指定--printf_support=full, minimal或者nofloat, full為默認(rèn)參數(shù),表示支持所有的格式;nofloat不支持對浮點(diǎn)類型的數(shù)據(jù)的輸入/打印,包括%a,%A, %f, %F,%g,%G,%e和%E,支持其它的字符、定點(diǎn)格式等;minimal:對數(shù)據(jù)格式的最小支持,只包含了不指定數(shù)據(jù)寬度和精度標(biāo)志的整形、字符型或者字符串,即只支持%%,%d,%o,%c,%s和%x格式。需要注意的是,如果--printf_support使用了不支持的格式,鏈接器并不能給出特定的實時運(yùn)行庫的錯誤提示,在使用時要仔細(xì)檢查。

  此外,如果不去指定鏈接器選項,我們也可以修改printf函數(shù)默認(rèn)對應(yīng)的源程序_printfi.c來實現(xiàn)類似的效果,它的路徑一般在編譯器的庫函數(shù)目錄下,例如\ti\ccsv6\tools\compiler\c2000_6.2.5\lib\src。在此路徑下,有3個printf函數(shù)對應(yīng)的c程序,它們與鏈接器選項的對應(yīng)關(guān)系如下表所示。DSP編程技巧之30---答疑解惑哪家強(qiáng)之(5)

  由此我們也可以看出,支持全部格式的printf的源程序的大小,達(dá)到了最小格式支持下源程序大小的23倍還要多。

  30. CCS編譯器是否支持任何工業(yè)標(biāo)準(zhǔn)?

  1) 所有的TI DSP支持的C語言標(biāo)準(zhǔn):

  C89 (ISO/IEC 9899:1990,或者叫NSI X3.159-1989)

  C99 (ISO/IEC 9899:1999). 不完全支持。

  2) 不支持的C語言標(biāo)準(zhǔn):

  C11 (ISO/IEC 9899:2011)

  3) 支持的C++標(biāo)準(zhǔn):

  C++98 (ISO/IEC 14882:1998)

  C++03 (本質(zhì)是C++98的bug修復(fù))

  4) 不支持的C++標(biāo)準(zhǔn):

  C++ TR1

  C++11 (ISO/IEC 14882:2011)

  5) IEEE-754 (ISO/IEC/IEEE 60559)標(biāo)準(zhǔn):

  TI的ARM和DSP的C/C++編譯器支持32位和64位的二進(jìn)制浮點(diǎn)數(shù)運(yùn)算,能夠支持IEEE754標(biāo)準(zhǔn)中大部分特性。

  6) MISRA-C

  MISRA C是由汽車產(chǎn)業(yè)軟件可靠性協(xié)會(MISRA,motor industry software reliability association)提出的C語言開發(fā)標(biāo)準(zhǔn),在控制有關(guān)的代碼中是非常有用的標(biāo)準(zhǔn)。

  7) 其它標(biāo)準(zhǔn)

  在工業(yè)領(lǐng)域中,safety安全特性在一些應(yīng)用場合中已經(jīng)是要求必須具備的功能了,相關(guān)的標(biāo)準(zhǔn)包括IEC61508、TÜV認(rèn)證等。目前已經(jīng)有一部分包含硬件safety特性的DSP器件了;如果使用軟件來實現(xiàn)這些特性,則目前還需要我們自己來編寫代碼以支持這樣的特征。

  31. CCS編譯器對GCC擴(kuò)展的支持如何?

  GNU編譯器結(jié)合GCC支持許多標(biāo)準(zhǔn)ANSI/ISO C/C++所不支持的特性。在開源應(yīng)用和Linux等開發(fā)中,GCC的編譯器gcc和g++等都被廣泛使用。所以為了保證對GCC工具所開發(fā)的代碼的兼容性,TI的編譯器也支持某些GCC的擴(kuò)展特性。目前支持的一些特性基本都包含在GCC4.3中,可查看:http://gcc.gnu.org/onlinedocs/gcc-4.3.6/gcc/C-Extensions.html

  32. 如何了解有關(guān)編譯/代碼產(chǎn)生工具的已知問題,并獲得最新進(jìn)展?

  老外喜歡用IBM的ClearQuest系統(tǒng)來報告bug并分享解決方案,我們可以使用TI提供的開放鏈接https://cqweb.ext.ti.com/cqweb/# ... t=HTML&version=cqwj來報告bug、查看/分享解決方案等,其界面如下圖所示:DSP編程技巧之30---答疑解惑哪家強(qiáng)之(5)

  避開老舊的“傳統(tǒng)”bug的最好辦法當(dāng)然是定期升級編譯器和開發(fā)環(huán)境了。通過配置,新版本的CCS在啟動后會自動檢測升級并自動升級,這也簡化了我們對開發(fā)環(huán)境的維護(hù)工作。

  33. 鏈接文件中包含那么多個段,有什么快速識別的方法?

  把下面這個例子記牢就好了:

  //

  // Global variables x & y ==> .ebss

  // Initial values 2 & 7 ==> .cinit

  //

  int x = 2;

  int y = 7;

  void main()

  {

  long z; // Local variable => .stack

  z = x + y; // Code => .text

  }

  34. 為什么我們需要鏈接文件.cmd?為何編譯器不能自動分配存儲空間并進(jìn)行內(nèi)存管理?

  在操作系統(tǒng)存在的情況下,這些工作確實不需要我們花費(fèi)太多的心思。但是在嵌入式的DSP處理中,這樣做的主要原因是處理能力和存儲空間是十分有限的,必須要我們進(jìn)行一定的介入,例如我們需要考慮的因素包括:

  1) 運(yùn)行速度:在RAM中比在Flash中快,在Flash中又比在外部存儲器(使用XINTF)中快。

  2) 代碼是否需要存儲在非易失的存儲器中(例如Flash)?

  3) 任務(wù)是否是時間關(guān)鍵的?例如需要把某個時間關(guān)鍵的ISR被保存在Flash中,然后運(yùn)行時復(fù)制到RAM里。

  4) 一些RAM可被DMA模塊所訪問,而另一些則不行。

  5) 使用單獨(dú)的物理RAM模塊來避免資源的沖突。例如,在C2000 DSP中,RAM模塊都是在單個機(jī)器周期內(nèi)只能訪問一次的SARAM(Single-access RAM)。

  6) 資源是否位于外部存儲器中?

  7) 代碼是否需要保存在包含緩存或者預(yù)讀的存儲器中以提高性能?在C2000DSP中,我們幾乎見不到緩存或者預(yù)讀的概念,它們一般出現(xiàn)在包括ARM處理器的器件中。

  8) 存儲器在程序空間、數(shù)據(jù)空間中是否具有等待狀態(tài)?

  9) 是否有需要被代碼安全模塊CSM所保護(hù)的代碼?CSM并不能保護(hù)所有的代碼空間。

  以上這些因素,在我們編程時也是需要特別關(guān)注,甚至是較為頭疼的事情,顯然讓編輯器去自動實現(xiàn)它們,在目前階段是不可能的(除非編譯器的算法有一天能實現(xiàn)一定程度的人工智能)。所以在現(xiàn)階段,我們需要使用鏈接器命令文件cmd去描述每個段所需要使用的內(nèi)存情況。

  如果我們沒有把某一個特殊的或者自定義的段給指定到特定的存儲空間中,則此時鏈接器會自動把它給分配到一個可用的存儲空間里,這有可能會影響到程序的執(zhí)行效果。所以我們要開啟編譯器的-w選項,這樣在在未定義的輸出段被創(chuàng)建時,開發(fā)環(huán)境的控制臺窗口中會產(chǎn)生相關(guān)的警告信息。
本文地址:http://m.qingdxww.cn/thread-135073-1-1.html     【打印本頁】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點(diǎn)和對其真實性負(fù)責(zé);文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問題,我們將根據(jù)著作權(quán)人的要求,第一時間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 利用模擬開發(fā)工具生態(tài)系統(tǒng)進(jìn)行安全電路設(shè)計
  • 深度體驗Microchip自動輔助駕駛應(yīng)用方案——2025巡展開啟報名!
  • 更佳設(shè)計的解決方案——Microchip模擬開發(fā)生態(tài)系統(tǒng)
  • Cortex-M4外設(shè) —— TC&TCC結(jié)合事件系統(tǒng)&DMA優(yōu)化任務(wù)培訓(xùn)教程
  • 貿(mào)澤電子(Mouser)專區(qū)
關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 久久一区不卡中文字幕 | 欧美中文在线视频 | 天天爽夜夜春 | 麻豆国产在线观看一区二区 | 亚欧在线 | 国产成人手机视频 | 美国黑人毛片 | 超级极品白嫩美女在线 | 特片我不卡 | 高清在线一区 | 九九视频免费精品视频免费 | 日韩在线看免费高清完整版 | 色视频免费 | 日韩短视频 | 一级毛片在线免费视频 | 欧美网站视频 | 三级在线观看 | 日韩欧美在线精品 | 亚洲国产高清在线精品一区 | 操狠狠| 亚洲黄色片一级 | 91综合国产 | 在线观看国产精品日本不卡网 | 4hu四虎最新免费地址 | 2021最新四虎永久免费 | 91在线视频一区 | 午夜 dy888理论久久 | 国产资源站| 91精品国产欧美一区二区 | 久久 精品 一区二区 | 久久久噜噜噜www成人网 | 99精品99 | 麻豆成人在线视频 | 午夜免费看片 | 亚洲日本在线看片 | 日韩在线视频免费播放 | 日本一区二区三区不卡在线视频 | 久久er国产精品免费观看1 | 一区二区视频网 | 国产精品成人免费综合 | 欧美的高清视频在线观看 |