19.7.1.3
定義傳輸源和目標(biāo)存儲(chǔ)器
首先,要使用DMA傳輸,就肯定要有一個(gè)源地址和一個(gè)目標(biāo)地址,這里我們定義SRC_Buffer數(shù)組的首地址作為源地址,DST_Buffer數(shù)組的首地址作為DMAC傳輸?shù)哪繕?biāo)地址。SRC_Buffer數(shù)組由于有const聲明為常量,因此其數(shù)據(jù)存儲(chǔ)在內(nèi)部Flash 中,DST_Buffer為普通的全局變量,其數(shù)據(jù)存儲(chǔ)在RAM中。這兩個(gè)數(shù)組的大小由宏定義BUFFER_SIZE來決定。
列表2:代碼清單20?1 定義傳輸源和目標(biāo)存儲(chǔ)器
左右滑動(dòng)查看完整內(nèi)容
// 用戶要發(fā)送的數(shù)據(jù)大小
#defineBUFFER_SIZE 32
/**
* 定義 SRC_Buffer 數(shù)組作為 DMAC 傳輸數(shù)據(jù)源
* const 關(guān)鍵字將 SRC_Buffer 數(shù)組變量定義為常量類型,數(shù)據(jù)存儲(chǔ)在內(nèi)部的 FLASH 中
*/
constuint32_tSRC_Buffer[BUFFER_SIZE] = {
0x01020304,0x05060708,0x090A0B0C,0x0D0E0F10,
0x11121314,0x15161718,0x191A1B1C,0x1D1E1F20,
0x21222324,0x25262728,0x292A2B2C,0x2D2E2F30,
0x31323334,0x35363738,0x393A3B3C,0x3D3E3F40,
0x41424344,0x45464748,0x494A4B4C,0x4D4E4F50,
0x51525354,0x55565758,0x595A5B5C,0x5D5E5F60,
0x61626364,0x65666768,0x696A6B6C,0x6D6E6F70,
0x71727374,0x75767778,0x797A7B7C,0x7D7E7F80};
/**
* 定義 DMAC 傳輸目標(biāo)存儲(chǔ)器
* 存儲(chǔ)在內(nèi)部的 SRAM 中
*/
uint32_tDST_Buffer[BUFFER_SIZE] = {0};
19.7.1.4
設(shè)置源地址和目標(biāo)地址函數(shù)
DMAC傳輸?shù)呐渲?,可以選擇在FSP配置界面中進(jìn)行配置,但是要注意,在FSP配置界面中進(jìn)行配置的話是不方便配置傳輸?shù)刂返?,所以此時(shí)我們其實(shí)還沒有配置傳輸?shù)脑吹刂泛湍繕?biāo)地址,這部分需要在代碼里面配置。
列表3:代碼清單20?2 設(shè)置源地址和目標(biāo)地址函數(shù)
左右滑動(dòng)查看完整內(nèi)容
/* 設(shè)置傳輸?shù)脑吹刂泛湍康牡刂?*/ voidset_transfer_dst_src_address(transfer_cfg_tconst *constp_config, voidconst * volatile p_src, voidconst * volatile p_dest ) { p_config->p_info->p_src = (void*) p_src; p_config->p_info->p_dest = (void*) p_dest; }
19.7.1.5
使用FSP配置器生成的配置
前面我們?cè)贔SP配置界面上的配置其實(shí)是保存在hal_data.c文件中。如下圖所示。

