26 .queue_flags = VK_QUEUE_VIDEO_DECODE_BIT_KHR,
27 .decode_op = VK_VIDEO_CODEC_OPERATION_DECODE_VP9_BIT_KHR,
29 .extensionName = VK_STD_VULKAN_VIDEO_CODEC_VP9_DECODE_EXTENSION_NAME,
30 .specVersion = VK_STD_VULKAN_VIDEO_CODEC_VP9_DECODE_SPEC_VERSION,
56 VkVideoReferenceSlotInfoKHR *ref_slot,
57 VkVideoPictureResourceInfoKHR *
ref,
70 *
ref = (VkVideoPictureResourceInfoKHR) {
71 .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
72 .codedOffset = (VkOffset2D){ 0, 0 },
76 .imageViewBinding = vkpic->
view.
ref[0],
79 *ref_slot = (VkVideoReferenceSlotInfoKHR) {
80 .sType = VK_STRUCTURE_TYPE_VIDEO_REFERENCE_SLOT_INFO_KHR,
82 .pPictureResource =
ref,
91 static enum StdVideoVP9InterpolationFilter
remap_interp(uint8_t is_filter_switchable,
92 uint8_t raw_interpolation_filter_type)
94 static const enum StdVideoVP9InterpolationFilter
remap[] = {
95 STD_VIDEO_VP9_INTERPOLATION_FILTER_EIGHTTAP_SMOOTH,
96 STD_VIDEO_VP9_INTERPOLATION_FILTER_EIGHTTAP,
97 STD_VIDEO_VP9_INTERPOLATION_FILTER_EIGHTTAP_SHARP,
98 STD_VIDEO_VP9_INTERPOLATION_FILTER_BILINEAR,
100 if (is_filter_switchable)
101 return STD_VIDEO_VP9_INTERPOLATION_FILTER_SWITCHABLE;
102 return remap[raw_interpolation_filter_type];
115 uint32_t frame_id_alloc_mask = 0;
126 for (
int i = 0;
i < STD_VIDEO_VP9_NUM_REF_FRAMES;
i++) {
129 frame_id_alloc_mask |= 1 << rp->
frame_id;
132 if (!ap->frame_id_set) {
133 unsigned slot_idx = 0;
134 for (
unsigned i = 0;
i < 32;
i++) {
135 if (!(frame_id_alloc_mask & (1 <<
i))) {
140 ap->frame_id = slot_idx;
141 ap->frame_id_set = 1;
142 frame_id_alloc_mask |= (1 << slot_idx);
145 for (
int i = 0;
i < STD_VIDEO_VP9_REFS_PER_FRAME;
i++) {
154 for (
int j = 0; j < ref_count; j++) {
155 if (vp->ref_slots[j].slotIndex == hp->
frame_id) {
164 &vp->ref_slots[ref_count], &vp->
refs[ref_count],
177 ap->loop_filter = (StdVideoVP9LoopFilter) {
178 .flags = (StdVideoVP9LoopFilterFlags) {
184 .update_ref_delta = 0x0,
185 .update_mode_delta = 0x0,
188 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_REF_FRAMES;
i++) {
192 for (
int i = 0;
i < STD_VIDEO_VP9_LOOP_FILTER_ADJUSTMENTS;
i++) {
197 ap->segmentation = (StdVideoVP9Segmentation) {
198 .flags = (StdVideoVP9SegmentationFlags) {
206 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTATION_TREE_PROBS;
i++)
208 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTATION_PRED_PROB;
i++)
210 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTS;
i++) {
211 ap->segmentation.FeatureEnabled[
i] = 0x0;
212 for (
int j = 0; j < STD_VIDEO_VP9_SEG_LVL_MAX; j++) {
220 ap->color_config = (StdVideoVP9ColorConfig) {
221 .flags = (StdVideoVP9ColorConfigFlags) {
232 ap->std_pic_info = (StdVideoDecodeVP9PictureInfo) {
233 .flags = (StdVideoDecodeVP9PictureInfoFlags) {
240 .show_frame = !
s->h.invisible,
241 .UsePrevFrameMvs =
s->h.use_last_frame_mvs,
248 .ref_frame_sign_bias_mask = 0x0,
258 .pColorConfig = &ap->color_config,
259 .pLoopFilter = &ap->loop_filter,
260 .pSegmentation = &ap->segmentation,
266 ap->vp9_pic_info = (VkVideoDecodeVP9PictureInfoKHR) {
267 .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_VP9_PICTURE_INFO_KHR,
268 .pStdPictureInfo = &ap->std_pic_info,
269 .uncompressedHeaderOffset = 0,
270 .compressedHeaderOffset =
s->h.uncompressed_header_size,
271 .tilesOffset =
s->h.uncompressed_header_size +
272 s->h.compressed_header_size,
275 for (
int i = 0;
i < STD_VIDEO_VP9_REFS_PER_FRAME;
i++) {
281 ap->vp9_pic_info.referenceNameSlotIndices[
i] = -1;
283 ap->vp9_pic_info.referenceNameSlotIndices[
i] = hp->
frame_id;
286 vp->decode_info = (VkVideoDecodeInfoKHR) {
287 .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_INFO_KHR,
288 .pNext = &ap->vp9_pic_info,
290 .pSetupReferenceSlot = &vp->ref_slot,
291 .referenceSlotCount = ref_count,
292 .pReferenceSlots = vp->ref_slots,
293 .dstPictureResource = (VkVideoPictureResourceInfoKHR) {
294 .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
295 .codedOffset = (VkOffset2D){ 0, 0 },
298 .imageViewBinding = vp->view.out[0],
331 AVFrame *rav[STD_VIDEO_VP9_REFS_PER_FRAME] = { 0 };
357 .
p.
name =
"vp9_vulkan",