Mercurial > libavcodec.hg
changeset 493:873b9075d853 libavcodec
move unaligned access macros to dsputil.h - added unaligned 32 bit store
author | bellard |
---|---|
date | Tue, 11 Jun 2002 13:43:27 +0000 |
parents | de11e138a661 |
children | 54b88078c361 |
files | dsputil.c dsputil.h |
diffstat | 2 files changed, 19 insertions(+), 15 deletions(-) [+] |
line wrap: on
line diff
--- a/dsputil.c Tue Jun 11 13:42:18 2002 +0000 +++ b/dsputil.c Tue Jun 11 13:43:27 2002 +0000 @@ -252,21 +252,6 @@ } } -#ifdef __GNUC__ - -struct unaligned_64 { uint64_t l; } __attribute__((packed)); -struct unaligned_32 { uint32_t l; } __attribute__((packed)); - -#define LD32(a) (((const struct unaligned_32 *) (a))->l) -#define LD64(a) (((const struct unaligned_64 *) (a))->l) - -#else /* __GNUC__ */ - -#define LD32(a) (*((uint32_t*)(a))) -#define LD64(a) (*((uint64_t*)(a))) - -#endif /* !__GNUC__ */ - #if 0 #define PIXOP2(OPNAME, OP) \
--- a/dsputil.h Tue Jun 11 13:42:18 2002 +0000 +++ b/dsputil.h Tue Jun 11 13:43:27 2002 +0000 @@ -168,6 +168,25 @@ #endif +#ifdef __GNUC__ + +struct unaligned_64 { uint64_t l; } __attribute__((packed)); +struct unaligned_32 { uint32_t l; } __attribute__((packed)); + +#define LD32(a) (((const struct unaligned_32 *) (a))->l) +#define LD64(a) (((const struct unaligned_64 *) (a))->l) + +#define ST32(a, b) (((struct unaligned_32 *) (a))->l) = (b) + +#else /* __GNUC__ */ + +#define LD32(a) (*((uint32_t*)(a))) +#define LD64(a) (*((uint64_t*)(a))) + +#define ST32(a, b) *((uint32_t*)(a)) = (b) + +#endif /* !__GNUC__ */ + /* PSNR */ void get_psnr(UINT8 *orig_image[3], UINT8 *coded_image[3], int orig_linesize[3], int coded_linesize,