3493
- 收藏
- 点赞
- 分享
- 举报
HI3556双系统使用Datafifo异常,mmap提示Operation not permitted
本帖最后由 chuxian 于 2019-10-10 18:30 编辑
在3556双系统中,使用datafifo传输数据,liteos作为写端,Linux作为读端。
在Linux端使用HI_DATAFIFO_OpenByAddr时候,提示如下错误:
[code]ERROR: MMAP ADDR: 0x843ea000-0x84460000
mmap error: Operation not permitted
HI_MPI_SYS_Mmap addr:84464000, len:11440 error.
[AENC] [MAPI_AENC_OpenDatafifoReader][ 207][Info]:MAPI_AENC_OpenDatafifoReader fail s32Ret:6660[/code]
提示Operation not permitted,这个要映射的地址0x843ea000是liteos作为写端申请的liteos MMZ地址。
根据上面的信息,猜测HI_DATAFIFO_OpenByAddr函数其实内部调用了HI_MPI_SYS_Mmap 函数,然后HI_MPI_SYS_Mmap 内部又调用mmap进行内存映射,但是mmap时候使用的设备文件是/dev/mmz_userdev,因此我直接写代码使用mmap进行内存映射,分别使用/dev/mmz_userdev 和 /dev/mem作为mmap的设备文件,代码片段如下:
[code] if (atoi(argv[1]) == 1)
{
g_s32MapFd = open("/dev/mmz_userdev", O_RDWR | O_SYNC);
if (g_s32MapFd < 0) {
printf("open AENC_MEM_DEV error\n");
return -1;
};
}
else
{
g_s32MapFd = open("/dev/mem", O_RDWR | O_SYNC);
if (g_s32MapFd < 0) {
printf("open AENC_MEM_DEV error\n");
return -1;
}
}
//gTestDataPhyAddr = 0x42825000;
gTestDataPhyAddr = 0x86456000;
pDataVirtAddr = mmap(NULL, 4096, PROT_READ | PROT_WRITE, MAP_SHARED, g_s32MapFd,
gTestDataPhyAddr);[/code]
发现使用/dev/mmz_userdev时候,提示Operation not permitted,使用/dev/mem则正常,没有错误提示。
不太清楚是哪里有问题,也没有找到思路,请教各位大神是否遇到过这种情况或者有什么调试思路?
在3556双系统中,使用datafifo传输数据,liteos作为写端,Linux作为读端。
在Linux端使用HI_DATAFIFO_OpenByAddr时候,提示如下错误:
[code]ERROR: MMAP ADDR: 0x843ea000-0x84460000
mmap error: Operation not permitted
HI_MPI_SYS_Mmap addr:84464000, len:11440 error.
[AENC] [MAPI_AENC_OpenDatafifoReader][ 207][Info]:MAPI_AENC_OpenDatafifoReader fail s32Ret:6660[/code]
提示Operation not permitted,这个要映射的地址0x843ea000是liteos作为写端申请的liteos MMZ地址。
根据上面的信息,猜测HI_DATAFIFO_OpenByAddr函数其实内部调用了HI_MPI_SYS_Mmap 函数,然后HI_MPI_SYS_Mmap 内部又调用mmap进行内存映射,但是mmap时候使用的设备文件是/dev/mmz_userdev,因此我直接写代码使用mmap进行内存映射,分别使用/dev/mmz_userdev 和 /dev/mem作为mmap的设备文件,代码片段如下:
[code] if (atoi(argv[1]) == 1)
{
g_s32MapFd = open("/dev/mmz_userdev", O_RDWR | O_SYNC);
if (g_s32MapFd < 0) {
printf("open AENC_MEM_DEV error\n");
return -1;
};
}
else
{
g_s32MapFd = open("/dev/mem", O_RDWR | O_SYNC);
if (g_s32MapFd < 0) {
printf("open AENC_MEM_DEV error\n");
return -1;
}
}
//gTestDataPhyAddr = 0x42825000;
gTestDataPhyAddr = 0x86456000;
pDataVirtAddr = mmap(NULL, 4096, PROT_READ | PROT_WRITE, MAP_SHARED, g_s32MapFd,
gTestDataPhyAddr);[/code]
发现使用/dev/mmz_userdev时候,提示Operation not permitted,使用/dev/mem则正常,没有错误提示。
不太清楚是哪里有问题,也没有找到思路,请教各位大神是否遇到过这种情况或者有什么调试思路?
我来回答
回答2个
时间排序
认可量排序
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2020-05-25 11:04:20
-
2018-02-05 23:39:06
-
2018-04-20 10:46:43
-
12018-03-14 17:00:57
-
2020-06-12 13:52:19
-
2020-06-13 12:20:03
-
2020-06-12 15:43:50
-
2015-03-16 19:18:04
-
2020-06-13 12:02:21
-
2020-12-08 14:42:55
-
2017-11-15 11:55:15
-
2020-12-05 16:05:45
-
2019-08-14 11:55:02
-
2017-05-05 15:59:26
-
2020-11-22 14:40:23
-
2020-11-21 17:58:42
-
2018-02-03 14:48:32
-
2019-05-02 19:41:38
-
2019-01-06 10:15:07
无更多相似问答 去提问
点击登录
-- 积分
-- 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币)
取消
确认