我們完全可以在hal_data.c文件中找到定義好的數(shù)據(jù),重新復(fù)制一份,再改個(gè)變量名,在此基礎(chǔ)上重新配置各個(gè)參數(shù)。在本例程中也使用了這種方法,主要是為了使用宏去方便切換不同模式的配置代碼,在代碼中配置DMAC。在頭文件“bsp_dmac_m2m.h”中,默認(rèn)定義了USE_MY_TRANSFER_INFOR_CONFIG來選擇使用我們?cè)诖a里自定義的傳輸信息配置,但是現(xiàn)在讓我們先注釋掉這個(gè)宏定義,從而選擇使用在FSP配置界面上的配置。
下面的是與我們之前在FSP配置界面上的配置等效的配置代碼:
列表4:代碼清單20?3與FSP配置界面上的配置等效的配置代碼
左右滑動(dòng)查看完整內(nèi)容
/* FSP 配置界面的傳輸信息配置(正常傳輸模式)等效于下面 fsp_transfer_info_normal 里
的配置(除了源地址和目標(biāo)地址)
源地址和目標(biāo)地址在 FSP 配置界面設(shè)置的話不太方便,我們會(huì)在 DMAC_Init 函數(shù)里設(shè)置。
關(guān)于偏移值(Offset value)和源緩沖大小(Source Buffer Size),在 transfer_info_
→t 里沒有這兩項(xiàng)設(shè)置,建議在 FSP 配置界面設(shè)置
- 偏移值只有在地址模式是偏移模式的情況下才會(huì)用到;
- 而源緩沖大小與之相關(guān)的功能本例程不會(huì)涉及到,所以暫不考慮。
下面的 fsp_transfer_info_normal 僅作為對(duì)比參考,在本例程中是沒有用到的。
*/
//transfer_info_t fsp_transfer_info_normal =
//{
// .transfer_settings_word_b.dest_addr_mode = TRANSFER_ADDR_MODE_FIXED,?
→//每次傳輸后,目標(biāo)地址指針固定不變
// .transfer_settings_word_b.repeat_area = TRANSFER_REPEAT_AREA_
→SOURCE,//源區(qū)域重復(fù) (正常模式下無效)
// .transfer_settings_word_b.irq = TRANSFER_IRQ_END, ?
→//傳輸完成后中斷
// .transfer_settings_word_b.chain_mode = TRANSFER_CHAIN_MODE_
→DISABLED,//不使能(DMAC 沒有該功能,僅 DTC 有)
// .transfer_settings_word_b.src_addr_mode = TRANSFER_ADDR_MODE_FIXED,?
→//每次傳輸后,源地址指針固定不變
// .transfer_settings_word_b.size = TRANSFER_SIZE_2_BYTE, ?
→//每次傳輸 2 字節(jié)
// .transfer_settings_word_b.mode = TRANSFER_MODE_NORMAL, ?
→//正常傳輸模式
// .p_dest = (void *) DST_Buffer, ?
→//目標(biāo)地址
// .p_src = (void const *) SRC_Buffer,
→//源地址
// .num_blocks = 0, //指定傳輸?shù)膲K數(shù)(正常模式下無效,僅在重復(fù)、塊或
重復(fù)-塊模式下有效)
// .length = 1, //指定傳輸?shù)拈L(zhǎng)度(即正常和重復(fù)模式下的傳輸次數(shù)?
→或 塊和重復(fù)-塊模式下傳輸?shù)膲K大小)
//};
// 按照上述傳輸信息配置,期待的正確傳輸結(jié)果為:
uint32_tExpected_DST_Buffer[BUFFER_SIZE] = {
0x00000304,0x00000000,0x00000000,0x00000000,
0x00000000,0x00000000,0x00000000,0x00000000,
0x00000000,0x00000000,0x00000000,0x00000000,
0x00000000,0x00000000,0x00000000,0x00000000,
0x00000000,0x00000000,0x00000000,0x00000000,
0x00000000,0x00000000,0x00000000,0x00000000,
0x00000000,0x00000000,0x00000000,0x00000000,
0x00000000,0x00000000,0x00000000,0x00000000};
可以看到,上述代碼中的傳輸信息結(jié)構(gòu)體變量fsp_transfer_info_normal被完全注釋掉了,因?yàn)樵诒纠讨校肋h(yuǎn)不會(huì)用到該變量,即使取消了注釋也是一樣,雖然取消注釋后編譯也不會(huì)報(bào)錯(cuò)。該變量在這里的目的僅是方便與我們之前在FSP配置界面上的傳輸配置進(jìn)行比較,兩者的配置基本上是等效的。
本例程中需要用到的是Expected_DST_Buffer數(shù)組,其中保存的數(shù)據(jù)是根據(jù)源數(shù)據(jù)SRC_Buffer和當(dāng)前的傳輸配置得出的正確結(jié)果,我們?cè)谶M(jìn)行實(shí)際上的傳輸結(jié)束后也應(yīng)該在DST_Buffer數(shù)組中獲得這樣的數(shù)據(jù)。換句話說,SRC_Buffer保存了要傳輸?shù)脑磾?shù)據(jù),DST_Buffer保存了傳輸后的實(shí)際結(jié)果,Expected_DST_Buffer則保存的是傳輸后的正確結(jié)果,后面還會(huì)通過DST_Buffer與Expected_DST_Buffer數(shù)組中數(shù)據(jù)的對(duì)比,來判斷傳輸是否成功。
19.7.1.6
使用代碼配置:正常傳輸模式
下面是DMAC在正常模式下傳輸?shù)呐渲么a:
列表5:代碼清單20?4 DMAC正常傳輸模式配置
左右滑動(dòng)查看完整內(nèi)容
/* 正常傳輸模式 */
transfer_info_tmy_transfer_info_normal =
{
.transfer_settings_word_b.dest_addr_mode = TRANSFER_ADDR_MODE_
→INCREMENTED,//每次傳輸后,目標(biāo)地址指針都會(huì)增加
.transfer_settings_word_b.repeat_area = TRANSFER_REPEAT_AREA_SOURCE,
→//源區(qū)域重復(fù) (正常模式下無效)
.transfer_settings_word_b.irq = TRANSFER_IRQ_END, ?
→//傳輸完成后中斷
.transfer_settings_word_b.chain_mode = TRANSFER_CHAIN_MODE_
→DISABLED,//不使能(DMAC 沒有該功能,僅 DTC 有)
.transfer_settings_word_b.src_addr_mode = TRANSFER_ADDR_MODE_
→INCREMENTED,//每次傳輸后,源地址指針都會(huì)增加
.transfer_settings_word_b.size = TRANSFER_SIZE_4_BYTE, ?
→//每次傳輸 4 字節(jié)
.transfer_settings_word_b.mode = TRANSFER_MODE_NORMAL, ?
→//正常傳輸模式
.p_dest = (void*) DST_Buffer, ?
→//目標(biāo)地址
.p_src = (voidconst *) SRC_Buffer, ?
→//源地址
.num_blocks =0,//指定傳輸?shù)膲K數(shù)(正常模式下無效,僅在重復(fù)、塊或重
復(fù)-塊模式下有效)
.length = BUFFER_SIZE,//指定傳輸?shù)拈L(zhǎng)度(即正常和重復(fù)模式下的傳輸次數(shù) 或?
→塊和重復(fù)-塊模式下傳輸?shù)膲K大?。?};
// 按照上述傳輸信息配置,期待的正確傳輸結(jié)果為:
uint32_tExpected_DST_Buffer[BUFFER_SIZE] = {
0x01020304,0x05060708,0x090A0B0C,0x0D0E0F10,
0x11121314,0x15161718,0x191A1B1C,0x1D1E1F20,
0x21222324,0x25262728,0x292A2B2C,0x2D2E2F30,
0x31323334,0x35363738,0x393A3B3C,0x3D3E3F40,
0x41424344,0x45464748,0x494A4B4C,0x4D4E4F50,
0x51525354,0x55565758,0x595A5B5C,0x5D5E5F60,
0x61626364,0x65666768,0x696A6B6C,0x6D6E6F70,
0x71727374,0x75767778,0x797A7B7C,0x7D7E7F80};
注
在本例程中使用以上代碼需在頭文件“bsp_dmac_m2m.h”中定義宏USE_MY_TRANSFER_INFOR_CONFIG,并且 定義宏DMAC_TRANSFER_MODE等DMAC_TRANSFER_NORMAL_MODE來選擇。傳輸模式為:正常傳輸模式。
傳輸信息結(jié)構(gòu)體變量my_transfer_info_normal用于對(duì)DMAC的傳輸進(jìn)行重配置。
讀者可跳到本章后面的“下載驗(yàn)證”小節(jié),編譯并下載程序來驗(yàn)證本實(shí)驗(yàn)例程運(yùn)行結(jié)果。
-
存儲(chǔ)器
+關(guān)注
關(guān)注
39文章
7737瀏覽量
171629 -
瑞薩
+關(guān)注
關(guān)注
37文章
22481瀏覽量
90819 -
函數(shù)
+關(guān)注
關(guān)注
3文章
4417瀏覽量
67490 -
dma
+關(guān)注
關(guān)注
3文章
581瀏覽量
105910
原文標(biāo)題:定義傳輸源和目標(biāo)存儲(chǔ)器——瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南(55)
文章出處:【微信號(hào):瑞薩嵌入式小百科,微信公眾號(hào):瑞薩嵌入式小百科】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
瑞薩RA系列MCU FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南(09)存儲(chǔ)器映射
瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南之DTC外部中斷觸發(fā)傳輸實(shí)驗(yàn)
瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南之I2C讀寫EEPROM實(shí)驗(yàn)
瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南之常用存儲(chǔ)器介紹
瑞薩e2studio(1)----瑞薩芯片之搭建FSP環(huán)境
【瑞薩RA6E2地奇星開發(fā)板試用】介紹、環(huán)境搭建、工程測(cè)試
【瑞薩RA4系列開發(fā)板體驗(yàn)】開發(fā)環(huán)境搭建和新手點(diǎn)燈指南
【瑞薩RA4系列開發(fā)板體驗(yàn)】10. 我的試用總結(jié)
【瑞薩RA4系列開發(fā)板體驗(yàn)】1、開發(fā)板要來了(1)
【瑞薩RA4系列開發(fā)板體驗(yàn)】體驗(yàn)過程
瑞薩推出SH7216系列32-位片上Flash存儲(chǔ)器MCU
瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南之定義傳輸源和目標(biāo)存儲(chǔ)器
評(píng)論