4820
- 收藏
- 点赞
- 分享
- 举报
HI_MPI_SYS_MmzAlloc分配内存,程序出错,求助。
问题是这样的:
我在自己的程序中封装个动态库,库中调用HI_MPI_SYS_MmzAlloc分配内存:
printf("~~~~~~Debug Malloc:111111111~~~~~~~~~~~~~~~~\n");
HI_MPI_SYS_MmzAlloc(pPhyAddr, (void**)&data, NULL, HI_NULL, totalsize);
printf("~~~~~~Debug Malloc:222222222~~~~~~~~~~~~~~~~\n");
运行结果提示出错,程序直接退出。
错误提示:
~~~~~~Debug Malloc:111111111~~~~~~~~~~~~~~~~
MMB LEAK(pid=1132): 0x8854C000, 233472 bytes, ''
mmz_userdev_release: mmb<0x8854C000> mapped to userspace 0xb6719000 will be force unmaped!
Segmentation fault
还以为是没有在库中初始化MPI的原因,加上初始化代码:
static HI_S32 Library_MPI_Init(HI_VOID)
{
HI_S32 s32Ret;
VB_CONF_S struVbConf;
MPP_SYS_CONF_S struSysConf;
HI_MPI_SYS_Exit();
HI_MPI_VB_Exit();
memset(&struVbConf, 0, sizeof(VB_CONF_S));
struVbConf.u32MaxPoolCnt = 128;
struVbConf.astCommPool[0].u32BlkSize = 1920 * 1080 * 2;
struVbConf.astCommPool[0].u32BlkCnt = 40;
s32Ret = HI_MPI_VB_SetConf(&struVbConf);
if (HI_SUCCESS != s32Ret)
{
printf("HI_MPI_VB_SetConf fail,Error%d\n", s32Ret);
return s32Ret;
}
s32Ret = HI_MPI_VB_Init();
if (HI_SUCCESS != s32Ret)
{
printf("HI_MPI_VB_Init fail,Error%d\n", s32Ret);
return s32Ret;
}
struSysConf.u32AlignWidth = 16;//64;//Orignal Value 64
s32Ret = HI_MPI_SYS_SetConf(&struSysConf);
if (HI_SUCCESS != s32Ret)
{
printf("HI_MPI_SYS_SetConf fail,Error%d\n", s32Ret);
(HI_VOID)HI_MPI_VB_Exit();
return s32Ret;
}
s32Ret = HI_MPI_SYS_Init();
if (HI_SUCCESS != s32Ret)
{
printf("HI_MPI_SYS_Init fail,%d\n", s32Ret);
(HI_VOID)HI_MPI_VB_Exit();
return s32Ret;
}
return HI_SUCCESS;
}
初始化后再去进行HI_MPI_SYS_MmzAlloc分配,结果还是出错:
@@@@@@@@@@@@Debug Hi_LibInit@@@@@@@@@@@@@@@
~~~~~~Debug Malloc:111111111~~~~~~~~~~~~~~~~
MMB LEAK(pid=1132): 0x8854C000, 233472 bytes, ''
mmz_userdev_release: mmb<0x8854C000> mapped to userspace 0xb6719000 will be force unmaped!
Segmentation fault
问题是同样的初始化方法和分配在主应用程序中分配是没有问题的。
麻烦请教论坛知情人士,到底是哪里出了问题。非常感谢。。。。
我在自己的程序中封装个动态库,库中调用HI_MPI_SYS_MmzAlloc分配内存:
printf("~~~~~~Debug Malloc:111111111~~~~~~~~~~~~~~~~\n");
HI_MPI_SYS_MmzAlloc(pPhyAddr, (void**)&data, NULL, HI_NULL, totalsize);
printf("~~~~~~Debug Malloc:222222222~~~~~~~~~~~~~~~~\n");
运行结果提示出错,程序直接退出。
错误提示:
~~~~~~Debug Malloc:111111111~~~~~~~~~~~~~~~~
MMB LEAK(pid=1132): 0x8854C000, 233472 bytes, ''
mmz_userdev_release: mmb<0x8854C000> mapped to userspace 0xb6719000 will be force unmaped!
Segmentation fault
还以为是没有在库中初始化MPI的原因,加上初始化代码:
static HI_S32 Library_MPI_Init(HI_VOID)
{
HI_S32 s32Ret;
VB_CONF_S struVbConf;
MPP_SYS_CONF_S struSysConf;
HI_MPI_SYS_Exit();
HI_MPI_VB_Exit();
memset(&struVbConf, 0, sizeof(VB_CONF_S));
struVbConf.u32MaxPoolCnt = 128;
struVbConf.astCommPool[0].u32BlkSize = 1920 * 1080 * 2;
struVbConf.astCommPool[0].u32BlkCnt = 40;
s32Ret = HI_MPI_VB_SetConf(&struVbConf);
if (HI_SUCCESS != s32Ret)
{
printf("HI_MPI_VB_SetConf fail,Error%d\n", s32Ret);
return s32Ret;
}
s32Ret = HI_MPI_VB_Init();
if (HI_SUCCESS != s32Ret)
{
printf("HI_MPI_VB_Init fail,Error%d\n", s32Ret);
return s32Ret;
}
struSysConf.u32AlignWidth = 16;//64;//Orignal Value 64
s32Ret = HI_MPI_SYS_SetConf(&struSysConf);
if (HI_SUCCESS != s32Ret)
{
printf("HI_MPI_SYS_SetConf fail,Error%d\n", s32Ret);
(HI_VOID)HI_MPI_VB_Exit();
return s32Ret;
}
s32Ret = HI_MPI_SYS_Init();
if (HI_SUCCESS != s32Ret)
{
printf("HI_MPI_SYS_Init fail,%d\n", s32Ret);
(HI_VOID)HI_MPI_VB_Exit();
return s32Ret;
}
return HI_SUCCESS;
}
初始化后再去进行HI_MPI_SYS_MmzAlloc分配,结果还是出错:
@@@@@@@@@@@@Debug Hi_LibInit@@@@@@@@@@@@@@@
~~~~~~Debug Malloc:111111111~~~~~~~~~~~~~~~~
MMB LEAK(pid=1132): 0x8854C000, 233472 bytes, ''
mmz_userdev_release: mmb<0x8854C000> mapped to userspace 0xb6719000 will be force unmaped!
Segmentation fault
问题是同样的初始化方法和分配在主应用程序中分配是没有问题的。
麻烦请教论坛知情人士,到底是哪里出了问题。非常感谢。。。。
我来回答
回答3个
时间排序
认可量排序
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2019-12-25 15:11:20
-
2018-07-11 12:21:15
-
2016-11-14 10:24:15
-
2019-06-03 10:39:23
-
2015-10-10 14:40:45
-
12017-11-02 20:16:06
-
2015-04-22 13:48:48
-
2018-10-03 14:18:21
-
2016-03-21 16:08:03
-
2019-07-22 10:45:02
-
102017-04-11 15:03:50
-
2018-02-03 03:19:30
-
2022-06-21 10:34:39
-
2016-10-20 10:15:46
-
2023-07-01 16:30:02
-
2018-07-02 16:39:40
-
2019-08-21 10:09:09
-
2019-05-16 08:45:59
-
2020-11-30 20:41:48
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5SS928的emmc有32GB,bootargs设置使用16GB,但是为啥能用的只有rootfs的大小
-
33SS928怎样烧写ubuntu系统
-
10ToolPlatform下载rootfs提示网络失败
-
10谁有GK7205V500的SDK
-
5Hi3516CV610 烧录不进去
-
10Hi3559AV100 芯片硬解码h265编码格式的视频时出现视频播放错误,解码错误信息 s32PackErr:码流有错
-
5海思SS928 / SD3403的sample_venc.c摄像头编码Demo中,采集到的摄像头的YUV数据在哪个相关的函数中?
-
5海鸥派openEuler无法启动网卡,连接WIFI存在问题
-
66有没有ISP相关的巨佬帮忙看看SS928对接IMX347的图像问题
-
50求助hi3559与FPGA通过SLVS-EC接口对接问题
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认