[FFmpeg-devel] [PATCH] fraps: optimize pseudo-YUV to RGB conversion.
Reimar Döffinger
Reimar.Doeffinger at gmx.de
Sun Jan 29 15:41:54 CET 2012
With gcc 4.6 this part of the code is ca. 4x faster, resulting
in an overall speedup of around 5% for fate-fraps-v5 sample.
Signed-off-by: Reimar Döffinger <Reimar.Doeffinger at gmx.de>
---
libavcodec/fraps.c | 11 ++++++++---
1 files changed, 8 insertions(+), 3 deletions(-)
diff --git a/libavcodec/fraps.c b/libavcodec/fraps.c
index c83667e..bbabfd9 100644
--- a/libavcodec/fraps.c
+++ b/libavcodec/fraps.c
@@ -141,6 +141,7 @@ static int decode_frame(AVCodecContext *avctx,
uint32_t offs[4];
int i, j, is_chroma;
const int planes = 3;
+ uint8_t *out;
header = AV_RL32(buf);
@@ -269,12 +270,16 @@ static int decode_frame(AVCodecContext *avctx,
return -1;
}
}
+ out = f->data[0];
// convert pseudo-YUV into real RGB
for(j = 0; j < avctx->height; j++){
- for(i = 0; i < avctx->width; i++){
- f->data[0][0 + i*3 + j*f->linesize[0]] += f->data[0][1 + i*3 + j*f->linesize[0]];
- f->data[0][2 + i*3 + j*f->linesize[0]] += f->data[0][1 + i*3 + j*f->linesize[0]];
+ uint8_t *line_end = out + 3*avctx->width;
+ while (out < line_end) {
+ out[0] += out[1];
+ out[2] += out[1];
+ out += 3;
}
+ out += f->linesize[0] - 3*avctx->width;
}
break;
}
--
1.7.8.3
More information about the ffmpeg-devel
mailing list