文档
注册

hi_mpi_vdec_send_stream

Atlas 200/300/500 推理产品,不支持该接口。

Atlas 训练系列产品,不支持该接口。

函数功能

解码前,向解码通道发送码流数据及存放解码结果的buffer。

约束说明

  • 发送数据前必须保证已经调用hi_mpi_vdec_start_recv_stream接口启动接收码流,否则直接返回该操作不允许的错误码HI_ERR_VDEC_NOT_PERM。如果在发送数据过程中停止接收码流,就会立刻返回HI_ERR_VDEC_NOT_PERM。
  • 发送数据前必须保证通道已经被创建,否则直接返回通道未创建的错误码HI_ERR_VDEC_UNEXIST。如果在发送码流过程中复位通道或者销毁通道,就会立刻返回错误码HI_ERR_VDEC_UNEXIST。
  • 发送码流时需要按照创建解码通道时设置的发送方式(仅支持按帧发送)进行发送。按帧发送时,调用此接口一次,必须发送完整的一帧码流,否则,解码会出现错误。
  • 不能发送end_of_stream为0的空码流包(码流长度为0或码流地址为空),否则返回错误码。发送end_of_stream为1的空码流包时,解码器会把所有码流全部解完并输出全部图像。除此之外,其它情况应该把end_of_stream置为0。
  • 当码流buffer为空且装不下当前包码流时,会返回参数超出范围的错误码HI_ERR_VDEC_ILLEGAL_PARAM。
  • 以非阻塞方式发送码流,如果码流缓冲区已满,会立刻返回错误码HI_ERR_VDEC_BUF_FULL。
  • 以超时方式发送码流,到达设定的超时时间还不能成功发送码流会返回错误码HI_ERR_VDEC_BUF_FULL。
  • 视频解码时支持设置是否将解码结果写入输出内存中,hi_vdec_stream结构体中将need_display设置为0时,此帧码流的解码结果将不会写入到hi_vdec_pic_info结构体中配置的输出内存中,此时允许将输出内存地址配置为NULL。hi_mpi_vdec_get_frame接口仍然能获取到结构hi_video_frame_info和hi_vdec_stream的信息,但是此时输出内存中无解码结果数据,需要用户释放输出内存(如果用户传入的输出内存地址是NULL,则无需释放)。
  • 解码时,输入输出内存均需要在调用hi_mpi_vdec_get_frame接口获取结果之后才能进行释放。
  • 视频解码,输入输出内存要求、输入码流格式、输出图片格式请参见VDEC功能及约束说明
  • 图像解码,输入输出内存要求、输入图片格式、输出图片格式请参见JPEGD功能及约束说明

函数原型

hi_s32 hi_mpi_vdec_send_stream(hi_vdec_chn chn, const hi_vdec_stream *stream, hi_vdec_pic_info *vdec_pic_info, hi_s32 milli_sec)

参数说明

参数名

输入/输出

说明

chn

输入

解码通道号。

Atlas 推理系列产品(Ascend 310P处理器),该参数的取值范围:[0, 256),JPEGD功能和VDEC功能共用通道,且通道总数最多256。

Atlas A2训练系列产品/Atlas 800I A2推理产品,该参数的取值范围:[0, 256),JPEGD功能和VDEC功能共用通道,且通道总数最多256,其中,JPEGD解码通道总数最多256,VDEC解码通道总数最多32。

Atlas 200/500 A2推理产品,该参数的取值范围:[0, 128),JPEGD功能和VDEC功能共用通道,且通道总数最多128。

stream

输入

输入码流信息的指针。

该结构体内的addr参数配置的地址为Device上的内存地址。

vdec_pic_info

输入

输出图片信息的指针。

milli_sec

输入

超时时间,单位是毫秒。
  • -1:阻塞方式
  • 0:非阻塞方式
  • >0:超时方式,配置具体的超时时间。超时时间受操作系统影响,一般偏差在操作系统的一个时间片内,例如,操作系统的一个时间片为4ms,用户设置的milli_sec参数值为1,则实际的超时时间在1ms到5ms范围内。在CPU负载高场景下,超时时间仍可能存在波动。

返回值说明

参考资源

接口调用流程及示例,参见JPEGD图片解码VDEC视频解码

搜索结果
找到“0”个结果

当前产品无相关内容

未找到相关内容,请尝试其他搜索词