[FFmpeg-cvslog] r14747 - in trunk/libavcodec: mlp.c mlp.h mlpdec.c
ramiro
subversion
Thu Aug 14 05:58:05 CEST 2008
Author: ramiro
Date: Thu Aug 14 05:58:05 2008
New Revision: 14747
Log:
mlp: split simple inline function that xors 4 bytes into one.
Modified:
trunk/libavcodec/mlp.c
trunk/libavcodec/mlp.h
trunk/libavcodec/mlpdec.c
Modified: trunk/libavcodec/mlp.c
==============================================================================
--- trunk/libavcodec/mlp.c (original)
+++ trunk/libavcodec/mlp.c Thu Aug 14 05:58:05 2008
@@ -110,8 +110,7 @@ uint8_t ff_mlp_calculate_parity(const ui
for (; buf < buf_end - 3; buf += 4)
scratch ^= *((const uint32_t*)buf);
- scratch ^= scratch >> 16;
- scratch ^= scratch >> 8;
+ scratch = xor_32_to_8(scratch);
for (; buf < buf_end; buf++)
scratch ^= *buf;
Modified: trunk/libavcodec/mlp.h
==============================================================================
--- trunk/libavcodec/mlp.h (original)
+++ trunk/libavcodec/mlp.h Thu Aug 14 05:58:05 2008
@@ -107,4 +107,12 @@ int ff_mlp_init_crc2D(AVCodecParserConte
void ff_mlp_init_crc();
+/** XOR four bytes into one. */
+static inline uint8_t xor_32_to_8(uint32_t value)
+{
+ value ^= value >> 16;
+ value ^= value >> 8;
+ return value;
+}
+
#endif /* FFMPEG_MLP_H */
Modified: trunk/libavcodec/mlpdec.c
==============================================================================
--- trunk/libavcodec/mlpdec.c (original)
+++ trunk/libavcodec/mlpdec.c Thu Aug 14 05:58:05 2008
@@ -364,10 +364,7 @@ static int read_restart_header(MLPDecode
lossless_check = get_bits(gbp, 8);
if (substr == m->max_decoded_substream
&& s->lossless_check_data != 0xffffffff) {
- tmp = s->lossless_check_data;
- tmp ^= tmp >> 16;
- tmp ^= tmp >> 8;
- tmp &= 0xff;
+ tmp = xor_32_to_8(s->lossless_check_data);
if (tmp != lossless_check)
av_log(m->avctx, AV_LOG_WARNING,
"Lossless check failed - expected %02x, calculated %02x.\n",
More information about the ffmpeg-cvslog
mailing list