On 2012-01-09 14:40:02 -0500, Justin Ruggles wrote:
> fixes stream copy of raw gsm to mov.
> tested with QuickTime.
> ---
>  libavformat/gsmdec.c |    5 ++---
>  1 files changed, 2 insertions(+), 3 deletions(-)
> 
> diff --git a/libavformat/gsmdec.c b/libavformat/gsmdec.c
> index 2360887..a23ce3b 100644
> --- a/libavformat/gsmdec.c
> +++ b/libavformat/gsmdec.c
> @@ -37,7 +37,7 @@ static int gsm_read_packet(AVFormatContext *s, AVPacket 
> *pkt)
>  {
>      int ret, size;
>  
> -    size = GSM_BLOCK_SIZE * 32;
> +    size = GSM_BLOCK_SIZE;
>  
>      pkt->pos = avio_tell(s->pb);
>      pkt->stream_index = 0;
> @@ -48,7 +48,7 @@ static int gsm_read_packet(AVFormatContext *s, AVPacket 
> *pkt)
>          return ret < 0 ? ret : AVERROR(EIO);
>      }
>      pkt->size     = ret;
> -    pkt->duration = ret      / GSM_BLOCK_SIZE;
> +    pkt->duration = 1;
>      pkt->pts      = pkt->pos / GSM_BLOCK_SIZE;
>  
>      return 0;
> @@ -65,7 +65,6 @@ static int gsm_read_header(AVFormatContext *s, 
> AVFormatParameters *ap)
>      st->codec->codec_id    = s->iformat->value;
>      st->codec->channels    = 1;
>      st->codec->sample_rate = c->sample_rate;
> -    st->codec->block_align = GSM_BLOCK_SIZE;
>      st->codec->bit_rate    = GSM_BLOCK_SIZE * 8 * c->sample_rate / 
> GSM_BLOCK_SAMPLES;
>  
>      avpriv_set_pts_info(st, 64, GSM_BLOCK_SAMPLES, GSM_SAMPLE_RATE);

except that 33/65 byte packets look very inefficient probably ok

Janne
_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel

Reply via email to