跳到主要内容

K230系统控制MAPI参考

1. 概述

1.1 概述

系统控制根据 k230芯片特性,完成硬件各个部件的复位、基本初始化工作,同时负责完成 MPP(Media Process Platform 媒体处理平台)系统核间通讯建立,多媒体内存管理等模块的初始化、去初始化。

1.2 功能描述

MAPI的特性是跨OS调用,在K230的大小核上均可以调用相同的API来实现需要的功能。整体的系统架构如下图所示

关于MAPI中涉及绑定以及内存管理的具体内容请参考文档《K230 系统控制 API参考 V1.0》中的相关内容

2. API参考

该功能模块提供以下API:

2.1 kd_mapi_sys_init

【描述】

初始化系统资源,建立双核间的消息通信管道。为了建立双核连接,在每个操作系统上运行的服务需要在初始化过程中调用这个接口来建立连接,然后才能进行核间通信。

【语法】

k_s32 kd_mapi_sys_init(void );

【参数】

【返回值】

返回值描述
0成功
非0失败,其值参见错误码

【芯片差异】

无。

【需求】

  • 头文件:mapi_sys_api.h
  • 库文件:libmapi.a

【注意】

这个函数需要在调用kd_mapi_media_init之前被调用

【举例】

【相关主题】

2.2 kd_mapi_sys_deinit

【描述】

去初始化系统资源,断开双核间的消息通信管道。

【语法】

k_s32 kd_mapi_sys_deinit(void );

【参数】

【返回值】

返回值描述
0成功
非0失败,其值参见错误码

【芯片差异】

无。

【需求】

  • 头文件:mapi_sys_api.h
  • 库文件:libmapi.a

【注意】

当kd_mapi_sys_init没有被调用时,对这个mapi的调用返回成功。

【举例】

【相关主题】

2.3 kd_mapi_media_init

【描述】

初始化多媒体相关资源。主要是配置vb的个数和大小

【语法】

k_s32 kd_mapi_media_init(const k_mapi_media_attr_t *media_attr);

【参数】

参数名称描述输入/输出
media_attr媒体属性指针输入

【返回值】

返回值描述
0成功
非0失败,其值参见错误码

【芯片差异】

无。

【需求】

  • 头文件:mapi_sys_api.h
  • 库文件:libmapi.a

【注意】

【举例】

【相关主题】

2.4 kd_mapi_media_deinit

【描述】

去初始化多媒体相关资源。

【语法】

k_s32 kd_mapi_media_deinit(void);

【参数】

【返回值】

返回值描述
0成功
非0失败,其值参见错误码

【芯片差异】

无。

【需求】

  • 头文件:mapi_sys_api.h
  • 库文件:libmapi.a

【注意】

【举例】

【相关主题】

2.5 kd_mapi_alloc_buffer

【描述】

在用户态分配 MMZ 的内存(带cache)

【语法】

k_s32 kd_mapi_alloc_buffer(k_u64 *phys_addr, void **virt_addr, k_u32 len, const k_char *name);

【参数】

参数名称描述输入/输出
phys_addrbuffer的物理地址输出
virt_addrbuffer的虚拟地址输出
lenbuffer的长度输入
namebuffer的名称输入

【返回值】

返回值描述
0成功
非0失败,其值参见错误码

【芯片差异】

无。

【需求】

  • 头文件:mapi_sys_api.h
  • 库文件:libmapi.a

【注意】

  • Buffer 的虚拟地址和物理地址已经映射
  • 在分配内存之后在大核端msh下通过 cat /proc/umap/media-mem 查看 buffer 是否分配成功。

【举例】

【相关主题】

2.6 kd_mapi_free_buffer

【描述】

在用户态释放 MMZ 的内存。

【语法】

k_s32 kd_mapi_free_buffer(k_u64 phys_addr, void *virt_addr, k_u32 len);

【参数】

参数名称描述输入/输出
phys_addrbuffer的物理地址输入
virt_addrbuffer的虚拟地址输入
lenbuffer的长度输入

【返回值】

返回值描述
0成功
非0失败,其值参见错误码

【芯片差异】

无。

【需求】

  • 头文件:mapi_sys_api.h
  • 库文件:libmapi.a

【注意】

在释放内存之后在大核端msh下通过 cat /proc/umap/media-mem 查看 buffer 是否释放成功。

【举例】

【相关主题】

