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;
125 for (
int i = 0;
i < STD_VIDEO_VP9_NUM_REF_FRAMES;
i++) {
128 frame_id_alloc_mask |= 1 << rp->
frame_id;
131 if (!ap->frame_id_set) {
132 unsigned slot_idx = 0;
133 for (
unsigned i = 0;
i < 32;
i++) {
134 if (!(frame_id_alloc_mask & (1 <<
i))) {
139 ap->frame_id = slot_idx;
140 ap->frame_id_set = 1;
141 frame_id_alloc_mask |= (1 << slot_idx);
144 for (
int i = 0;
i < STD_VIDEO_VP9_REFS_PER_FRAME;
i++) {
153 for (
int j = 0; j < ref_count; j++) {
154 if (vp->ref_slots[j].slotIndex == hp->
frame_id) {
163 &vp->ref_slots[ref_count], &vp->
refs[ref_count],
176 ap->loop_filter = (StdVideoVP9LoopFilter) {
177 .flags = (StdVideoVP9LoopFilterFlags) {
183 .update_ref_delta = 0x0,
184 .update_mode_delta = 0x0,
187 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_REF_FRAMES;
i++) {
191 for (
int i = 0;
i < STD_VIDEO_VP9_LOOP_FILTER_ADJUSTMENTS;
i++) {
196 ap->segmentation = (StdVideoVP9Segmentation) {
197 .flags = (StdVideoVP9SegmentationFlags) {
205 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTATION_TREE_PROBS;
i++)
207 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTATION_PRED_PROB;
i++)
209 for (
int i = 0;
i < STD_VIDEO_VP9_MAX_SEGMENTS;
i++) {
210 ap->segmentation.FeatureEnabled[
i] = 0x0;
211 for (
int j = 0; j < STD_VIDEO_VP9_SEG_LVL_MAX; j++) {
219 ap->color_config = (StdVideoVP9ColorConfig) {
220 .flags = (StdVideoVP9ColorConfigFlags) {
230 ap->std_pic_info = (StdVideoDecodeVP9PictureInfo) {
231 .flags = (StdVideoDecodeVP9PictureInfoFlags) {
239 .UsePrevFrameMvs =
s->h.use_last_frame_mvs,
246 .ref_frame_sign_bias_mask = 0x0,
256 .pColorConfig = &ap->color_config,
257 .pLoopFilter = &ap->loop_filter,
258 .pSegmentation = &ap->segmentation,
264 ap->vp9_pic_info = (VkVideoDecodeVP9PictureInfoKHR) {
265 .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_VP9_PICTURE_INFO_KHR,
266 .pStdPictureInfo = &ap->std_pic_info,
267 .uncompressedHeaderOffset = 0,
268 .compressedHeaderOffset =
s->h.uncompressed_header_size,
269 .tilesOffset =
s->h.uncompressed_header_size +
270 s->h.compressed_header_size,
273 for (
int i = 0;
i < STD_VIDEO_VP9_REFS_PER_FRAME;
i++) {
279 ap->vp9_pic_info.referenceNameSlotIndices[
i] = -1;
281 ap->vp9_pic_info.referenceNameSlotIndices[
i] = hp->
frame_id;
284 vp->decode_info = (VkVideoDecodeInfoKHR) {
285 .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_INFO_KHR,
286 .pNext = &ap->vp9_pic_info,
288 .pSetupReferenceSlot = &vp->ref_slot,
289 .referenceSlotCount = ref_count,
290 .pReferenceSlots = vp->ref_slots,
291 .dstPictureResource = (VkVideoPictureResourceInfoKHR) {
292 .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
293 .codedOffset = (VkOffset2D){ 0, 0 },
296 .imageViewBinding = vp->view.out[0],
329 AVFrame *rav[STD_VIDEO_VP9_REFS_PER_FRAME] = { 0 };
355 .
p.
name =
"vp9_vulkan",