summaryrefslogtreecommitdiff
path: root/opcodes/cgen-dis.in
diff options
context:
space:
mode:
authorFrank Ch. Eigler <fche@redhat.com>2001-01-03 15:10:26 +0000
committerFrank Ch. Eigler <fche@redhat.com>2001-01-03 15:10:26 +0000
commit0869210290054c3483fd0a7d597259b4d2731452 (patch)
tree381654acbbb0e8a6f4db926f3c0d04a572149f30 /opcodes/cgen-dis.in
parent262992c71be935ef709f5c0641778c50c33fb4f7 (diff)
downloadbinutils-redhat-0869210290054c3483fd0a7d597259b4d2731452.tar.gz
* generalization
2001-01-03 Richard Sandiford <r.sandiford@redhat.com> cgen-dis.in (read_insn): Use bfd_get_bits()
Diffstat (limited to 'opcodes/cgen-dis.in')
-rw-r--r--opcodes/cgen-dis.in16
1 files changed, 1 insertions, 15 deletions
diff --git a/opcodes/cgen-dis.in b/opcodes/cgen-dis.in
index 22cef1f0fe..9d25c1a347 100644
--- a/opcodes/cgen-dis.in
+++ b/opcodes/cgen-dis.in
@@ -211,21 +211,7 @@ read_insn (cd, pc, info, buf, buflen, ex_info, insn_value)
ex_info->valid = (1 << buflen) - 1;
ex_info->insn_bytes = buf;
- switch (buflen)
- {
- case 1:
- *insn_value = buf[0];
- break;
- case 2:
- *insn_value = info->endian == BFD_ENDIAN_BIG ? bfd_getb16 (buf) : bfd_getl16 (buf);
- break;
- case 4:
- *insn_value = info->endian == BFD_ENDIAN_BIG ? bfd_getb32 (buf) : bfd_getl32 (buf);
- break;
- default:
- abort ();
- }
-
+ *insn_value = bfd_get_bits (buf, buflen * 8, info->endian == BFD_ENDIAN_BIG);
return 0;
}