基于Spartan-6的高速數(shù)據(jù)采集、處理和實(shí)時(shí)傳輸研究
開0號(hào)設(shè)備,
本文引用地址:http://www.ex-cimer.com/article/201612/326826.htmCCyUSBEndPoint *endpt = USBDevice->EndPointOf(0X82); //使用端點(diǎn)2,in傳輸可以看到,上面的只需要3行代碼,比枚舉簡(jiǎn)潔方便多了。至于獲取USB其他屬性,這里列出經(jīng)常使用的幾個(gè):(1)USBDevice->DeviceCount()//返回連接到電腦的USB設(shè)備個(gè)數(shù),從0,1,2.開始命名(2)USBDevice->DeviceName()//返回USB設(shè)備名稱,也就是固件中 StringDscr2:字段字符串。(3)USBDevice->VendorID//返回USB設(shè)備VIDUSBDevice->ProductID//返回USB設(shè)備PID。具體的可參考cyapi的文檔,在CCyUSBDevice和CCyUSBEndPoint這兩個(gè)類里可查詢到。
4)傳輸命令控制
可以說,寫USB上位機(jī),要對(duì)固件進(jìn)行自定義命令傳輸,通常都是用輸入輸出控制傳輸進(jìn)行的,即使用控制傳輸in或者out方式實(shí)現(xiàn)對(duì)固件的自定義命令。
(1)out控制傳輸發(fā)送vendor命令
采用out方式應(yīng)該比較符合大家的思維,因?yàn)槭菑纳衔粰C(jī)發(fā)命令到下位機(jī),怎么看都應(yīng)該是out而不是in。例如你在固件里設(shè)置了out的接收buf:
BOOL DR_VendorCmnd(void)
{
switch (SETUPDAT[1])
{
case 0xDD:
{ temp=EP0BUF[0];
EP0BCH=0;
EP0BCL=1;
EP0CS |=bmHSNAK;
break;
}
default:
return(TRUE);
}
return(FALSE);
}
在VS2008的C++/MFC中:
CCyControlEndPoint* CtlEndpoint;//定義一個(gè)控制端點(diǎn)
CtlEndpoint->Target = TGT_DEVICE;//不必關(guān)注,固定
CtlEndpoint->ReqType = REQ_VENDOR; //請(qǐng)求類型:自定義請(qǐng)求(標(biāo)準(zhǔn)請(qǐng)求等)CtlEndpoint->Direction = DIR_TO_DEVICE; //傳輸方向:主機(jī)->usb設(shè)備(out)
CtlEndpoint->ReqCode = 0XDD; //自定義請(qǐng)求碼
CtlEndpoint->Value = 0; //這里的設(shè)定值將傳給setupdat的[2:3]位
CtlEndpoint->Index = 0; //這里的設(shè)定值將傳給setupdat的[4:5];PUCHAR buf=new UCHAR[1];
ZeroMemory(buf,1);//用0填充buf區(qū),填充大小(1字節(jié))
long buflen=1;//傳輸?shù)钠渌止?jié)數(shù):cy控制臺(tái)console中l(wèi)ength的值。
CtlEndpoint->XferData(buf,buflen);
當(dāng)然,沒有規(guī)定說一定必須傳給下位機(jī)至少一個(gè)字節(jié)的數(shù)據(jù);你也可以不傳;不過最好下位機(jī)同樣設(shè)置接收字節(jié)為0,否則小心有莫名奇妙的錯(cuò)誤(XX內(nèi)存不能為只讀等等)。
將temp=EP0BUF[0];去掉,上位機(jī):
PUCHAR buf=new UCHAR; //用0填充buf區(qū),填充大小(1字節(jié))
long buflen=0;
CtlEndpoint->XferData(buf,buflen);
也是可以的,另外,控制傳輸請(qǐng)盡量用同步的xferdata()而不是異步的begindataxfer()。
(2)in控制傳輸發(fā)送vendor命令
基本上,跟out區(qū)別不大。固件中:
BOOL DR_VendorCmnd(void)
{
switch (SETUPDAT[1])
{
case 0xDD:
{
*EP0BUF=0XDD;
EP0BCH=0;
EP0BCL=1;
EP0CS |=bmHSNAK;
break;
}
default:
return(TRUE);
}
return(FALSE);
}
VC中:CCyControlEndPoint* CtlEndpoint; //定義一個(gè)控制端點(diǎn)
CtlEndpoint->Target = TGT_DEVICE;//不必關(guān)注,固定
CtlEndpoint->ReqType= REQ_VENDOR; //請(qǐng)求類型:自定義請(qǐng)求(標(biāo)準(zhǔn)請(qǐng)求等)CtlEndpoint->Direction = DIR_FROM_DEVICE; //傳輸方向:usb設(shè)備->主機(jī)(in)CtlEndpoint->ReqCode = 0XDD; //自定義請(qǐng)求碼CtlEndpoint->Value = 0;//這里的設(shè)定值將傳給setupdat的[2:3]位CtlEndpoint->Index = 0; //這里的設(shè)定值將傳給setupdat的[4:5]位PUCHAR buf=new UCHAR[1];
ZeroMemory(buf,1); //用0填充buf區(qū),填充大小(1字節(jié))
long buflen=1; //傳輸?shù)钠渌止?jié)數(shù):cy控制臺(tái)console中l(wèi)ength的值CtlEndpoint->XferData(buf,buflen);這里的話,推薦盡量設(shè)置接收緩沖,不要將buflen設(shè)置為0.同樣,控制傳輸請(qǐng)盡量用同步的xferdata()而不是異步的begindataxfer()。
(3)另外,還有兩個(gè)簡(jiǎn)化版本的函數(shù)Write(out傳輸)和Read(in傳輸)也可以進(jìn)行控制傳輸。其作用同XferData()是一樣的,因?yàn)橐呀?jīng)明確表示了是in還是out,所以Direction 項(xiàng)的值就省略了。只是看起來代碼更加簡(jiǎn)潔,輸入效率更高而已。基本上,大多數(shù)時(shí)候,使用Write和Read會(huì)方便很多。
CCyControlEndPoint* CtlEndpoint; //定義一個(gè)控制端點(diǎn)
CtlEndpoint->Target = TGT_DEVICE; //不必關(guān)注,固定
CtlEndpoint->ReqType = REQ_VENDOR; //請(qǐng)求類型:自定義請(qǐng)求(標(biāo)準(zhǔn)請(qǐng)求等)CtlEndpoint->ReqCode = 0XDD; //自定義請(qǐng)求碼CtlEndpoint->Value = 0; //這里的設(shè)定值將傳給setupdat的[2:3]位CtlEndpoint->Index = 0; //這里的設(shè)定值將傳給setupdat的[4:5]位PUCHAR buf=new UCHAR[1];ZeroMemory(buf,1);//用0填充buf區(qū),填充大小(1字節(jié)) long buflen=1; //傳輸?shù)钠渌止?jié)數(shù):cy控制臺(tái)console中l(wèi)ength的值CtlEndpoint->Write(buf,buflen);
Read的話同理。
評(píng)論