mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
Fix decoding of:
http://samples.mplayerhq.hu/A-codecs/msgsm/levis.avi http://samples.mplayerhq.hu/A-codecs/msgsm/wernfried_1.avi partially fix decoding of: http://samples.mplayerhq.hu/A-codecs/GSM/sample-gsm-8000.gsm Allow the user to encode non standard samplerates by using -strict Originally committed as revision 13020 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
e6dba5dfab
commit
ef79ef3c11
@ -41,9 +41,18 @@ static av_cold int libgsm_init(AVCodecContext *avctx) {
|
||||
avctx->channels);
|
||||
return -1;
|
||||
}
|
||||
|
||||
if(avctx->codec->decode){
|
||||
if(!avctx->channels)
|
||||
avctx->channels= 1;
|
||||
|
||||
if(!avctx->sample_rate)
|
||||
avctx->sample_rate= 8000;
|
||||
}else{
|
||||
if (avctx->sample_rate != 8000) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Sample rate 8000Hz required for GSM, got %dHz\n",
|
||||
avctx->sample_rate);
|
||||
if(avctx->strict_std_compliance > FF_COMPLIANCE_INOFFICIAL)
|
||||
return -1;
|
||||
}
|
||||
if (avctx->bit_rate != 13000 /* Official */ &&
|
||||
@ -51,8 +60,10 @@ static av_cold int libgsm_init(AVCodecContext *avctx) {
|
||||
avctx->bit_rate != 0 /* Unknown; a.o. mov does not set bitrate when decoding */ ) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Bitrate 13000bps required for GSM, got %dbps\n",
|
||||
avctx->bit_rate);
|
||||
if(avctx->strict_std_compliance > FF_COMPLIANCE_INOFFICIAL)
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
avctx->priv_data = gsm_create();
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user