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];
113 uint32_t frame_id_alloc_mask = 0;
123 for (
int i = 0;
i < STD_VIDEO_VP9_NUM_REF_FRAMES;
i++) {
126 frame_id_alloc_mask |= 1 << rp->
frame_id;
129 if (!ap->frame_id_set) {
130 unsigned slot_idx = 0;
131 for (
unsigned i = 0;
i < 32;
i++) {
132 if (!(frame_id_alloc_mask & (1 <<
i))) {
137 ap->frame_id = slot_idx;
138 ap->frame_id_set = 1;
139 frame_id_alloc_mask |= (1 << slot_idx);
142 for (
int i = 0;
i < STD_VIDEO_VP9_REFS_PER_FRAME;
i++) {
151 for (
int j = 0; j < ref_count; j++) {
152 if (vp->ref_slots[j].slotIndex == hp->
frame_id) {
161 &vp->ref_slots[ref_count], &vp->
refs[ref_count],
174 ap->loop_filter = (StdVideoVP9LoopFilter) {
175 .flags = (StdVideoVP9LoopFilterFlags) {
181 .update_ref_delta = 0x0,
182 .update_mode_delta = 0x0,
185 for (
int i = 0;
i < 2;
i++)
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++)
195 ap->segmentation = (StdVideoVP9Segmentation) {
196 .flags = (StdVideoVP9SegmentationFlags) {
204 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTATION_TREE_PROBS;
i++)
206 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTATION_PRED_PROB;
i++)
208 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTS;
i++) {
209 ap->segmentation.FeatureEnabled[
i] = 0x0;
210 for (
int j = 0; j < STD_VIDEO_VP9_SEG_LVL_MAX; j++) {
218 ap->color_config = (StdVideoVP9ColorConfig) {
219 .flags = (StdVideoVP9ColorConfigFlags) {
229 ap->std_pic_info = (StdVideoDecodeVP9PictureInfo) {
230 .flags = (StdVideoDecodeVP9PictureInfoFlags) {
238 .UsePrevFrameMvs =
s->h.use_last_frame_mvs,
245 .ref_frame_sign_bias_mask = 0x0,
255 .pColorConfig = &ap->color_config,
256 .pLoopFilter = &ap->loop_filter,
257 .pSegmentation = &ap->segmentation,
263 ap->vp9_pic_info = (VkVideoDecodeVP9PictureInfoKHR) {
264 .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_VP9_PICTURE_INFO_KHR,
265 .pStdPictureInfo = &ap->std_pic_info,
266 .uncompressedHeaderOffset = 0,
267 .compressedHeaderOffset =
s->h.uncompressed_header_size,
268 .tilesOffset =
s->h.uncompressed_header_size +
269 s->h.compressed_header_size,
272 for (
int i = 0;
i < STD_VIDEO_VP9_REFS_PER_FRAME;
i++) {
278 ap->vp9_pic_info.referenceNameSlotIndices[
i] = -1;
280 ap->vp9_pic_info.referenceNameSlotIndices[
i] = hp->
frame_id;
283 vp->decode_info = (VkVideoDecodeInfoKHR) {
284 .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_INFO_KHR,
285 .pNext = &ap->vp9_pic_info,
287 .pSetupReferenceSlot = &vp->ref_slot,
288 .referenceSlotCount = ref_count,
289 .pReferenceSlots = vp->ref_slots,
290 .dstPictureResource = (VkVideoPictureResourceInfoKHR) {
291 .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
292 .codedOffset = (VkOffset2D){ 0, 0 },
295 .imageViewBinding = vp->view.out[0],
328 AVFrame *rav[STD_VIDEO_VP9_REFS_PER_FRAME] = { 0 };
354 .
p.
name =
"vp9_vulkan",