毛片网站在线看_天堂俺去俺来也www久久婷婷_日韩av免费网站_18性欧美xxxⅹ性满足_一区二区三区韩国免费中文网站 _性xx色xx综合久久久xx_999亚洲国产精


曙海教育集團論壇DSP專區DSP5000技術討論 → 一種TI 5000系列DSP C/C++語言和匯編語言混合編程的方法


  共有10551人關注過本帖樹形打印

主題:一種TI 5000系列DSP C/C++語言和匯編語言混合編程的方法

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個性首頁 | 博客 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發短信
等級:青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊:2010-11-12 11:08:23
一種TI 5000系列DSP C/C++語言和匯編語言混合編程的方法  發帖心情 Post By:2010-11-22 8:52:54

摘 要:首先介紹并比較了 TI 5000 系列DSP的三種主要軟件開發方法的優缺點,提出了C/C++與匯編語言混合編程方法的優越性所在。之后在比較了幾種典型混合編程方法的基礎上,提出了一種結構化的混合編程方法并詳細闡述了其函數調用規則和寄存器規則。最后給出了一個經過驗證的混合編程程序,該程序對DSP軟件開發有較大參考價值。
  關鍵詞:DSP;混合編程;函數調用規則;寄存器規則


1引言
  
TI 公司的5000系列低功耗16 b定點DSP,因其良好的性價比,在國內獲得了很大的普及。如何對5000系列DSP進行軟件開發也一直是業界關注的熱點。5000系列DSP的軟件設計通常有3種方法。

1.1用C/C++語言開發
  TI公司提供了用于C/C++語言開發的CCS平臺。該平臺包括優化ANSI C/C++ 編譯器,從而可以在源程序級進行開發調試。這種方法大大提高了軟件的開發速度和可讀性,方便了軟件的修改和移植。但是,C/C++代碼的效率還是無法與手工編寫的匯編代碼效率相比,如FFT程序。因為即使是最佳的C/C++編譯器,也無法在所有的情況下都能合理的利用DSP芯片提供的各種資源。此外,用C/C++語言實現DSP芯片某些硬件控制也不如匯編方便,有些甚至無法用C/C++語言實現。
1.2全匯編語言開發

  TI公司提供了用于匯編語言開發的針對5000系列DSP的匯編語言。用戶可以用他進行軟件開發。這種方式可以更為合理的利用芯片提供的硬件資源,其代碼效率高,程序執行速度快。但是用匯編語言編寫程序是比較復雜的,一般來說,不同公司的芯片匯編語言是不同的,即使是同一公司的芯片,由于芯片的類型不同(如定點和浮點)、芯片的升級換代,其匯編語言也不同。因此,用匯編語言開發基于某種芯片的產品周期較長,并且軟件的修改和升級較困難。而且匯編語言的可讀性和可移植性較差。

1.3C/C++語言和匯編語言混合編程開發
  為了充分利用DSP芯片的硬件資源,更好發揮C/C++語言和匯編語言進行軟件開發的各自優點,可以將兩者有機的結合起來,兼顧兩者優點,避免其弊端。因此,在很多情況下,采用混合編程方法能更好地達到設計要求,完成設計任務。

2 C/C++語言和匯編語言混合編程方法討論
  
C/C++語言和匯編語言混合編程的具體方法有以下幾種:
  (1)獨立編寫C/C++程序和匯編程序,分開編譯或匯編形成各自的目標模塊,再用鏈接器將C/C++模塊和匯編模塊鏈接起來,這是一種靈活性較大的方法。但用戶必須自己維護各匯編模塊的入口和出口代碼,自己計算傳遞參數在堆棧中的偏移量,工作量稍大,但能做到對程序的絕對控制,也能滿足軟件設計結構化的要求。這是本文主要講述的方法。
  (2)在C/C++程序中使用匯編程序中定義的變量和常量。
  (3)在C/C++程序中直接內嵌匯編語句。這種方法可以在C/C++程序中實現C/C++語言無法實現的硬件控制功能,如修改中斷控制寄存器、中斷標志寄存器等。
  (4)在C/C++源程序中使用內部函數直接調用匯編語言語句。
  后3種方法由于在C/C++語言中直接嵌入了匯編語言的成分,容易造成程序混亂,C/C++環境被破壞,甚至導致程序崩潰,而編程者又很難對不良結果進行預期和有效控制。而如果采用第一種方法,只要遵循有關C/C++語言函數調用規則和寄存器規則,就能預見到程序運行的結果,保證程序正確。下面分別講述函數調用規則和寄存器規則,最后給出編程實例。

3函數調用規則
  
