# HG changeset patch # User philipjsg # Date 1038284980 0 # Node ID d3fc77a6d57e8ecb4eef2917369c34feb6d5ce55 # Parent 653d9419ea01c777ffcc4355c3aef733c8d48698 Add some rudimentary support for sparc64 diff -r 653d9419ea01 -r d3fc77a6d57e common.h --- a/common.h Tue Nov 26 00:54:27 2002 +0000 +++ b/common.h Tue Nov 26 04:29:40 2002 +0000 @@ -248,6 +248,10 @@ uint8_t run; } RL_VLC_ELEM; +#ifdef ARCH_SPARC64 +#define UNALIGNED_STORES_ARE_BAD +#endif + /* used to avoid missaligned exceptions on some archs (alpha, ...) */ #ifdef ARCH_X86 # define unaligned32(a) (*(UINT32*)(a)) @@ -294,6 +298,14 @@ } else { bit_buf<<=bit_left; bit_buf |= value >> (n - bit_left); +#ifdef UNALIGNED_STORES_ARE_BAD + if (3 & (int) s->buf_ptr) { + s->buf_ptr[0] = bit_buf >> 24; + s->buf_ptr[1] = bit_buf >> 16; + s->buf_ptr[2] = bit_buf >> 8; + s->buf_ptr[3] = bit_buf ; + } else +#endif *(UINT32 *)s->buf_ptr = be2me_32(bit_buf); //printf("bitbuf = %08x\n", bit_buf); s->buf_ptr+=4;