diff options
author | Kung Hsu <kung@cygnus> | 1995-03-01 02:13:06 +0000 |
---|---|---|
committer | Kung Hsu <kung@cygnus> | 1995-03-01 02:13:06 +0000 |
commit | 66aa7cf935634f615e1134f708c3d5aa95b3e5bc (patch) | |
tree | c3107773f7628d62d9f249c5c8000b4d9d749911 /gdb | |
parent | abed6bc2e16f4253cfe464db18a2aefcda871a80 (diff) | |
download | gdb-66aa7cf935634f615e1134f708c3d5aa95b3e5bc.zip gdb-66aa7cf935634f615e1134f708c3d5aa95b3e5bc.tar.gz gdb-66aa7cf935634f615e1134f708c3d5aa95b3e5bc.tar.bz2 |
* defs.h (SWAP_TARGET_AND_HOST): check endianess at runtime not
compile time.
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 3 | ||||
-rw-r--r-- | gdb/defs.h | 31 |
2 files changed, 19 insertions, 15 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 33bcbe3..b6096ee 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,8 @@ Tue Feb 28 14:38:39 1995 Kung Hsu <kung@mexican.cygnus.com> + * defs.h (SWAP_TARGET_AND_HOST): check endianess at runtime not + compile time. + * arc-tdep.c (_initialize_arc_tdep): set tm_print_insn according to processor. * remote-arc.c (arc_wait): when a processor stops, stop other two @@ -741,22 +741,23 @@ extern void set_endian_from_file PARAMS ((bfd *)); #endif /* BITS_BIG_ENDIAN not defined. */ /* Swap LEN bytes at BUFFER between target and host byte-order. */ -#if TARGET_BYTE_ORDER == HOST_BYTE_ORDER -#define SWAP_TARGET_AND_HOST(buffer,len) -#else /* Target and host byte order differ. */ #define SWAP_TARGET_AND_HOST(buffer,len) \ - { \ - char __tmp_; \ - char *p = (char *)(buffer); \ - char *q = ((char *)(buffer)) + len - 1; \ - for (; p < q; p++, q--) \ - { \ - __tmp_ = *q; \ - *q = *p; \ - *p = __tmp_; \ - } \ - } -#endif /* Target and host byte order differ. */ + do \ + { \ + if (TARGET_BYTE_ORDER != HOST_BYTE_ORDER) \ + { \ + char tmp; \ + char *p = (char *)(buffer); \ + char *q = ((char *)(buffer)) + len - 1; \ + for (; p < q; p++, q--) \ + { \ + tmp = *q; \ + *q = *p; \ + *p = tmp; \ + } \ + } \ + } \ + while (0) /* In findvar.c. */ |