C/C++編譯器對函數調用強加了一組嚴格的原則。除了特殊的運行時間支持庫函數外,任何調用函數和被C/C++函數調用的函數都必須遵守這些原則。不遵守這些原則可能破壞C/C++環境并導致程序失敗。

  圖1說明了典型的函數調用。在這個例子中,參數被傳遞到堆棧中調用者的參數塊,函數再使用這些參數調用被調用函數。注意,第一個參數是在A累加器中傳遞的。這個例子還說明了匯編器對被調用函數的局部幀的分配。局部幀包括局部變量塊和局部參數塊兩部分,其中局部參數塊是局部幀中用來傳遞參數到其他函數的部分。如果被調用函數沒有局部變量并且不再調用其他函數或需要調用的函數沒有參數,則不分配局部幀。對于混合編程而言,由于被調用函數是手工編寫的匯編程序,則局部幀由編程者自己完成分配,也不需要在堆棧中進行,而編譯器分配局部幀。

圖片點擊可在新窗口打開查看

  (1)函數如何調用
  函數(調用者)在調用被調用函數時執行以下任務。
  ①調用者將第一個(最左邊)的參數值放進累加器A。調用者將剩下的參數按相反的順序傳進參數塊,剩下的最左邊的參數在最低的地址。
  ②若函數返回一個結構,則調用者為該結構分配空間,然后用累加器A傳遞返回空間的地址給調用的函數。
  ③調用者調用函數。
  (2)被調用函數如何響應。
  被調用函數執行以下任務:
  注意:如果被調用函數是C/C++函數,則下面步驟都是由匯編器自動完成。如果是混合編程,則如下步驟都是由編程者在被調用的匯編函數中完成的。
  ①若被調用函數修改AR1,AR2或AR7,則將他們壓入堆棧。
  ②被調用函數通過從SP減去一個常數,為局部變量塊和局部參數塊分配存儲器。該常數按以下公式計算,即:
  局部變量塊的大小+局部參數塊的大小+padding
  padding值是為了保證SP對準偶數邊界而可能要求補充的一個字。之所以SP要對準偶數邊界,是因為5000系列DSP指令可一次讀寫存儲器的32 b,例如DLD,DADD等。這樣,編譯器必須保證所有32 b的目標都駐留在偶數邊界。
  對于混合編程而言可以在匯編函數中,按本步驟的方法在堆棧中分配局部幀,但本方法相對比較麻煩,尤其該匯編函數還要調用其他函數時,所以,一般而言編程者通常用其他方法分配局部幀,比如用bss偽指令定義局部變量供函數使用。
  ③被調用函數為調用函數執行代碼。
  ④若函數返回一個值,則被調用函數將該值放在累加器A中;若函數返回一個結構,則被 調用函數將該結構復制到累加器A指到的存儲器塊;若調用者不返回函數值,則A被置0。
  ⑤被調用函數給SP上加上第二步計算的常數,釋放為局部變量和局部參數分配的存儲空間。對混合編程而言,如果編程者沒有在堆棧中分配局部幀,則本步驟省略。
  ⑥被調用函數恢復所有保存的寄存器。
  ⑦被調用函數執行返回。

4寄存器規則
  
(1)必須保存任何被函數修正的專用寄存器。專用寄存器包括:
  ①AR1,AR6,AR7
  ②堆棧指針(SP)
  若對SP正常使用,不需要明顯的保存。換句話說,只要任何壓入堆棧的東西在函數返回之 前被彈回(因而保存了SP),匯編函數就可以自由的使用堆棧。任何非專用的寄存器都可以自由地使用而無需將他們保存。
  (2)中斷函數必須保存他使用的所有寄存器。
  (3)ARP在函數進入和返回時,必須為0,即當前輔助寄存器為AR0。函數執行時可以為其 他值。
  (4)在默認的情況下,編譯器總是認為OVM為0。因此,若在匯編程序中將OVM置為1,則返回C/C++環境時,必須將其恢復為0。
  (5)在默認的情況下,編譯器總是認為CPL為1。因此,若在匯編程序中將CPL清0,則在返回C/C++環境時,必須將其恢復為1。
  (6)長整數和浮點數存儲在存儲器中的方法是最高有效字在低位地址。
  (7)函數必須按前面有關被調用函數響應中所述的方法返回值。
  (8)除了全局變量的初始化外,匯編語言模塊不能以任何目的使用cinit段。在boot asm中的C/C++啟動程序假定cinit段完全由初始化表組成。將其他的信息放入cin it中將使初始化表產生混亂,并將產生不可預期的結果。
  (9)在匯編語言模塊中,對可以從C/C++中訪問的變量和函數名需加上前綴“_”。對于僅用于匯編語言模塊中的標識符,應不得用下劃線開始。
  (10)任何在匯編語言模塊中聲明的將要從C/C++訪問或調用的對象或函數,都必須在匯編語言中用global偽指令聲明為全局變量。

5編程實例
  
