gnulib: import count-one-bits module and use it
For a fix I intend to submit, I would need a function that counts the number of set bits in a word. There is __builtin_popcount that is supported by gcc and clang, but there is also a gnulib module that wraps that and provides a fallback for other compilers, so I think it would be good to use it. I also noticed that there is a bitcount function in arch/arm.c, so I thought that as a first step I would replace that one with the gnulib count-one-bits module. This is what this patch does. The gnulib module provides multiple functions, with various parameter length (unsigned int, unsigned long int, unsigned long long int), I chose the one that made sense for each call site based on the argument type. gnulib/ChangeLog: * update-gnulib.sh (IMPORTED_GNULIB_MODULES): Import count-one-bits module. * configure: Re-generate. * aclocal.m4: Re-generate. * Makefile.in: Re-generate. * import/count-one-bits.c: New file. * import/count-one-bits.h: New file. * import/Makefile.am: Re-generate. * import/Makefile.in: Re-generate. * import/m4/gnulib-cache.m4: Re-generate. * import/m4/gnulib-comp.m4: Re-generate. * import/m4/count-one-bits.m4: New file. gdb/ChangeLog: * arm-tdep.c: Include count-one-bits.h. (cleanup_block_store_pc): Use count_one_bits. (cleanup_block_load_pc): Use count_one_bits. (arm_copy_block_xfer): Use count_one_bits. (thumb2_copy_block_xfer): Use count_one_bits. (thumb_copy_pop_pc_16bit): Use count_one_bits. * arch/arm-get-next-pcs.c: Include count-one-bits.h. (thumb_get_next_pcs_raw): Use count_one_bits. (arm_get_next_pcs_raw): Use count_one_bits_l. * arch/arm.c (bitcount): Remove. * arch/arm.h (bitcount): Remove.
This commit is contained in:
parent
8084e579e1
commit
5f661e0397
17 changed files with 303 additions and 103 deletions
|
@ -22,6 +22,7 @@
|
|||
#include "gdbsupport/common-regcache.h"
|
||||
#include "arm.h"
|
||||
#include "arm-get-next-pcs.h"
|
||||
#include "count-one-bits.h"
|
||||
|
||||
/* See arm-get-next-pcs.h. */
|
||||
|
||||
|
@ -408,8 +409,8 @@ thumb_get_next_pcs_raw (struct arm_get_next_pcs *self)
|
|||
|
||||
/* Fetch the saved PC from the stack. It's stored above
|
||||
all of the other registers. */
|
||||
unsigned long offset = bitcount (bits (inst1, 0, 7))
|
||||
* ARM_INT_REGISTER_SIZE;
|
||||
unsigned long offset
|
||||
= count_one_bits (bits (inst1, 0, 7)) * ARM_INT_REGISTER_SIZE;
|
||||
sp = regcache_raw_get_unsigned (regcache, ARM_SP_REGNUM);
|
||||
nextpc = self->ops->read_mem_uint (sp + offset, 4, byte_order);
|
||||
}
|
||||
|
@ -496,7 +497,7 @@ thumb_get_next_pcs_raw (struct arm_get_next_pcs *self)
|
|||
/* LDMIA or POP */
|
||||
if (!bit (inst2, 15))
|
||||
load_pc = 0;
|
||||
offset = bitcount (inst2) * 4 - 4;
|
||||
offset = count_one_bits (inst2) * 4 - 4;
|
||||
}
|
||||
else if (!bit (inst1, 7) && bit (inst1, 8))
|
||||
{
|
||||
|
@ -864,7 +865,7 @@ arm_get_next_pcs_raw (struct arm_get_next_pcs *self)
|
|||
{
|
||||
/* up */
|
||||
unsigned long reglist = bits (this_instr, 0, 14);
|
||||
offset = bitcount (reglist) * 4;
|
||||
offset = count_one_bits_l (reglist) * 4;
|
||||
if (bit (this_instr, 24)) /* pre */
|
||||
offset += 4;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue