mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-24 16:22:51 +00:00
h264_ps: change decode_scaling_matrices so that it takes const {s,p}ps
In order to be able to make SPS const in H264ParamSets, modify decode_scaling_matrices so that it returns if the scaling matrix are present in the SPS, instead of altering the input SPS structure.
This commit is contained in:
parent
57d30fde9e
commit
3e8cda1eb1
@ -265,8 +265,9 @@ static void decode_scaling_list(GetBitContext *gb, uint8_t *factors, int size,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void decode_scaling_matrices(GetBitContext *gb, SPS *sps,
|
/* returns non zero if the provided SPS scaling matrix has been filled */
|
||||||
PPS *pps, int is_sps,
|
static int decode_scaling_matrices(GetBitContext *gb, const SPS *sps,
|
||||||
|
const PPS *pps, int is_sps,
|
||||||
uint8_t(*scaling_matrix4)[16],
|
uint8_t(*scaling_matrix4)[16],
|
||||||
uint8_t(*scaling_matrix8)[64])
|
uint8_t(*scaling_matrix8)[64])
|
||||||
{
|
{
|
||||||
@ -277,8 +278,9 @@ static void decode_scaling_matrices(GetBitContext *gb, SPS *sps,
|
|||||||
fallback_sps ? sps->scaling_matrix8[0] : default_scaling8[0],
|
fallback_sps ? sps->scaling_matrix8[0] : default_scaling8[0],
|
||||||
fallback_sps ? sps->scaling_matrix8[3] : default_scaling8[1]
|
fallback_sps ? sps->scaling_matrix8[3] : default_scaling8[1]
|
||||||
};
|
};
|
||||||
|
int ret = 0;
|
||||||
if (get_bits1(gb)) {
|
if (get_bits1(gb)) {
|
||||||
sps->scaling_matrix_present |= is_sps;
|
ret = is_sps;
|
||||||
decode_scaling_list(gb, scaling_matrix4[0], 16, default_scaling4[0], fallback[0]); // Intra, Y
|
decode_scaling_list(gb, scaling_matrix4[0], 16, default_scaling4[0], fallback[0]); // Intra, Y
|
||||||
decode_scaling_list(gb, scaling_matrix4[1], 16, default_scaling4[0], scaling_matrix4[0]); // Intra, Cr
|
decode_scaling_list(gb, scaling_matrix4[1], 16, default_scaling4[0], scaling_matrix4[0]); // Intra, Cr
|
||||||
decode_scaling_list(gb, scaling_matrix4[2], 16, default_scaling4[0], scaling_matrix4[1]); // Intra, Cb
|
decode_scaling_list(gb, scaling_matrix4[2], 16, default_scaling4[0], scaling_matrix4[1]); // Intra, Cb
|
||||||
@ -296,6 +298,8 @@ static void decode_scaling_matrices(GetBitContext *gb, SPS *sps,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ff_h264_ps_uninit(H264ParamSets *ps)
|
void ff_h264_ps_uninit(H264ParamSets *ps)
|
||||||
@ -401,7 +405,7 @@ int ff_h264_decode_seq_parameter_set(GetBitContext *gb, AVCodecContext *avctx,
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
sps->transform_bypass = get_bits1(gb);
|
sps->transform_bypass = get_bits1(gb);
|
||||||
decode_scaling_matrices(gb, sps, NULL, 1,
|
sps->scaling_matrix_present |= decode_scaling_matrices(gb, sps, NULL, 1,
|
||||||
sps->scaling_matrix4, sps->scaling_matrix8);
|
sps->scaling_matrix4, sps->scaling_matrix8);
|
||||||
} else {
|
} else {
|
||||||
sps->chroma_format_idc = 1;
|
sps->chroma_format_idc = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user