From 57c36bdceae2f22fb7babf86c1aba3255cc3d548 Mon Sep 17 00:00:00 2001 From: Måns Rullgård Date: Sun, 16 Aug 2009 15:51:52 +0000 Subject: intreadwrite: allow arch-specific 24-bit access macros Originally committed as revision 19657 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavutil/intreadwrite.h | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'libavutil/intreadwrite.h') diff --git a/libavutil/intreadwrite.h b/libavutil/intreadwrite.h index 18a2b6de44..3d52ab8028 100644 --- a/libavutil/intreadwrite.h +++ b/libavutil/intreadwrite.h @@ -25,7 +25,7 @@ /* * Arch-specific headers can provide any combination of - * AV_[RW][BLN](16|32|64) macros. Preprocessor symbols must be + * AV_[RW][BLN](16|24|32|64) macros. Preprocessor symbols must be * defined, even if these are implemented as inline functions. */ @@ -249,20 +249,28 @@ struct unaligned_16 { uint16_t l; } __attribute__((packed)); # define AV_WL64(p, v) AV_WL(64, p, v) #endif +#ifndef AV_RB24 #define AV_RB24(x) ((((const uint8_t*)(x))[0] << 16) | \ (((const uint8_t*)(x))[1] << 8) | \ ((const uint8_t*)(x))[2]) +#endif +#ifndef AV_WB24 #define AV_WB24(p, d) do { \ ((uint8_t*)(p))[2] = (d); \ ((uint8_t*)(p))[1] = (d)>>8; \ ((uint8_t*)(p))[0] = (d)>>16; } while(0) +#endif +#ifndef AV_RL24 #define AV_RL24(x) ((((const uint8_t*)(x))[2] << 16) | \ (((const uint8_t*)(x))[1] << 8) | \ ((const uint8_t*)(x))[0]) +#endif +#ifndef AV_WL24 #define AV_WL24(p, d) do { \ ((uint8_t*)(p))[0] = (d); \ ((uint8_t*)(p))[1] = (d)>>8; \ ((uint8_t*)(p))[2] = (d)>>16; } while(0) +#endif #endif /* AVUTIL_INTREADWRITE_H */ -- cgit v1.2.3