STM32F103系列USB問題
1. usb和can公用512B的RAM,但是RAm地址為0x40006000-0x40006400,分明為1KB啊,為什么還是說512B.
2. 若PC機讀RAM中數(shù)據(jù)時,我同時對RAM進行寫操作,怎么辦,我感覺庫中并沒有對這種操作進行處理啊。
3. 對于緩沖區(qū),不理解為什么給了個地址,又同時給了個USB本地地址,并且我認為,地址偏移應(yīng)該為[USB_BTABLE]*2+n*16+(0,4,8,12),也就是緩沖區(qū)描述表也應(yīng)該擴大2倍,不知道是不是
4.不理解為什么USB_BTABLE設(shè)置成13+3位的,反正一共就512B(我理解為1K),8位就夠了
1)這個緩沖區(qū)是個雙端口RAM,CPU一端是以32位寬訪問,而USB一端是以16位寬訪問,因此從CPU端看浪費了一半的地址空間,即從CPU端讀出32位數(shù)據(jù)時只有16位是有效的;所以1KB的地址空間,實際只有512字節(jié)的存儲空間。
2)因為這個緩沖區(qū)是個雙端口RAM,所以你不用擔(dān)心訪問沖突的問題,硬件會協(xié)調(diào)它們之間的操作。
3)因為這個緩沖區(qū)是個雙端口RAM,所以有2個地址空間,一個是從CPU端看,另一個是從USB收發(fā)器那一端看。
4)不明白你說的"USB_BTABLE設(shè)置成13+3位"是什么意思。
----------------------------------------------------
1.您說的usb收發(fā)器應(yīng)該指的的是stm芯片內(nèi)核中的獨立模塊,這個我沒有理解錯吧,還有usb端寫ram應(yīng)該是按字對其的是吧,比方說寫的地址為0x00,0x01,然后0x02,0x03不寫,再寫0x04和0x05,我沒有理解錯吧
2.即使是ram同一時刻也只能又一個控制器對指定地址進行操作啊,而開始時,usb控制器以及經(jīng)addr和count讀取到內(nèi)部控制內(nèi)核中了,cpu再一次操作后不就會改變addr和count,而usb控制器的addr和count也沒有改變,怎么回事,我有點轉(zhuǎn)不過來
3.我的意思是沒必要把usb_btable設(shè)置成那么多位,因為就沒有那么大的地址空間,可以尋址,比如說設(shè)置成0xfff8,這個已經(jīng)超出緩沖區(qū)范圍了
1)可以這么理解。但更準(zhǔn)確地說是,USB收發(fā)器寫RAM時,如果從CPU端看,寫的地址為0x00、0x01,然后0x02、0x03不寫,再寫0x04、0x05;但是USB收發(fā)器寫RAM時,如果從USB端看,寫的地址就是連續(xù)的,即0x00、0x01、0x02、0x03........。
2)你還沒有明白雙端口RAM的構(gòu)造,它有2個地址總線和2個操作計數(shù)器,CPU端和USB收發(fā)器端各有一個地址總線和一個操作計數(shù)器。
3)不錯,沒必要把usb_btable設(shè)置成那么多位,即使這樣與你的操作有什么關(guān)系嗎?不管怎樣你都不能設(shè)置超出緩沖區(qū)范圍的參數(shù)。
----------------------------
STM32F103沒有集成USB Host Controller,STM32F105或STM32F107集成了USB Host Controller。
評論