From: Frank Ch. Eigler Date: Wed, 3 Jan 2001 15:10:26 +0000 (+0000) Subject: * generalization X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7e30bc3635d961336a9db1c88d4e18bea5012038;p=binutils-gdb.git * generalization 2001-01-03 Richard Sandiford cgen-dis.in (read_insn): Use bfd_get_bits() --- diff --git a/opcodes/ChangeLog b/opcodes/ChangeLog index a9a0645acba..1666a769c2e 100644 --- a/opcodes/ChangeLog +++ b/opcodes/ChangeLog @@ -1,3 +1,7 @@ +2001-01-03 Richard Sandiford + + cgen-dis.in (read_insn): Use bfd_get_bits() + 2001-01-02 Richard Sandiford * cgen-dis.c (hash_insn_array): Use bfd_put_bits(). diff --git a/opcodes/cgen-dis.in b/opcodes/cgen-dis.in index 22cef1f0fee..9d25c1a3476 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; }