视频数据获取功能
当前需通过以下功能模块的配合实现视频数据获取功能:
- ISP系统控制
系统控制部分用于注册3A算法、注册Sensor驱动、初始化ISP firmware、运行ISP firmware、退出ISP firmware、配置ISP属性等功能。
- MIPI Rx ioctl命令字
MIPI Rx是一个支持多种差分视频输入接口的采集单元,通过combo-PHY接收MIPI/LVDS/sub-LVDS/HiSPi接口的数据,通过不同的功能模式配置,MIPI Rx可以支持多种速度和分辨率的数据传输需求,支持多种外部输入设备。
- VI(Vedio Input)
VI模块捕获视频图像,可对其做裁剪、防抖、颜色优化、亮度优化、噪声去除等处理,并输出YUV或RAW格式的图像数据。
总体接口调用流程
接口调用流程说明如下:
- 调用hi_mpi_sys_init接口初始化媒体数据处理系统。
- 使用MIPI Rx ioctl命令字初始化MIPI/Sensor硬件对接信息,接口调用流程请参见初始化MIPI/SENSOR硬件对接信息。
- 使用VI(Vedio Input)功能接口初始化VI模块,接口调用流程请参见初始化VI视频输入模块。
- 使用ISP(Image Signal Processing)系统控制接口初始化并运行ISP模块,接口调用流程请参见初始化并运行ISP图像信号处理模块。
- 使用VI功能接口获取已处理的图像数据,接口调用流程请参见获取已处理的图像数据。
- 使用ISP功能接口释放ISP模块资源,接口调用流程请参见释放ISP图像信号处理模块资源。
- 使用VI功能接口释放VI模块资源,接口调用流程请参见释放VI视频输入模块资源。
- 使用MIPI Rx ioctl命令字退出MIPI/Sensor硬件,接口调用流程请参见退出MIPI/SENSOR硬件。
- 调用hi_mpi_sys_exit接口释放媒体数据处理系统资源。
初始化MIPI/SENSOR硬件对接信息
- 使用HI_MIPI_SET_HS_MODE命令字设置模式。
- 使用HI_MIPI_ENABLE_MIPI_CLOCK命令字打开MIPI时钟。
- 使用HI_MIPI_RESET_MIPI命令字复位SENSOR所对接的MIPI。
- (可选)使用HI_MIPI_CONFIG_SENSOR_CLOCK命令字配置SENSOR时钟。
- (可选)使用HI_MIPI_ENABLE_SENSOR_CLOCK命令字打开SENSOR时钟。
- 使用HI_MIPI_RESET_SENSOR命令字复位SENSOR。
- 使用HI_MIPI_SET_DEV_ATTR命令字配置MIPI Rx/设备属性。
- 使用HI_MIPI_UNRESET_MIPI命令字撤销复位MIPI。
- 使用HI_MIPI_UNRESET_SENSOR命令字撤销复位SENSOR。
初始化VI视频输入模块
不同数据来源、不同数据格式、不同模式,初始化VI视频输入模块的流程不同。
处理方式 |
接口调用流程 |
流程说明 |
---|---|---|
从Sensor传入数据,若要获取YUV格式的数据,则通过VI通道处理,线性模式 |
|
|
从Sensor传入数据,若要获取YUV格式的数据,则通过VI通道处理,WDR模式 |
|
相对于普通线性模式,WDR模式下,Sensor模组会通过长短曝光方式同时产生两帧图像数据,VI需要创建两个PIPE资源,并将两个PIPE绑定到同一个VI设备上,分别接收和处理对应的长短曝光帧图像,然后在主PIPE对应的通道中,输出长短曝光融合后的图像数据。所以,接口调用流程存在如下差异:
|
若要获取RAW格式的数据,则通过VI PIPE处理 |
|
|
由用户指定RAW图数据,VI PIPE灌入并处理,获取YUV图 |
|
用户回灌图片场景,图片的数据来源不再是外部的摄像头设备,但因为当前版本还不支持虚拟pipe,只能通过物理pipe进行灌图,所以即使数据不从sensor输入,仍旧需要设置对应dev并调用hi_mpi_vi_set_dev_bind_pipe接口做dev和pipe的绑定。
|
初始化并运行ISP图像信号处理模块
- 调用hi_mpi_isp_sensor_reg_callback接口注册Sensor驱动通用算法。
- (可选)调用hi_mpi_ae_sensor_reg_callback接口、hi_mpi_awb_sensor_reg_callback接口注册系统内置的Sensor驱动AE、AWB算法。
此处用户可以根据需求注册自定义的算法。
- (可选)调用hi_mpi_ae_register接口、hi_mpi_awb_register接口初始化系统内置的2A算法。
此处用户可以根据需求注册自定义的算法。
- 调用hi_mpi_isp_mem_init接口初始化ISP内部资源。
- 调用hi_mpi_isp_set_pub_attr接口初始化算法模块。
- 调用hi_mpi_isp_init接口初始化ISP firmware。
- 启用单独线程,调用hi_mpi_isp_run接口运行ISP算法的调度业务主流程。
获取已处理的图像数据
- 获取YUV数据
VI图像处理完成后,可在对应的VI通道上获取已完成图像并进行相关处理,典型接口调用流程如下:
- (可选)通过系统文件句柄+select/epoll等待机制,等待图像处理完成事件,可通过hi_mpi_vi_get_chn_fd接口获取指定通道的系统文件句柄,然后获取并处理完一帧图像数据后,会唤醒系统的select/epoll读等待请求。
- 调用hi_mpi_vi_get_chn_frame接口,获取已处理完成的图像数据。此时图像数据对应内存资源会自动被用户占用,用户必须在处理完图像数据后,调用hi_mpi_vi_release_chn_frame接口释放对应图像的内存资源。
- 如果用户通过hi_mpi_vi_get_chn_frame接口获取到图像数据后,要再发布给其他进程使用,则可通过返回的hi_video_frame.user_data[0]得到acltdtBuf句柄,再结合acl的共享buf管理接口(如acltdtCopyBufRef)以及共享队列管理接口(如acltdtEnqueue)将对象发布给其他进程使用。
- 获取RAW数据
VI图像处理完成后,可在对应的VI PIPE上获取已完成图像并进行相关处理,典型接口调用流程如下:
- (可选)通过系统文件句柄+select/epoll等待机制,等待图像处理完成事件,可通过hi_mpi_vi_get_pipe_fd接口获取指定通道的系统文件句柄,当后台获取并处理完一帧图像数据后,会唤醒系统的select/epoll读等待请求。
- 调用hi_mpi_vi_get_pipe_frame接口,获取已处理完成的图像数据。此时图像数据对应内存资源会自动被用户占用,用户必须在处理完图像数据后,调用hi_mpi_vi_release_pipe_frame接口释放对应图像的内存资源。
- 如果用户通过hi_mpi_vi_get_pipe_frame接口获取到图像数据后,要再发布给其他进程使用,则可通过返回的hi_video_frame.user_data[0]得到acltdtBuf句柄,再结合acl的共享buf管理接口(如acltdtCopyBufRef)以及共享队列管理接口(如acltdtEnqueue)将对象发布给其他进程使用。
释放ISP图像信号处理模块资源
- 调用hi_mpi_isp_exit接口去初始化ISP firmware。
- 调用hi_mpi_ae_unregister接口、hi_mpi_awb_unregister接口去初始化2A算法。
- 调用hi_mpi_ae_sensor_unreg_callback接口、hi_mpi_awb_sensor_unreg_callback接口取消注册Sensor驱动AE、AWB算法。
- 调用hi_mpi_isp_sensor_unreg_callback接口取消注册Sensor驱动通用算法。
释放VI视频输入模块资源
- 调用hi_mpi_vi_disable_chn接口关闭VI通道。
- 依次调用hi_mpi_vi_stop_pipe、hi_mpi_vi_destroy_pipe接口停止并销毁VI PIPE。
- 调用hi_mpi_vi_disable_dev接口关闭VI设备。
退出MIPI/SENSOR硬件
- 使用HI_MIPI_RESET_SENSOR命令字复位SENSOR。
- 使用HI_MIPI_DISABLE_SENSOR_CLOCK命令字关闭SENSOR所连接的时钟。
- 使用HI_MIPI_RESET_MIPI命令字复位SENSOR所对接的MIPI。
- 使用HI_MIPI_DISABLE_MIPI_CLOCK关闭MIPI。