資料介紹
數字信號處理器(DSP)在各領域中的應用已日趨廣泛,其中TI(TEXAS INSTRUMENT)公司的TMS320系列芯片占據了主導地位。TMS320F206(簡稱F206)由于具有片內32K字的Flash,支持JTAG掃描端口的仿真調試,并支持程序的串行下載,便于開發設計及產品的軟件升級,因而在中高檔儀器開發中受到青睞。
DSP的處理速度雖然較高,但直接支持的I/O口線較少,控制能力相對較弱,因而與外部器件接口采用串行方式較為適合。常用的串行接口和串行總線有UART、I2C總線,由于I2C總線提供了較完善的總線協議,且接口電路簡單,因而得到廣泛的應用。目前,已有很多外圍器件支持I2C接口,但多數MCU并不直接支持I2C總線,因而采用I/O口線模擬I2C的方式成為一種通用解決方案。但由于I2C總線協議的復雜性及操作管理的特殊性,仍給此類方式的開發造成了較大不便。好在文獻中提出了一種按平臺模式設計的、適用于80C51的虛擬I2C總線軟件包,大大簡化了80C51的I2C接口程序設計,使用戶無需了解I2C總線協議的細節,即可實現相應的接口。文獻中也給出了一種用于MSP430單片機的軟件包。由于DSP尚無此類軟件包,為簡化DSP的此類I2C接口程序設計,本文參照文獻中的設計原則,設計了一種適用于TMS320C2XX系列DSP開發的軟件包。
1 虛擬I2C軟件包的設計
根據文獻中所提到的最佳包容性設計、后歸一化設計、前歸一化設計原則,軟件包進行了如下定義。
(1)適用范圍
① 適用主發送和主接收方式。I2C總線有4種工作方式:主發送、主接收、從發送、從接收。因實際DSP多工作于I2C總線的主方式,因而軟件包設計為主方式。
② 適用TMS320C2XX系列與I2C總線外圍器件的接口,支持對外圍器件N字節的讀寫,通信方式為對虛擬節點尋址后點對點的讀寫。
③ 模擬I/O口線可選擇4根通用I/O口線(I/O0~ I/O4)中的任意兩根。
(2)軟件包結構設計
TMS320C2XX系列產品,基本包括4根通用I/O口線I/O0~I/O4(由于XF僅能作為輸入口線,BIO僅能作為輸出口線,因而暫不考慮)。它們的輸入輸出方向由ASPCR的低4位來設定,相應口線狀態的設定或讀取由IOSR寄存器控制。但此處DSP與80C51有所不同,口線的輸入輸出狀態不是自動切換的,且ASPCR、IOSR寄存器都不支持位尋址方式,因而在進行I2C總線工作方式模擬時較為繁瑣。為避免所用寄存器其它狀態位的改變,需通過較多的與、或操作來改變指定I/O口線的狀態,因而本軟件包與80C51的虛擬I2C軟件包結構稍有不同。當然,這些均在軟件包內部完成,使用者不必了解具體細節,用戶接口同樣簡單易用。
① 軟件包組成。為模擬I2C總線的操作時序,軟件包中包括了2個宏定義和12個子函數。
(a)時序模擬子程序
Sendb--發送起始標志,啟動I2C總線;senda--發送確認標志;
Sendna--發送非確認標志;Sende--發送結束標志。
(b)操作模擬子程序
geta--接收確認標志;sendd--發送8位數據;
getd--接收1個字節數據。
(c)數據讀寫子程序
wrnbyte--寫入N字節;rdnbyte--讀取N字節。
(d)其它宏及子函數
subsendd--根據標志位C設置模擬數據口線的狀態;toggleclk--切換模擬時鐘口線狀態;
Xdelay--延時子程序;Sdainm--將模擬數據口線A配置為輸入口線;
sdaoutm--將模擬數據口線配置為輸出。
因DSP的工作頻率一般遠高于I2C總線的操作頻率,因而這里需專用的延時子程序降低模擬時鐘口線頻率。本文所給出的源程序為F206采用40 MHz晶振時的情況,用戶使用時可隨實際情況調整延時時間。
② 軟件包符號定義。軟件包中包括如下符號定義:
VSDA、VSCL--分別定義了模擬數據口線和模擬時鐘口線對應的屏蔽位,因DSP中對通用I/O口線的操作不能通過位操作來實現,因而僅能屏蔽位來定義,如采用IO3模擬數據線、IO2模擬時鐘線,則可定義IO3為08h、IO2為04h;
RAM0--為數據暫存用的臨時存儲單元;
RIO--為用于保存I/O口線當前狀態的存儲單元;
SLA--用于保存總線上節點地址并確定傳輸方向的存儲單元;
NUMBYTE--待發送或接收的字節數存儲單元;
MTD--發送數據緩沖區;
MRD--接收數據緩沖區。
DSP的處理速度雖然較高,但直接支持的I/O口線較少,控制能力相對較弱,因而與外部器件接口采用串行方式較為適合。常用的串行接口和串行總線有UART、I2C總線,由于I2C總線提供了較完善的總線協議,且接口電路簡單,因而得到廣泛的應用。目前,已有很多外圍器件支持I2C接口,但多數MCU并不直接支持I2C總線,因而采用I/O口線模擬I2C的方式成為一種通用解決方案。但由于I2C總線協議的復雜性及操作管理的特殊性,仍給此類方式的開發造成了較大不便。好在文獻中提出了一種按平臺模式設計的、適用于80C51的虛擬I2C總線軟件包,大大簡化了80C51的I2C接口程序設計,使用戶無需了解I2C總線協議的細節,即可實現相應的接口。文獻中也給出了一種用于MSP430單片機的軟件包。由于DSP尚無此類軟件包,為簡化DSP的此類I2C接口程序設計,本文參照文獻中的設計原則,設計了一種適用于TMS320C2XX系列DSP開發的軟件包。
1 虛擬I2C軟件包的設計
根據文獻中所提到的最佳包容性設計、后歸一化設計、前歸一化設計原則,軟件包進行了如下定義。
(1)適用范圍
① 適用主發送和主接收方式。I2C總線有4種工作方式:主發送、主接收、從發送、從接收。因實際DSP多工作于I2C總線的主方式,因而軟件包設計為主方式。
② 適用TMS320C2XX系列與I2C總線外圍器件的接口,支持對外圍器件N字節的讀寫,通信方式為對虛擬節點尋址后點對點的讀寫。
③ 模擬I/O口線可選擇4根通用I/O口線(I/O0~ I/O4)中的任意兩根。
(2)軟件包結構設計
TMS320C2XX系列產品,基本包括4根通用I/O口線I/O0~I/O4(由于XF僅能作為輸入口線,BIO僅能作為輸出口線,因而暫不考慮)。它們的輸入輸出方向由ASPCR的低4位來設定,相應口線狀態的設定或讀取由IOSR寄存器控制。但此處DSP與80C51有所不同,口線的輸入輸出狀態不是自動切換的,且ASPCR、IOSR寄存器都不支持位尋址方式,因而在進行I2C總線工作方式模擬時較為繁瑣。為避免所用寄存器其它狀態位的改變,需通過較多的與、或操作來改變指定I/O口線的狀態,因而本軟件包與80C51的虛擬I2C軟件包結構稍有不同。當然,這些均在軟件包內部完成,使用者不必了解具體細節,用戶接口同樣簡單易用。
① 軟件包組成。為模擬I2C總線的操作時序,軟件包中包括了2個宏定義和12個子函數。
(a)時序模擬子程序
Sendb--發送起始標志,啟動I2C總線;senda--發送確認標志;
Sendna--發送非確認標志;Sende--發送結束標志。
(b)操作模擬子程序
geta--接收確認標志;sendd--發送8位數據;
getd--接收1個字節數據。
(c)數據讀寫子程序
wrnbyte--寫入N字節;rdnbyte--讀取N字節。
(d)其它宏及子函數
subsendd--根據標志位C設置模擬數據口線的狀態;toggleclk--切換模擬時鐘口線狀態;
Xdelay--延時子程序;Sdainm--將模擬數據口線A配置為輸入口線;
sdaoutm--將模擬數據口線配置為輸出。
因DSP的工作頻率一般遠高于I2C總線的操作頻率,因而這里需專用的延時子程序降低模擬時鐘口線頻率。本文所給出的源程序為F206采用40 MHz晶振時的情況,用戶使用時可隨實際情況調整延時時間。
② 軟件包符號定義。軟件包中包括如下符號定義:
VSDA、VSCL--分別定義了模擬數據口線和模擬時鐘口線對應的屏蔽位,因DSP中對通用I/O口線的操作不能通過位操作來實現,因而僅能屏蔽位來定義,如采用IO3模擬數據線、IO2模擬時鐘線,則可定義IO3為08h、IO2為04h;
RAM0--為數據暫存用的臨時存儲單元;
RIO--為用于保存I/O口線當前狀態的存儲單元;
SLA--用于保存總線上節點地址并確定傳輸方向的存儲單元;
NUMBYTE--待發送或接收的字節數存儲單元;
MTD--發送數據緩沖區;
MRD--接收數據緩沖區。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- I2C模塊arduinoio Simulink軟件包 0次下載
- 基于DSP虛擬I2C總線軟件包的設計分析 0次下載
- DSP虛擬I2C總線軟件包的設計 0次下載
- 基于I2C總線的處理器的聯網設計方案 11次下載
- 虛擬I2C總線匯編程序軟件包 19次下載
- 24系列I2C軟件包使用說明 9次下載
- 基于CPLD的I2C總線接口設計
- I2C總線在Linux系統中的驅動設計
- I2C總線應用中的幾個問題
- i2c總線的特點
- I2C 串行總線技術在DSP 系統中的虛擬實現The Sim
- 模擬I2C總線多主通信的通用軟件包
- 模擬I2C總線多主通信的通用軟件包
- 模擬I2C總線C51程序軟件包
- i2c總線ppt(I2C總線器件應用) 0次下載
- Linux I2C驅動入門知識科普 2.5k次閱讀
- i2c總線用來做什么_i2c總線數據傳輸過程 7.8k次閱讀
- I2C總線驅動的C語言源程序詳細說明 5.9k次閱讀
- 基于I2C總線應用呼喚平臺模式實現VIIC1.0軟件包的設計 1.2k次閱讀
- I2C總線的工作原理以及優缺點解析 1.6w次閱讀
- 基于DSP虛擬I2C總線軟件包的結構設計 1.4k次閱讀
- 基于MCS-51單片機I2C總線接口電路的設計 4.1k次閱讀
- I2C總線技術在HDTV數字地面接收機中的應用解析 1.4k次閱讀
- I2C總線的工作原理解析 7.2k次閱讀
- I2C總線的特點與構成詳解 1.1w次閱讀
- I2C總線的特點、控制技術與傳輸分析 1.1w次閱讀
- i2c總線相關知識 4.1k次閱讀
- 《振南電子STM32視頻教程》第八講:I2C總線 1.3k次閱讀
- 基于FPGA的I2C SLAVE模式總線的設計方案 2w次閱讀
- 虛擬I2C總線串行顯示電路介紹 3.9k次閱讀
下載排行
本周
- 1MDD品牌三極管BC807數據手冊
- 3.00 MB | 次下載 | 免費
- 2MDD品牌三極管BC817數據手冊
- 2.51 MB | 次下載 | 免費
- 3MDD品牌三極管D882數據手冊
- 3.49 MB | 次下載 | 免費
- 4MDD品牌三極管MMBT2222A數據手冊
- 3.26 MB | 次下載 | 免費
- 5MDD品牌三極管MMBTA56數據手冊
- 3.09 MB | 次下載 | 免費
- 6MDD品牌三極管MMBTA92數據手冊
- 2.32 MB | 次下載 | 免費
- 7STM32G474 HRTIME PWM 丟波問題分析與解決
- 1.00 MB | 次下載 | 3 積分
- 8新能源電動汽車高壓線束的銅鋁連接解決方案
- 2.71 MB | 次下載 | 2 積分
本月
- 1愛華AIWA HS-J202維修手冊
- 3.34 MB | 37次下載 | 免費
- 2NB-IoT芯片廠商的資料說明
- 0.31 MB | 22次下載 | 1 積分
- 3PC5502負載均流控制電路數據手冊
- 1.63 MB | 22次下載 | 免費
- 4H110主板CPU PWM芯片ISL95858HRZ-T核心供電電路圖資料
- 0.63 MB | 6次下載 | 1 積分
- 5UWB653Pro USB口測距通信定位模塊規格書
- 838.47 KB | 5次下載 | 免費
- 6技嘉H110主板IT8628E_BX IO電路圖資料
- 2.61 MB | 4次下載 | 1 積分
- 7蘇泊爾DCL6907(即CHK-S007)單芯片電磁爐原理圖資料
- 0.04 MB | 4次下載 | 1 積分
- 8蘇泊爾DCL6909(即CHK-S009)單芯片電磁爐原理圖資料
- 0.08 MB | 2次下載 | 1 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191439次下載 | 10 積分
- 5十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183353次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81602次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73822次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發燒友App





創作
發文章
發帖
提問
發資料
發視頻
上傳資料賺積分
評論