基于DSP和LTC1859數(shù)據(jù)采集系統(tǒng)
3 軟件設(shè)計(jì)
由于采用標(biāo)準(zhǔn) SPI總線通信,軟件的關(guān)鍵是 DSP和 LTC1859之間的時(shí)序匹配,首先介紹 LTC1859軟件配置。
3.1 LTC1859不管是在發(fā)送系統(tǒng)中還是接收系統(tǒng)中,都是在 SCK的下降沿傳輸,上升沿被捕獲,這就要求 DSP在進(jìn)行SPI初始化時(shí)采用上升沿?zé)o延時(shí)模式。8位的控制字通過 SDI輸入,用于配置 LTC1859以進(jìn)行下一個(gè)轉(zhuǎn)換,同時(shí)前一個(gè)轉(zhuǎn)換輸出在SDO上輸出,在數(shù)據(jù)交換的末端在 CONVST上施加一個(gè)上升沿啟動(dòng)被請(qǐng)求的轉(zhuǎn)換。轉(zhuǎn)換完成后,轉(zhuǎn)換結(jié)果將在將在下一個(gè)數(shù)據(jù)傳送周期提供。LTC1859的8位命令控制字在首 8個(gè) SCK的上升沿按時(shí)間順序記錄到 SDI輸入中,SDI隨后的輸入的位被忽略??刂谱值?8位定義如表 1。
其中復(fù)用器通道選擇如表 2。
其中輸入范圍選擇如表 3。
3.2 下面詳細(xì)介紹軟件編寫,考慮到 SPI總線的時(shí)鐘很快,采用查詢方式,其軟件流程如圖 2,這里只介紹LTC1859(1)的流程及源代碼,其它原理都一樣。
圖 2流程圖 Fig2 Flow chart
程序源代碼及其詳細(xì)注釋:
void SPIAD_Init()
{ MCRB=MCRB | 0x001C; // SPISIMO,SPISOMI,SPICLK特殊功能方式 SPICCR=0x000F;
// 16bit數(shù)據(jù), 上升沿?zé)o延時(shí)模式 SPICTL=0x0006; //禁止中 斷 SPIBRR=0x0004; // 8M波特率
,40M/5=8M SPICCR=SPICCR | 0x80;
}
void ADLTC()
{ PADATDIR=PADATDIR|0x1010; //將 A4即 LTC2RD置高
PADATDIR=PADATDIR0xFFFD; //將 A1即 LTC1RD置低 PADATDIR=PADATDIR0xFFFE;
//將 A0 即 LTC1CON(CONVST)置低 PADATDIR=PADATDIR|0x0101;
//將A0即LTC1CON(CONVST)拉高啟動(dòng)轉(zhuǎn)換 asm( NOP );
while((PADATDIR0x0004)!=0x0000); //等待 A2即 LTC1BUSY(BUSY)變低
PADATDIR=PADATDIR0xFFFE; //A2即 LTC1BUSY(BUSY)變低后再將 A0即 LTC1CON(CONVST)拉低
while((PADATDIR0x0004)!=0x0004); //等待 A2即 LTC1BUSY(BUSY)變高
SPITXBUF=(0x00048); // 輸入通道 1控制字,當(dāng) LTC1BUSY變高說明轉(zhuǎn)換完成 ,則可寫入下次轉(zhuǎn)換的命令字
while ((SPISTS0x0040)!=0x0040); //等待總線傳輸
SPIRXBUF=SPIRXBUF; PADATDIR=PADATDIR|0x0101; asm( NOP );
while((PADATDIR0x0004)!=0x0000);PADATDIR=PADATDIR0xFFFE;
while((PADATDIR0x0004)!=0x0004); SPITXBUF=(0x00148);
while((SPISTS0x0040)!=0x0040);
/*虛讀寄存器以清除中斷標(biāo)志*/ //將A0即LTC1CON(CONVST)拉高啟動(dòng)轉(zhuǎn)換
//等待 A2即 LTC1BUSY(BUSY)變低 //A2即 LTC1BUSY(BUSY)變低后再將 A0即
LTC1CON(CONVST)拉低 //等待 A2即 LTC1BUSY(BUSY)變高 //輸入通道 2控制字, 當(dāng)
LTC1BUSY變高說明轉(zhuǎn)換完成,則可寫入下次轉(zhuǎn)換的命令字 //等待總線傳輸
ADINRESULT[4]=(0x0FFFSPIRXBUF); /*保存轉(zhuǎn)換結(jié)果 */ SPIRXBUF= SPIRXBUF;
/*虛讀寄存器以清除中斷標(biāo)志*/ PADATDIR=PADATDIR|0X0101; //將 A0即 LTC1CON(CONVST)拉高啟動(dòng)轉(zhuǎn)換
asm( NOP ); while((PADATDIR0x0004)!=0x0000); //等待 A2即 LTC1BUSY(BUSY)變低
PADATDIR=PADATDIR0xFFFE; //A2即 LTC1BUSY(BUSY)變低后再將
A0即 LTC1CON(CONVST)拉低 while((PADATDIR0x0004)!=0x0004); //等待 A2即
LTC1BUSY(BUSY)變高 SPITXBUF=(0x00248); //輸入通道3控制字當(dāng)LTC1BUSY變高說明轉(zhuǎn)換完成,
則可寫入下次轉(zhuǎn)換的命令字
while((SPISTS0x0040)!=0x0040); //等待總線傳輸
ADINRESULT[5]=SPIRXBUF; /*保存轉(zhuǎn)換結(jié)果 */
SPIRXBUF=SPIRXBUF; /*虛讀寄存器以清除中斷標(biāo)志*/
……………………………………………通道 3、4的轉(zhuǎn)換程序原理一樣 }
4 結(jié) 論
本文作者創(chuàng)新點(diǎn)是成功實(shí)現(xiàn)了基于 DSP和 LTC1859的
16位高精度數(shù)據(jù)采集系統(tǒng),給出了全新實(shí)用的硬件和軟件設(shè)計(jì),特別適合差分信號(hào)和電壓范圍變化較大的系統(tǒng)該設(shè)計(jì),對(duì)與 LTC1859與其它的
CPU的設(shè)計(jì)也有很大的參考價(jià)值。該系統(tǒng)性價(jià)比高,具有一般通用性能,有一定的應(yīng)用推廣價(jià)值。
評(píng)論