From e9538aabfe6cb2a9d8a76c71a77bc02f2fd9341f Mon Sep 17 00:00:00 2001 From: John Cupitt Date: Fri, 7 Mar 2008 23:54:10 +0000 Subject: [PATCH] stuff --- ChangeLog | 1 + libsrc/iofuncs/im_desc_hd.c | 13 +++++++++---- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/ChangeLog b/ChangeLog index 8fab4542..becb3934 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,6 @@ 7/3/08 started 7.15.0 - MAGIC numbers should be unsigned +- write MAGIC correctly on sparc/powerpc machines 25/1/08 started 7.14.0 - bump all version numbers for new stable diff --git a/libsrc/iofuncs/im_desc_hd.c b/libsrc/iofuncs/im_desc_hd.c index 4db8046f..23af15cb 100644 --- a/libsrc/iofuncs/im_desc_hd.c +++ b/libsrc/iofuncs/im_desc_hd.c @@ -23,6 +23,8 @@ * - use gunit32/16 for 2 and 4 byte quantities * 12/1/07 * - override bbits in the file ... it's now deprecated + * 7/3/08 + * - write MAGIC correctly on sparc/powerpc machines */ /* @@ -184,11 +186,14 @@ im__write_header_bytes( IMAGE *im, unsigned char *to ) int i; unsigned char *q; - /* How odd, you'd think it would be the other way around. + /* Always write MSB first. */ - magic = im_amiMSBfirst() ? IM_MAGIC_INTEL : IM_MAGIC_SPARC; - q = to; - im__write_4byte( &q, (unsigned char *) &magic ); + magic = im_amiMSBfirst() ? IM_MAGIC_SPARC : IM_MAGIC_INTEL; + to[0] = (magic & 0xff000000) >> 24; + to[1] = (magic & 0xff0000) >> 16; + to[2] = (magic & 0xff00) >> 8; + to[3] = magic & 0xff; + q = to + 4; for( i = 0; i < IM_NUMBER( fields ); i++ ) fields[i].write( &q,