以32 b乘法運算為例。雖然用C/C++語言表達32 b乘法運算較為方便和明了,但由于C/C++語言無法很好利用DSP匯編語言為實現各種乘法運算而提供的指令,而使得C/C++程序效率低下。所以這里用匯編語言完成32 b乘法運算,再用C/C++程序調用他。

5.1算法簡介
  由于16 b定點DSP中沒有32 b乘法指令,所以一定要用幾種16 b乘法指令結合一定算法來進行32 b乘法運算。一個32 b數在存儲器中是分開存儲的。高16位存放在低地址,他在進行乘法運算是可以看作一個16 b有符號數;低16位存放在相鄰的低地址,他進行乘法運算時可以看作一個16 b無符號數。于是算式如下:  
  圖片點擊可在新窗口打開查看
其中:S代表符號數;U代表無符號數。
  由上算式可見,在32 b乘法運算中,實際上包含了3種乘法運算:U*U,S*U和S*S 。一般的乘法運算指令都是兩個帶符號數相乘,即S*S。所以在編程時,還要用到以下兩條乘法指令:
 圖片點擊可在新窗口打開查看
5.2C語言主程序

圖片點擊可在新窗口打開查看
  
在主程序中進行MPY32函數調用時,函數傳遞情形如圖2所示。

圖片點擊可在新窗口打開查看

  從圖2可以看出,函數MPY32的第一參數存放在A累加器中,第二個參數在堆棧中,高16位在堆棧中的低地址,低16位在堆棧中的高地址。由于MPY32是匯編語言函數,所以編譯器不為其分配局部幀,局部幀的分配在匯編程序中進行。

5.3匯編程序
  可以看出,在匯編程序中至少要為局部幀分配8個單元,其中4個單元用來存放參數值,4個單元用來存放運算結果,如圖3所示。
  匯編函數:
 圖片點擊可在新窗口打開查看
 圖片點擊可在新窗口打開查看
 圖片點擊可在新窗口打開查看
 圖片點擊可在新窗口打開查看


圖片點擊可在新窗口打開查看

6結語
  本文介紹的混合編程方法不但適用于TI 5000系列DSP,同樣也適用于TI其他系列的DSP,如2000系列、6000系列,甚至對其他芯片,如51系列單片機,實現混合編程也有很大參考價值。值得注意的是,為了使混合編程不破壞C語言的結構性,在匯編語言中不要設置除函數名之外的任何全局變量。


