[FFmpeg-devel] [PATCH] fix motion-test on non-MMX CPUs
Diego Biurrun
diego
Thu Apr 9 17:16:38 CEST 2009
On Thu, Apr 09, 2009 at 05:00:02PM +0200, Michael Niedermayer wrote:
> On Thu, Apr 09, 2009 at 09:22:45AM +0200, Diego Biurrun wrote:
> > Here is a patch to fix a sigill on CPUs without MMX2, like my trusty old
> > K6-III, when running motion-test.
> >
> > If somebody has a prettier idea, I'm all ears.
> >
> > --- libavcodec/motion-test.c (revision 18382)
> > +++ libavcodec/motion-test.c (working copy)
> > @@ -127,7 +128,13 @@
> > AVCodecContext *ctx;
> > int c;
> > DSPContext cctx, mmxctx;
> > +#if HAVE_MMX2
> > int flags[2] = { FF_MM_MMX, FF_MM_MMX2 };
> > + int flags_size = 2;
> > +#else
> > + int flags[2] = { FF_MM_MMX };
> > + int flags_size = 1;
> > +#endif
>
> it seems int flags[2] does noz need to be changed
Did you mean "noW" or "noT" here?
> > @@ -145,7 +152,7 @@
> > ctx = avcodec_alloc_context();
> > ctx->dsp_mask = FF_MM_FORCE;
> > dsputil_init(&cctx, ctx);
> > - for (c = 0; c < 1; c++) {
> > + for (c = 0; c < flags_size; c++) {
>
> hmm, this changes it from 1 to 2
This was the intention, what am I missing?
flags[0] is MMX, flags[1] is MMX2..
Diego
More information about the ffmpeg-devel
mailing list