endianness fix
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1055 c046a42c-6fe2-441c-8c8c-71466251a162
diff --git a/ppc-dis.c b/ppc-dis.c
index 354b2ac..fcced17 100644
--- a/ppc-dis.c
+++ b/ppc-dis.c
@@ -3076,15 +3076,20 @@
int print_insn_ppc (bfd_vma pc, disassemble_info *info)
{
uint32_t opc;
+ bfd_byte buf[4];
- (*info->read_memory_func)(pc, (bfd_byte *)(&opc), 4, info);
- return print_insn_powerpc (info->stream, tswap32(opc), pc,
+ (*info->read_memory_func)(pc, buf, 4, info);
+ if (info->endian == BFD_ENDIAN_BIG)
+ opc = bfd_getb32(buf);
+ else
+ opc = bfd_getl32(buf);
+ return print_insn_powerpc (info->stream, opc, pc,
PPC | B32 | M601);
}
/* Print a PowerPC or POWER instruction. */
-int
+static int
print_insn_powerpc (FILE *out, uint32_t insn, unsigned memaddr,
int dialect)
{