支持(0中立(0反對(0單帖管理 | 引用 | 回復 回到頂部

返回版面帖子列表

一種TI 5000系列DSP C/C++語言和匯編語言混合編程的方法








簽名
毛片网站在线看_天堂俺去俺来也www久久婷婷_日韩av免费网站_18性欧美xxxⅹ性满足_一区二区三区韩国免费中文网站 _性xx色xx综合久久久xx_999亚洲国产精
欧美高清在线视频| av在线不卡电影| 国产精品色婷婷| 亚洲欧美日韩一区二区| 国产免费成人在线视频| 国产精品无人区| 亚洲视频一区二区免费在线观看| 亚洲欧洲制服丝袜| 日韩电影在线一区二区| 激情文学综合插| 不卡av免费在线观看| 91久久精品日日躁夜夜躁欧美| 欧美系列日韩一区| 精品福利在线导航| 一区在线播放视频| 日本中文在线一区| voyeur盗摄精品| 欧美午夜在线观看| 国产亚洲欧美色| 亚洲欧美乱综合| 毛片av中文字幕一区二区| hitomi一区二区三区精品| 欧美日高清视频| 国产偷v国产偷v亚洲高清| 亚洲国产成人高清精品| 亚洲美女区一区| 美国三级日本三级久久99| 91原创在线视频| 久久综合九色综合97_久久久| 最新国产精品久久精品| 男人的j进女人的j一区| 成人高清伦理免费影院在线观看| 欧美人体做爰大胆视频| 国产欧美一区二区精品性色超碰 | 久久久午夜精品理论片中文字幕| 亚洲欧美精品午睡沙发| 极品销魂美女一区二区三区| 91亚洲精品乱码久久久久久蜜桃| 日韩精品一区二区三区在线播放 | 99re免费视频精品全部| 欧美成人精品福利| 亚洲国产aⅴ成人精品无吗| 成人免费视频国产在线观看| 国产精品主播直播| 欧美精品xxxxbbbb| 亚洲久本草在线中文字幕| 国产麻豆精品视频| 日韩视频一区在线观看| 亚洲国产美女搞黄色| 99riav久久精品riav| 国产精品免费人成网站| 色香色香欲天天天影视综合网| 欧美一区二区三区人| 亚洲午夜激情网页| 色婷婷国产精品综合在线观看| 国产视频亚洲色图| 国产一区二区三区日韩| 日韩一区二区高清| 午夜久久久久久电影| 欧美色网一区二区| 亚洲午夜电影网| 欧美亚洲精品一区| 一区二区三区在线观看视频| 91亚洲精品一区二区乱码| 一区在线中文字幕| 波多野结衣中文一区| 国产精品色婷婷久久58| 成人国产亚洲欧美成人综合网| 欧美精品一区二区三区一线天视频| 日韩精品欧美成人高清一区二区| 在线观看视频一区二区| 欧美巨大另类极品videosbest| 国产午夜精品一区二区三区视频 | 在线看不卡av| 综合久久国产九一剧情麻豆| 99麻豆久久久国产精品免费 | 欧美亚洲自拍偷拍| 欧美日韩中文字幕一区二区| 亚洲精品乱码久久久久久黑人| 成人三级在线视频| 欧美高清在线视频| 国产成人免费9x9x人网站视频| 日韩免费观看高清完整版 | √…a在线天堂一区| 99久久久精品免费观看国产蜜| 久久久久久久久久电影| 国产剧情一区二区| 2022国产精品视频| 经典三级视频一区| 欧美乱妇20p| 精品一区二区日韩| 精品久久五月天| 极品瑜伽女神91| 国产三级欧美三级| 成人黄色国产精品网站大全在线免费观看| 久久精品在线观看| 成人教育av在线| 亚洲少妇最新在线视频| 成人免费视频一区| 亚洲乱码中文字幕| 在线不卡欧美精品一区二区三区| 日本午夜精品视频在线观看| 国产色91在线| 91久久精品一区二区二区| 婷婷久久综合九色综合绿巨人| 91精品国产色综合久久不卡电影 | 99国产精品久久久久久久久久| 亚洲欧美国产77777| 欧美亚洲一区二区在线观看| 亚洲卡通动漫在线| 欧美大片拔萝卜| 成人h动漫精品| 亚洲午夜影视影院在线观看| 日韩欧美你懂的| 国产91精品精华液一区二区三区| 1000部国产精品成人观看| 欧美日韩激情在线| 国产乱一区二区| 亚洲影院理伦片| 欧美成人福利视频| 一本久久a久久免费精品不卡| 亚洲大片精品永久免费| 久久精品人人做人人爽人人| 一本色道久久综合亚洲91| 中文字幕一区二区三区在线播放| 欧美色综合网站| 国产91富婆露脸刺激对白| 亚洲精品高清在线观看| 欧美精品一区在线观看| 色999日韩国产欧美一区二区| 日韩精品三区四区| 成人欧美一区二区三区| 精品国产一区二区在线观看| 国内精品嫩模私拍在线| 一区二区高清免费观看影视大全 | 国产三级欧美三级日产三级99| 国产精品 欧美精品| 成人综合婷婷国产精品久久| 婷婷丁香久久五月婷婷| 国产欧美一区二区三区鸳鸯浴 | 欧美剧在线免费观看网站| 成人免费av在线| 亚洲天堂免费看| 久久久不卡影院| 欧美三级视频在线观看| 成人黄色a**站在线观看| 精品在线观看视频| 亚洲日本护士毛茸茸| 久久久噜噜噜久久中文字幕色伊伊| 色综合亚洲欧洲| 日本女人一区二区三区| 一区二区三区四区在线播放| 中文字幕第一页久久| 精品国产乱码久久久久久蜜臀| 在线观看一区日韩| 91啪九色porn原创视频在线观看| 国产一级精品在线| 日韩电影在线一区二区| 亚洲成人精品影院| 国产精品毛片久久久久久| 精品日韩成人av| 欧美一卡二卡在线| 3751色影院一区二区三区| 欧美做爰猛烈大尺度电影无法无天| 国产精品一区久久久久| 午夜精品久久久久久久久久 | 一级做a爱片久久| 日韩毛片一二三区| 国产一区二区三区在线看麻豆| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲福中文字幕伊人影院| 亚洲另类在线视频| 亚洲激情五月婷婷| 一区二区理论电影在线观看| 国产性色一区二区| 久久久精品国产99久久精品芒果| 国产精品天美传媒沈樵| 国产精品三级av在线播放| 国产精品国产三级国产aⅴ无密码| 国产午夜亚洲精品理论片色戒| 日本一区二区三区国色天香| 国产亚洲人成网站| 亚洲欧美在线aaa| 中文字幕永久在线不卡| 亚洲欧洲美洲综合色网| 亚洲国产精品ⅴa在线观看| 国产欧美日本一区二区三区| 国产偷v国产偷v亚洲高清| 成人国产电影网| 91成人免费在线视频| 欧美日韩国产综合久久| 欧洲一区在线电影| 91精品国产91久久久久久一区二区 | 亚洲成人777| 性久久久久久久| 三级不卡在线观看| 精品中文字幕一区二区小辣椒| 国产麻豆精品在线观看| 激情偷乱视频一区二区三区| 成人免费三级在线|