1
0
mirror of https://github.com/mpv-player/mpv synced 2024-12-17 20:34:58 +00:00

- using avcodec_alloc_context()

- fixed 10l bug (double free() ) causing random mem corruption...


git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@7853 b3059339-0415-0410-9bf9-f77b7e298cf2
This commit is contained in:
arpi 2002-10-22 22:25:17 +00:00
parent d58b5163fc
commit 71fb48ebc5

View File

@ -26,12 +26,12 @@ extern int avcodec_inited;
struct vf_priv_s { struct vf_priv_s {
unsigned char* outbuf; unsigned char* outbuf;
int outbuf_size; int outbuf_size;
AVCodecContext context; AVCodecContext* context;
AVCodec *codec; AVCodec* codec;
vo_mpegpes_t pes; vo_mpegpes_t pes;
}; };
#define lavc_venc_context (vf->priv->context) #define lavc_venc_context (*vf->priv->context)
//===========================================================================// //===========================================================================//
@ -62,7 +62,6 @@ static int config(struct vf_instance_s* vf,
if(vf->priv->outbuf) free(vf->priv->outbuf); if(vf->priv->outbuf) free(vf->priv->outbuf);
vf->priv->outbuf_size=10000+width*height; // must be enough! vf->priv->outbuf_size=10000+width*height; // must be enough!
if(vf->priv->outbuf) free(vf->priv->outbuf);
vf->priv->outbuf = malloc(vf->priv->outbuf_size); vf->priv->outbuf = malloc(vf->priv->outbuf_size);
if (avcodec_open(&lavc_venc_context, vf->priv->codec) != 0) { if (avcodec_open(&lavc_venc_context, vf->priv->codec) != 0) {
@ -142,6 +141,8 @@ static int open(vf_instance_t *vf, char* args){
mp_msg(MSGT_MENCODER,MSGL_ERR,MSGTR_MissingLAVCcodec, "mpeg1video"); mp_msg(MSGT_MENCODER,MSGL_ERR,MSGTR_MissingLAVCcodec, "mpeg1video");
return 0; return 0;
} }
vf->priv->context=avcodec_alloc_context();
// TODO: parse args -> // TODO: parse args ->
if(args) sscanf(args, "%d:%f", &p_quality, &p_fps); if(args) sscanf(args, "%d:%f", &p_quality, &p_fps);