v4l2m2m seems didn’t like some resolution format.
[ffmpeg/video] h264_v4l2m2m: Failed to find Size=2276x976, fmt=BGR4 in 1 frame size enums
Could not open codec.
@Darksky
After the last vulkan update, rpi-ffmpeg 6.1 or 6.1.1 don’t compile with error from vulkan av1 whatever i change to the configure option ?
CC libavcodec/vulkan_av1.o
Dans le fichier inclus depuis libavcodec/vulkan_av1.c:21:
libavcodec/vulkan_decode.h:31:5: erreur: nom de type « VkVideoDecodeAV1ProfileInfoMESA » inconnu
31 | VkVideoDecodeAV1ProfileInfoMESA av1_profile;
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:38:5: erreur: nom de type « StdVideoAV1MESATile » inconnu
38 | StdVideoAV1MESATile tiles[MAX_TILES];
| ^~~~~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:39:5: erreur: nom de type « StdVideoAV1MESATileList » inconnu
39 | StdVideoAV1MESATileList tile_list;
| ^~~~~~~~~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:43:5: erreur: nom de type « VkVideoDecodeAV1DpbSlotInfoMESA » inconnu
43 | VkVideoDecodeAV1DpbSlotInfoMESA vkav1_ref;
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:44:5: erreur: nom de type « StdVideoAV1MESAFrameHeader » inconnu
44 | StdVideoAV1MESAFrameHeader av1_frame_header;
| ^~~~~~~~~~~~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:45:5: erreur: nom de type « VkVideoDecodeAV1PictureInfoMESA » inconnu
45 | VkVideoDecodeAV1PictureInfoMESA av1_pic_info;
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:49:5: erreur: nom de type « VkVideoDecodeAV1DpbSlotInfoMESA » inconnu
49 | VkVideoDecodeAV1DpbSlotInfoMESA vkav1_refs[AV1_NUM_REF_FRAMES];
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:58:29: erreur: nom de type « VkVideoDecodeAV1DpbSlotInfoMESA » inconnu; vouliez-vous utiliser « VkVideoDecodeAV1DpbSlotInfoKHR » ?
58 | VkVideoDecodeAV1DpbSlotInfoMESA *vkav1_ref, /* Goes in ^ */
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| VkVideoDecodeAV1DpbSlotInfoKHR
libavcodec/vulkan_av1.c: Dans la fonction « vk_av1_create_params »:
libavcodec/vulkan_av1.c:113:5: erreur: nom de type « StdVideoAV1MESASequenceHeader » inconnu; vouliez-vous utiliser « StdVideoAV1SequenceHeader » ?
113 | StdVideoAV1MESASequenceHeader av1_sequence_header;
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| StdVideoAV1SequenceHeader
libavcodec/vulkan_av1.c:114:5: erreur: nom de type « VkVideoDecodeAV1SessionParametersAddInfoMESA » inconnu; vouliez-vous utiliser « VkVideoDecodeH265SessionParametersAddInfoKHR » ?
114 | VkVideoDecodeAV1SessionParametersAddInfoMESA av1_params_info;
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| VkVideoDecodeH265SessionParametersAddInfoKHR
libavcodec/vulkan_av1.c:115:5: erreur: nom de type « VkVideoDecodeAV1SessionParametersCreateInfoMESA » inconnu; vouliez-vous utiliser « VkVideoDecodeAV1SessionParametersCreateInfoKHR » ?
115 | VkVideoDecodeAV1SessionParametersCreateInfoMESA av1_params;
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| VkVideoDecodeAV1SessionParametersCreateInfoKHR
libavcodec/vulkan_av1.c:120:28: erreur: « StdVideoAV1MESASequenceHeader » non déclaré (première utilisation dans cette fonction); vouliez-vous utiliser « StdVideoAV1SequenceHeader » ?
120 | av1_sequence_header = (StdVideoAV1MESASequenceHeader) {
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| StdVideoAV1SequenceHeader
libavcodec/vulkan_av1.c:120:28: note: chaque identificateur non déclaré est rapporté une seule fois pour chaque fonction dans laquelle il apparaît
libavcodec/vulkan_av1.c:120:58: erreur: expected « ; » before « { » token
120 | av1_sequence_header = (StdVideoAV1MESASequenceHeader) {
| ^~
| ;
libavcodec/vulkan_av1.c:171:24: erreur: « VkVideoDecodeAV1SessionParametersAddInfoMESA » non déclaré (première utilisation dans cette fonction); vouliez-vous utiliser « VkVideoDecodeH265SessionParametersAddInfoKHR » ?
171 | av1_params_info = (VkVideoDecodeAV1SessionParametersAddInfoMESA) {
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| VkVideoDecodeH265SessionParametersAddInfoKHR
libavcodec/vulkan_av1.c:171:69: erreur: expected « ; » before « { » token
171 | av1_params_info = (VkVideoDecodeAV1SessionParametersAddInfoMESA) {
| ^~
| ;
libavcodec/vulkan_av1.c:175:19: erreur: « VkVideoDecodeAV1SessionParametersCreateInfoMESA » non déclaré (première utilisation dans cette fonction); vouliez-vous utiliser « VkVideoDecodeAV1SessionParametersCreateInfoKHR » ?
175 | av1_params = (VkVideoDecodeAV1SessionParametersCreateInfoMESA) {
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| VkVideoDecodeAV1SessionParametersCreateInfoKHR
libavcodec/vulkan_av1.c:175:67: erreur: expected « ; » before « { » token
175 | av1_params = (VkVideoDecodeAV1SessionParametersCreateInfoMESA) {
| ^~
| ;
libavcodec/vulkan_av1.c:114:50: attention: variable « av1_params_info » définie mais non utilisée [-Wunused-but-set-variable]
114 | VkVideoDecodeAV1SessionParametersAddInfoMESA av1_params_info;
| ^~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:113:35: attention: variable « av1_sequence_header » définie mais non utilisée [-Wunused-but-set-variable]
113 | StdVideoAV1MESASequenceHeader av1_sequence_header;
| ^~~~~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:111:33: attention: variable inutilisée « seq » [-Wunused-variable]
111 | const AV1RawSequenceHeader *seq = s->raw_seq;
| ^~~
libavcodec/vulkan_av1.c: Dans la fonction « vk_av1_start_frame »:
libavcodec/vulkan_av1.c:237:15: erreur: déclaration implicite de la fonction « vk_av1_fill_pict » [-Werror=implicit-function-declaration]
237 | err = vk_av1_fill_pict(avctx, &ap->ref_src[i], &vp->ref_slots[i],
| ^~~~~~~~~~~~~~~~
libavcodec/vulkan_av1.c:252:18: erreur: accès au membre « nb_tiles » de quelque chose qui n'est ni une structure ni une union
252 | ap->tile_list.nb_tiles = 0;
| ^
libavcodec/vulkan_av1.c:253:18: erreur: accès au membre « tile_list » de quelque chose qui n'est ni une structure ni une union
253 | ap->tile_list.tile_list = ap->tiles;
| ^
libavcodec/vulkan_av1.c:255:25: erreur: « VkVideoDecodeAV1PictureInfoMESA » non déclaré (première utilisation dans cette fonction); vouliez-vous utiliser « VkVideoDecodeAV1PictureInfoKHR » ?
255 | ap->av1_pic_info = (VkVideoDecodeAV1PictureInfoMESA) {
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
| VkVideoDecodeAV1PictureInfoKHR
libavcodec/vulkan_av1.c:255:57: erreur: expected « ; » before « { » token
255 | ap->av1_pic_info = (VkVideoDecodeAV1PictureInfoMESA) {
| ^~
| ;
libavcodec/vulkan_av1.c:278:29: erreur: « StdVideoAV1MESAFrameHeader » non déclaré (première utilisation dans cette fonction); vouliez-vous utiliser « StdVideoAV1SequenceHeader » ?
278 | ap->av1_frame_header = (StdVideoAV1MESAFrameHeader) {
| ^~~~~~~~~~~~~~~~~~~~~~~~~~
| StdVideoAV1SequenceHeader
libavcodec/vulkan_av1.c:278:56: erreur: expected « ; » before « { » token
278 | ap->av1_frame_header = (StdVideoAV1MESAFrameHeader) {
| ^~
| ;
libavcodec/vulkan_av1.c:402:29: erreur: accès au membre « tiling » de quelque chose qui n'est ni une structure ni une union
402 | ap->av1_frame_header.tiling.width_in_sbs_minus_1[i] = frame_header->width_in_sbs_minus_1[i];
| ^
libavcodec/vulkan_av1.c:403:29: erreur: accès au membre « tiling » de quelque chose qui n'est ni une structure ni une union
403 | ap->av1_frame_header.tiling.height_in_sbs_minus_1[i] = frame_header->height_in_sbs_minus_1[i];
| ^
libavcodec/vulkan_av1.c:404:29: erreur: accès au membre « tiling » de quelque chose qui n'est ni une structure ni une union
404 | ap->av1_frame_header.tiling.tile_start_col_sb[i] = frame_header->tile_start_col_sb[i];
| ^
libavcodec/vulkan_av1.c:405:29: erreur: accès au membre « tiling » de quelque chose qui n'est ni une structure ni une union
405 | ap->av1_frame_header.tiling.tile_start_row_sb[i] = frame_header->tile_start_row_sb[i];
| ^
libavcodec/vulkan_av1.c:409:29: erreur: accès au membre « segmentation » de quelque chose qui n'est ni une structure ni une union
409 | ap->av1_frame_header.segmentation.feature_enabled_bits[i] = 0;
| ^
libavcodec/vulkan_av1.c:411:33: erreur: accès au membre « segmentation » de quelque chose qui n'est ni une structure ni une union
411 | ap->av1_frame_header.segmentation.feature_enabled_bits[i] |= (frame_header->feature_enabled[i][j] << j);
| ^
libavcodec/vulkan_av1.c:412:33: erreur: accès au membre « segmentation » de quelque chose qui n'est ni une structure ni une union
412 | ap->av1_frame_header.segmentation.feature_data[i][j] = frame_header->feature_value[i][j];
| ^
libavcodec/vulkan_av1.c:415:29: erreur: accès au membre « loop_filter » de quelque chose qui n'est ni une structure ni une union
415 | ap->av1_frame_header.loop_filter.ref_deltas[i] = frame_header->loop_filter_ref_deltas[i];
| ^
libavcodec/vulkan_av1.c:417:29: erreur: accès au membre « cdef » de quelque chose qui n'est ni une structure ni une union
417 | ap->av1_frame_header.cdef.y_pri_strength[i] = frame_header->cdef_y_pri_strength[i];
| ^
libavcodec/vulkan_av1.c:418:29: erreur: accès au membre « cdef » de quelque chose qui n'est ni une structure ni une union
418 | ap->av1_frame_header.cdef.y_sec_strength[i] = frame_header->cdef_y_sec_strength[i];
| ^
libavcodec/vulkan_av1.c:419:29: erreur: accès au membre « cdef » de quelque chose qui n'est ni une structure ni une union
419 | ap->av1_frame_header.cdef.uv_pri_strength[i] = frame_header->cdef_uv_pri_strength[i];
| ^
libavcodec/vulkan_av1.c:420:29: erreur: accès au membre « cdef » de quelque chose qui n'est ni une structure ni une union
420 | ap->av1_frame_header.cdef.uv_sec_strength[i] = frame_header->cdef_uv_sec_strength[i];
| ^
libavcodec/vulkan_av1.c:422:29: erreur: accès au membre « ref_order_hint » de quelque chose qui n'est ni une structure ni une union
422 | ap->av1_frame_header.ref_order_hint[i] = frame_header->ref_order_hint[i];
| ^
libavcodec/vulkan_av1.c:423:29: erreur: accès au membre « global_motion » de quelque chose qui n'est ni une structure ni une union
423 | ap->av1_frame_header.global_motion[i] = (StdVideoAV1MESAGlobalMotion) {
| ^
libavcodec/vulkan_av1.c:423:50: erreur: « StdVideoAV1MESAGlobalMotion » non déclaré (première utilisation dans cette fonction); vouliez-vous utiliser « StdVideoAV1GlobalMotion » ?
423 | ap->av1_frame_header.global_motion[i] = (StdVideoAV1MESAGlobalMotion) {
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~
| StdVideoAV1GlobalMotion
libavcodec/vulkan_av1.c:423:78: erreur: expected « ; » before « { » token
423 | ap->av1_frame_header.global_motion[i] = (StdVideoAV1MESAGlobalMotion) {
| ^~
| ;
libavcodec/vulkan_av1.c:437:29: erreur: accès au membre « ref_frame_idx » de quelque chose qui n'est ni une structure ni une union
437 | ap->av1_frame_header.ref_frame_idx[i] = frame_header->ref_frame_idx[i];
| ^
libavcodec/vulkan_av1.c:438:29: erreur: accès au membre « delta_frame_id_minus1 » de quelque chose qui n'est ni une structure ni une union
438 | ap->av1_frame_header.delta_frame_id_minus1[i] = frame_header->delta_frame_id_minus1[i];
| ^
libavcodec/vulkan_av1.c:441:21: erreur: accès au membre « skip_mode_frame_idx » de quelque chose qui n'est ni une structure ni une union
441 | ap->av1_pic_info.skip_mode_frame_idx[0] = s->cur_frame.skip_mode_frame_idx[0];
| ^
libavcodec/vulkan_av1.c:442:21: erreur: accès au membre « skip_mode_frame_idx » de quelque chose qui n'est ni une structure ni une union
442 | ap->av1_pic_info.skip_mode_frame_idx[1] = s->cur_frame.skip_mode_frame_idx[1];
| ^
libavcodec/vulkan_av1.c:446:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
446 | ap->av1_frame_header.film_grain.point_y_value[i] = film_grain->point_y_value[i];
| ^
libavcodec/vulkan_av1.c:447:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
447 | ap->av1_frame_header.film_grain.point_y_scaling[i] = film_grain->point_y_scaling[i];
| ^
libavcodec/vulkan_av1.c:451:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
451 | ap->av1_frame_header.film_grain.point_cb_value[i] = film_grain->point_cb_value[i];
| ^
libavcodec/vulkan_av1.c:452:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
452 | ap->av1_frame_header.film_grain.point_cb_scaling[i] = film_grain->point_cb_scaling[i];
| ^
libavcodec/vulkan_av1.c:453:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
453 | ap->av1_frame_header.film_grain.point_cr_value[i] = film_grain->point_cr_value[i];
| ^
libavcodec/vulkan_av1.c:454:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
454 | ap->av1_frame_header.film_grain.point_cr_scaling[i] = film_grain->point_cr_scaling[i];
| ^
libavcodec/vulkan_av1.c:458:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
458 | ap->av1_frame_header.film_grain.ar_coeffs_y_plus_128[i] = film_grain->ar_coeffs_y_plus_128[i];
| ^
libavcodec/vulkan_av1.c:459:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
459 | ap->av1_frame_header.film_grain.ar_coeffs_cb_plus_128[i] = film_grain->ar_coeffs_cb_plus_128[i];
| ^
libavcodec/vulkan_av1.c:460:33: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
460 | ap->av1_frame_header.film_grain.ar_coeffs_cr_plus_128[i] = film_grain->ar_coeffs_cr_plus_128[i];
| ^
libavcodec/vulkan_av1.c:463:29: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
463 | ap->av1_frame_header.film_grain.ar_coeffs_cb_plus_128[24] = film_grain->ar_coeffs_cb_plus_128[24];
| ^
libavcodec/vulkan_av1.c:464:29: erreur: accès au membre « film_grain » de quelque chose qui n'est ni une structure ni une union
464 | ap->av1_frame_header.film_grain.ar_coeffs_cr_plus_128[24] = film_grain->ar_coeffs_cr_plus_128[24];
| ^
libavcodec/vulkan_av1.c: Dans la fonction « vk_av1_decode_slice »:
libavcodec/vulkan_av1.c:483:32: erreur: accès au membre « nb_tiles » de quelque chose qui n'est ni une structure ni une union
483 | ap->tiles[ap->tile_list.nb_tiles] = (StdVideoAV1MESATile) {
| ^
libavcodec/vulkan_av1.c:483:46: erreur: « StdVideoAV1MESATile » non déclaré (première utilisation dans cette fonction); vouliez-vous utiliser « StdVideoAV1Profile » ?
483 | ap->tiles[ap->tile_list.nb_tiles] = (StdVideoAV1MESATile) {
| ^~~~~~~~~~~~~~~~~~~
| StdVideoAV1Profile
libavcodec/vulkan_av1.c:483:66: erreur: expected « ; » before « { » token
483 | ap->tiles[ap->tile_list.nb_tiles] = (StdVideoAV1MESATile) {
| ^~
| ;
libavcodec/vulkan_av1.c:495:52: erreur: accès au membre « nb_tiles » de quelque chose qui n'est ni une structure ni une union
495 | &ap->tile_list.nb_tiles,
| ^
libavcodec/vulkan_av1.c:500:32: erreur: accès au membre « nb_tiles » de quelque chose qui n'est ni une structure ni une union
500 | ap->tiles[ap->tile_list.nb_tiles - 1].offset = ap->tile_offsets[ap->tile_list.nb_tiles - 1];
| ^
libavcodec/vulkan_av1.c:500:86: erreur: accès au membre « nb_tiles » de quelque chose qui n'est ni une structure ni une union
500 | ap->tiles[ap->tile_list.nb_tiles - 1].offset = ap->tile_offsets[ap->tile_list.nb_tiles - 1];
| ^
libavcodec/vulkan_av1.c: Dans la fonction « vk_av1_end_frame »:
libavcodec/vulkan_av1.c:516:23: erreur: accès au membre « nb_tiles » de quelque chose qui n'est ni une structure ni une union
516 | if (!ap->tile_list.nb_tiles)
| ^
libavcodec/vulkan_av1.c:534:42: erreur: accès au membre « nb_tiles » de quelque chose qui n'est ni une structure ni une union
534 | vp->slices_size, ap->tile_list.nb_tiles);
| ^
cc1 : certains avertissements sont traités comme des erreurs
make: *** [ffbuild/common.mak:81: libavcodec/vulkan_av1.o] Error 1
Edit :
I had needed to downgrade to vulkan-headers-1:1.3.276 and vulkan-icd-loader-1.3.276.
Here is his 6.1.1/rpi_import tree compiled with the fix. I have not tested it with vulkan so all I know that it compiled with out any issue after patching.
As I mentioned above that commit was not in jc-kynesim’s tree so you will not be able to use git cherry pick. I had to manually add back that commit. To complicate things there was 2 files that was renamed. My best guess is jc-kynesim rebased his tree and the commit was lost.