hi_mpi_vdec_send_stream
函数功能
解码前,向解码通道发送码流数据及存放解码结果的buffer。
Atlas 200/300/500 推理产品,不支持该接口。
Atlas 训练系列产品,不支持该接口。
约束说明
- 发送数据前必须保证已经调用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训练系列产品,该参数的取值范围:[0, 256),JPEGD功能和VDEC功能共用通道,且通道总数最多256,其中,JPEGD解码通道总数最多256,VDEC解码通道总数最多32。 Atlas 200I/500 A2推理产品,该参数的取值范围:[0, 128),JPEGD功能和VDEC功能共用通道,且通道总数最多128。 |
stream |
输入 |
输入码流信息的指针。 该结构体内的addr参数配置的地址为Device上的内存地址。 |
vdec_pic_info |
输入 |
输出图片信息的指针。 |
milli_sec |
输入 |
超时时间,单位是毫秒。
|
返回值说明
- 0:成功
- 非0:失败,参见VDEC视频解码/JPEGD图片解码返回码