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)
 {