2293
- 收藏
- 点赞
- 分享
- 举报
Hi3516a 在驅動 ˋ中 實現 DMA memory to memory 的問題
大家好~
小弟參考SDK裡的 /driver/hidmac 在驅動中實現DMA memory to memory時遇到了一些問題 , 不知道有沒有高手可以幫忙指點一下 , 感激不盡~
1. DMAC_Cn_CONTROL裡的傳輸位寬與burst長度之間的關係到底是? 小弟目前位寬只能設定到8位元 , 超過8位元就kernel panic , 不知道是哪裡出錯了?
2. DMA傳輸速度慢 , dma過程沒有報錯 , 但相同的資料量用DMA傳輸竟然比memcpy還要慢上10倍以上 , cpu使用率也飆高很多 , 這到底是小弟的DMA配置問題還是3516a的dma本來就慢?
以下是小弟在驅動中寫的一段dma測試程式 , 不知道是否哪裡有弄錯?
unsigned char *src_data = NULL;
unsigned char *dest_data = NULL;
unsigned char *src_data_phy = NULL;
unsigned char *dest_data_phy = NULL;
src_data = (unsigned char*)kmalloc(data_len, GFP_KERNEL);
dest_data = (unsigned char*)kmalloc(data_len, GFP_KERNEL);
memcpy(src_data, data, data_len);
src_data_phy = (unsigned char*)virt_to_phys(src_data);
dest_data_phy = (unsigned char*)virt_to_phys(dest_data);
do_dma_m2m((unsigned int)src_data_phy, (unsigned int)dest_data_phy, data_len); //從hi_dmac.c中EXPORT出來的
小弟參考SDK裡的 /driver/hidmac 在驅動中實現DMA memory to memory時遇到了一些問題 , 不知道有沒有高手可以幫忙指點一下 , 感激不盡~
1. DMAC_Cn_CONTROL裡的傳輸位寬與burst長度之間的關係到底是? 小弟目前位寬只能設定到8位元 , 超過8位元就kernel panic , 不知道是哪裡出錯了?
2. DMA傳輸速度慢 , dma過程沒有報錯 , 但相同的資料量用DMA傳輸竟然比memcpy還要慢上10倍以上 , cpu使用率也飆高很多 , 這到底是小弟的DMA配置問題還是3516a的dma本來就慢?
以下是小弟在驅動中寫的一段dma測試程式 , 不知道是否哪裡有弄錯?
unsigned char *src_data = NULL;
unsigned char *dest_data = NULL;
unsigned char *src_data_phy = NULL;
unsigned char *dest_data_phy = NULL;
src_data = (unsigned char*)kmalloc(data_len, GFP_KERNEL);
dest_data = (unsigned char*)kmalloc(data_len, GFP_KERNEL);
memcpy(src_data, data, data_len);
src_data_phy = (unsigned char*)virt_to_phys(src_data);
dest_data_phy = (unsigned char*)virt_to_phys(dest_data);
do_dma_m2m((unsigned int)src_data_phy, (unsigned int)dest_data_phy, data_len); //從hi_dmac.c中EXPORT出來的
我来回答
回答1个
时间排序
认可量排序
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2017-04-28 15:23:17
-
2018-01-16 10:04:46
-
2017-06-28 15:15:46
-
2015-06-23 17:50:29
-
2017-05-10 10:08:40
-
2014-09-26 22:19:39
-
2016-10-18 11:44:24
-
2016-11-17 16:57:00
-
2019-07-14 16:00:45
-
2016-08-09 10:24:06
-
2018-05-17 12:12:49
-
32017-10-22 09:00:20
-
2018-10-31 09:30:16
-
2016-10-12 17:22:32
-
2014-05-26 16:32:18
-
2014-10-22 17:41:19
-
2015-01-22 10:24:55
-
2018-04-24 09:58:27
-
2015-02-09 15:38:23
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5Hi3516CV610 如何使用SD卡升级固件
-
5cat /dev/logmpp 报错 <3>[ vi] [func]:vi_send_frame_node [line]:99 [info]:vi pic queue is full!
-
50如何获取vpss chn的图像修改后发送至vo
-
5FPGA通过Bt1120传YUV422数据过来,vi接收不到数据——3516dv500
-
50SS928 运行PQtools 拼接 推到设备里有一半画面会异常
-
53536AV100的sample_vdec输出到CVBS显示
-
10海思板子mpp怎么在vi阶段改变视频数据尺寸
-
10HI3559AV100 多摄像头同步模式
-
9海思ss928单路摄像头vio中加入opencv处理并显示
-
10EB-RV1126-BC-191板子运行自己编码的程序
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认