mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
avcodec: Add bits_per_raw_sample to AVCodecParameters
The bits_per_raw_sample represents the number of bits of precision per sample. The field is added at the logical place, not at the end as the code was just recently added This fixes the regression about losing the audio sample precision information The change in the fate test checksum un-does the change from the merge Previous version reviewed by: wm4 <nfxjfg@googlemail.com> Previous version reviewed by: Dominik 'Rathann' Mierzejewski <dominik@greysector.net> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
c8ed93efcf
commit
21acc4db5f
@ -3832,8 +3832,32 @@ typedef struct AVCodecParameters {
|
||||
*/
|
||||
int64_t bit_rate;
|
||||
|
||||
/**
|
||||
* The number of bits per sample in the codedwords.
|
||||
*
|
||||
* This is basically the bitrate per sample. It is mandatory for a bunch of
|
||||
* formats to actually decode them. It's the number of bits for one sample in
|
||||
* the actual coded bitstream.
|
||||
*
|
||||
* This could be for example 4 for ADPCM
|
||||
* For PCM formats this matches bits_per_raw_sample
|
||||
* Can be 0
|
||||
*/
|
||||
int bits_per_coded_sample;
|
||||
|
||||
/**
|
||||
* This is the number of valid bits in each output sample. If the
|
||||
* sample format has more bits, the least significant bits are additional
|
||||
* padding bits, which are always 0. Use right shifts to reduce the sample
|
||||
* to its actual size. For example, audio formats with 24 bit samples will
|
||||
* have bits_per_raw_sample set to 24, and format set to AV_SAMPLEFMT_S32.
|
||||
* To get the original sample use "(uint32_t)sample >> 8"."
|
||||
*
|
||||
* For ADPCM this might be 12 or 16 or similar
|
||||
* Can be 0
|
||||
*/
|
||||
int bits_per_raw_sample;
|
||||
|
||||
/**
|
||||
* Codec-specific bitstream restrictions that the stream conforms to.
|
||||
*/
|
||||
|
@ -3771,6 +3771,7 @@ int avcodec_parameters_from_context(AVCodecParameters *par,
|
||||
|
||||
par->bit_rate = codec->bit_rate;
|
||||
par->bits_per_coded_sample = codec->bits_per_coded_sample;
|
||||
par->bits_per_raw_sample = codec->bits_per_raw_sample;
|
||||
par->profile = codec->profile;
|
||||
par->level = codec->level;
|
||||
|
||||
@ -3824,6 +3825,7 @@ int avcodec_parameters_to_context(AVCodecContext *codec,
|
||||
|
||||
codec->bit_rate = par->bit_rate;
|
||||
codec->bits_per_coded_sample = par->bits_per_coded_sample;
|
||||
codec->bits_per_raw_sample = par->bits_per_raw_sample;
|
||||
codec->profile = par->profile;
|
||||
codec->level = par->level;
|
||||
|
||||
|
@ -29,7 +29,7 @@
|
||||
|
||||
#define LIBAVCODEC_VERSION_MAJOR 57
|
||||
#define LIBAVCODEC_VERSION_MINOR 34
|
||||
#define LIBAVCODEC_VERSION_MICRO 100
|
||||
#define LIBAVCODEC_VERSION_MICRO 101
|
||||
|
||||
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
||||
LIBAVCODEC_VERSION_MINOR, \
|
||||
|
@ -1,3 +1,3 @@
|
||||
79674a5219d00e1d2221a29157b35eb4 *./tests/data/lavf/lavf.ffm
|
||||
e63c16b5f0ad5015304fc4009fdb33ca *./tests/data/lavf/lavf.ffm
|
||||
376832 ./tests/data/lavf/lavf.ffm
|
||||
./tests/data/lavf/lavf.ffm CRC=0x000e23ae
|
||||
|
Loading…
Reference in New Issue
Block a user