|
|
|
@ -26,17 +26,40 @@ struct unaligned_16 { uint16_t l; } __attribute__((packed)); |
|
|
|
|
#endif /* !__GNUC__ */ |
|
|
|
|
|
|
|
|
|
/* endian macros */ |
|
|
|
|
#if !defined(AV_RB16) || !defined(AV_RB32) || !defined(AV_RL16) || !defined(AV_RL32) |
|
|
|
|
#define AV_RB16(x) ((((uint8_t*)(x))[0] << 8) | ((uint8_t*)(x))[1]) |
|
|
|
|
#define AV_RB32(x) ((((uint8_t*)(x))[0] << 24) | \ |
|
|
|
|
#define AV_RB8(x) (((uint8_t*)(x))[0]) |
|
|
|
|
#define AV_WB8(p, i, d) { ((uint8_t*)(p))[(i)] = (d); } |
|
|
|
|
|
|
|
|
|
#define AV_RB16(x) ((((uint8_t*)(x))[0] << 8) | ((uint8_t*)(x))[1]) |
|
|
|
|
#define AV_WB16(p, i, d) { \ |
|
|
|
|
((uint8_t*)(p))[(i)+1] = (d); \
|
|
|
|
|
((uint8_t*)(p))[(i)] = (d)>>8; } |
|
|
|
|
|
|
|
|
|
#define AV_RB32(x) ((((uint8_t*)(x))[0] << 24) | \ |
|
|
|
|
(((uint8_t*)(x))[1] << 16) | \
|
|
|
|
|
(((uint8_t*)(x))[2] << 8) | \
|
|
|
|
|
((uint8_t*)(x))[3]) |
|
|
|
|
#define AV_RL16(x) ((((uint8_t*)(x))[1] << 8) | ((uint8_t*)(x))[0]) |
|
|
|
|
#define AV_RL32(x) ((((uint8_t*)(x))[3] << 24) | \ |
|
|
|
|
#define AV_WB32(p, i, d) { \ |
|
|
|
|
((uint8_t*)(p))[(i)+3] = (d); \
|
|
|
|
|
((uint8_t*)(p))[(i)+2] = (d)>>8; \
|
|
|
|
|
((uint8_t*)(p))[(i)+1] = (d)>>16; \
|
|
|
|
|
((uint8_t*)(p))[(i)] = (d)>>24; } |
|
|
|
|
|
|
|
|
|
#define AV_RL8(x) AV_RB8(x) |
|
|
|
|
#define AV_WL8(p, i, d) AV_WB8(p, i, d) |
|
|
|
|
|
|
|
|
|
#define AV_RL16(x) ((((uint8_t*)(x))[1] << 8) | ((uint8_t*)(x))[0]) |
|
|
|
|
#define AV_WL16(p, i, d) { \ |
|
|
|
|
((uint8_t*)(p))[(i)] = (d); \
|
|
|
|
|
((uint8_t*)(p))[(i)+1] = (d)>>8; } |
|
|
|
|
|
|
|
|
|
#define AV_RL32(x) ((((uint8_t*)(x))[3] << 24) | \ |
|
|
|
|
(((uint8_t*)(x))[2] << 16) | \
|
|
|
|
|
(((uint8_t*)(x))[1] << 8) | \
|
|
|
|
|
((uint8_t*)(x))[0]) |
|
|
|
|
#endif |
|
|
|
|
#define AV_WL32(p, i, d) { \ |
|
|
|
|
((uint8_t*)(p))[(i)] = (d); \
|
|
|
|
|
((uint8_t*)(p))[(i)+1] = (d)>>8; \
|
|
|
|
|
((uint8_t*)(p))[(i)+2] = (d)>>16; \
|
|
|
|
|
((uint8_t*)(p))[(i)+3] = (d)>>24; } |
|
|
|
|
|
|
|
|
|
#endif /* INTREADWRITE_H */ |
|
|
|
|