2.7 kd_mapi_sys_get_vb_block

【描述】

在用户态获取一个缓存块。

【语法】

k_s32 kd_mapi_sys_get_vb_block(k_u32 *pool_id, k_u64 *phys_addr, k_u64 blk_size, const char* mmz_name);

【参数】

参数名称描述输入/输出
pool_id缓存块所在的缓存池ID号输出
phys_addr缓存块的物理地址输出
blk_size缓存块的大小输入
mmz_name缓存池所在的ddr的名称输入

【返回值】

返回值描述
0成功
非0失败,其值参见错误码

【芯片差异】

无。

【需求】

  • 头文件:mapi_sys_api.h
  • 库文件:libmapi.a

【注意】

  • 如果用户需要从任意一个公共缓存池中获取一块指定大小的缓存块,将第 2 个参数 blk_size 设置为需要的缓存块大小,并指定要从哪个 DDR 上的公共缓存池获取缓存块。如果指定的 DDR 上并没有公共缓存池,那么将获取不到缓存块。如果mmz_name 等于 NULL,则表示在没有命名的 DDR 上的公共缓存池获取缓存块
  • 媒体初始化时,如果 VB 在没有命名的 DDR 中创建缓存池,则从任意一个公共缓存池中获取一块指定大小的缓存块, mmz_name设置为 NULL 即可

【举例】

【相关主题】

2.8 kd_mapi_sys_release_vb_block

【描述】

在用户态释放一个缓存块。

【语法】

k_s32 kd_mapi_sys_release_vb_block(k_u64 phys_addr, k_u64 blk_size);

【参数】

参数名称描述输入/输出
phys_addr缓存块的物理地址输出
blk_size缓存块的大小输入

【返回值】

返回值描述
0成功
非0失败,其值参见错误码

【芯片差异】

无。

【需求】

  • 头文件:mapi_sys_api.h
  • 库文件:libmapi.a

【注意】

获取的缓存块使用完后,应该调用此接口释放缓存块。

【举例】

【相关主题】

3. 数据类型

3.1 k_mapi_mod_id_e

【说明】

定义MAPI模块ID

【定义】


typedef enum

{

K_MAPI_MOD_SYS = 0,

K_MAPI_MOD_VI,

K_MAPI_MOD_VPROC,

K_MAPI_MOD_VENC,

K_MAPI_MOD_VDEC,

K_MAPI_MOD_VREC,

K_MAPI_MOD_VO,

K_MAPI_MOD_AI,

K_MAPI_MOD_AENC,

K_MAPI_MOD_ADEC,

K_MAPI_MOD_AREC,

K_MAPI_MOD_AO,

K_MAPI_MOD_VVI,

K_MAPI_MOD_VVO,

K_MAPI_MOD_DPU,

K_MAPI_MOD_VICAP,

K_MAPI_MOD_SENSOR,

K_MAPI_MOD_ISP,

K_MAPI_MOD_BUTT,

} k_mapi_mod_id_e;

【成员】

【注意事项】

【相关数据类型及接口】

3.2 k_mapi_media_config_t

【说明】

定义媒体配置属性结构体

【定义】


typedef struct {

k_vb_supplement_config vb_supp;

k_vb_config vb_config;

} k_mapi_media_config_t;

【成员】

成员名称描述
vb_suppVB 附加信息结构体,参见《K230 系统控制 API参考》
vb_config视频缓存池属性结构体,参见《K230 系统控制 API参考》

【注意事项】

【相关数据类型及接口】

3.3 k_mapi_media_attr_t

【说明】

定义媒体初始化属性结构体

【定义】


typedef struct {

k_mapi_media_config_t media_config;

} k_mapi_media_attr_t;

【成员】

成员名称描述
media_config媒体配置属性结构体

【注意事项】

【相关数据类型及接口】

4. 错误码

表 41

错误代码宏定义描述
0xb0008003K_MAPI_ERR_SYS_ILLEGAL_PARAM参数错误
0xb0008006K_MAPI_ERR_SYS_NULL_PTR空指针错误
0xb0008009K_MAPI_ERR_SYS_NOT_PERM操作不允许
0xb0008010K_MAPI_ERR_SYS_NOTREADY设备未就绪
0xb0008012K_MAPI_ERR_SYS_BUSY系统忙
0xb000800cK_MAPI_ERR_SYS_NOMEM分配内存失败,如系统内存不足