Remove a VEC from py-unwind.c

This removes a use of VEC from py-unwind.c, replacing it wit
std::vector.  It also changes saved_regs to hold a gdbpy_ref<>,
simplifying the memory management.

Tested against gdb.python on x86-64 Fedora 26.

gdb/ChangeLog
2018-06-27  Tom Tromey  <tom@tromey.com>

	* python/py-unwind.c (unwind_info_object) <saved_regs>: Now a
	std::vector.
	(unwind_infopy_str, pyuw_create_unwind_info)
	(unwind_infopy_add_saved_register, pyuw_sniffer)
	(unwind_infopy_dealloc, unwind_infopy_add_saved_register):
	Update.
	(struct saved_reg): Add constructor.
	<value>: Now a gdbpy_ref<>.
This commit is contained in:
Tom Tromey 2018-06-05 10:02:45 -06:00
parent 6317728958
commit 0c6aef226e
2 changed files with 39 additions and 32 deletions

View file

@ -1,3 +1,14 @@
2018-06-27 Tom Tromey <tom@tromey.com>
* python/py-unwind.c (unwind_info_object) <saved_regs>: Now a
std::vector.
(unwind_infopy_str, pyuw_create_unwind_info)
(unwind_infopy_add_saved_register, pyuw_sniffer)
(unwind_infopy_dealloc, unwind_infopy_add_saved_register):
Update.
(struct saved_reg): Add constructor.
<value>: Now a gdbpy_ref<>.
2018-06-27 Tom Tromey <tom@tromey.com> 2018-06-27 Tom Tromey <tom@tromey.com>
* machoread.c (macho_symfile_read): Define "symbol_table" earlier. * machoread.c (macho_symfile_read): Define "symbol_table" earlier.

View file

@ -46,12 +46,17 @@ typedef struct
/* Saved registers array item. */ /* Saved registers array item. */
typedef struct struct saved_reg
{ {
saved_reg (int n, gdbpy_ref<> &&v)
: number (n),
value (std::move (v))
{
}
int number; int number;
PyObject *value; gdbpy_ref<> value;
} saved_reg; };
DEF_VEC_O (saved_reg);
/* The data we keep for the PyUnwindInfo: pending_frame, saved registers /* The data we keep for the PyUnwindInfo: pending_frame, saved registers
and frame ID. */ and frame ID. */
@ -67,7 +72,7 @@ typedef struct
struct frame_id frame_id; struct frame_id frame_id;
/* Saved registers array. */ /* Saved registers array. */
VEC (saved_reg) *saved_regs; std::vector<saved_reg> *saved_regs;
} unwind_info_object; } unwind_info_object;
/* The data we keep for a frame we can unwind: frame ID and an array of /* The data we keep for a frame we can unwind: frame ID and an array of
@ -196,17 +201,15 @@ unwind_infopy_str (PyObject *self)
fprint_frame_id (&stb, unwind_info->frame_id); fprint_frame_id (&stb, unwind_info->frame_id);
{ {
const char *sep = ""; const char *sep = "";
int i;
struct value_print_options opts; struct value_print_options opts;
saved_reg *reg;
get_user_print_options (&opts); get_user_print_options (&opts);
stb.printf ("\nSaved registers: ("); stb.printf ("\nSaved registers: (");
for (i = 0; VEC_iterate (saved_reg, unwind_info->saved_regs, i, reg); i++) for (const saved_reg &reg : *unwind_info->saved_regs)
{ {
struct value *value = value_object_to_value (reg->value); struct value *value = value_object_to_value (reg.value.get ());
stb.printf ("%s(%d, ", sep, reg->number); stb.printf ("%s(%d, ", sep, reg.number);
if (value != NULL) if (value != NULL)
{ {
TRY TRY
@ -249,7 +252,7 @@ pyuw_create_unwind_info (PyObject *pyo_pending_frame,
unwind_info->frame_id = frame_id; unwind_info->frame_id = frame_id;
Py_INCREF (pyo_pending_frame); Py_INCREF (pyo_pending_frame);
unwind_info->pending_frame = pyo_pending_frame; unwind_info->pending_frame = pyo_pending_frame;
unwind_info->saved_regs = VEC_alloc (saved_reg, 4); unwind_info->saved_regs = new std::vector<saved_reg>;
return (PyObject *) unwind_info; return (PyObject *) unwind_info;
} }
@ -303,24 +306,19 @@ unwind_infopy_add_saved_register (PyObject *self, PyObject *args)
} }
} }
{ {
int i; gdbpy_ref<> new_value = gdbpy_ref<>::new_reference (pyo_reg_value);
saved_reg *reg; bool found = false;
for (saved_reg &reg : *unwind_info->saved_regs)
for (i = 0; VEC_iterate (saved_reg, unwind_info->saved_regs, i, reg); i++)
{ {
if (regnum == reg->number) if (regnum == reg.number)
{ {
Py_DECREF (reg->value); found = true;
reg.value = std::move (new_value);
break; break;
} }
} }
if (reg == NULL) if (!found)
{ unwind_info->saved_regs->emplace_back (regnum, std::move (new_value));
reg = VEC_safe_push (saved_reg, unwind_info->saved_regs, NULL);
reg->number = regnum;
}
Py_INCREF (pyo_reg_value);
reg->value = pyo_reg_value;
} }
Py_RETURN_NONE; Py_RETURN_NONE;
} }
@ -335,9 +333,7 @@ unwind_infopy_dealloc (PyObject *self)
saved_reg *reg; saved_reg *reg;
Py_XDECREF (unwind_info->pending_frame); Py_XDECREF (unwind_info->pending_frame);
for (i = 0; VEC_iterate (saved_reg, unwind_info->saved_regs, i, reg); i++) delete unwind_info->saved_regs;
Py_DECREF (reg->value);
VEC_free (saved_reg, unwind_info->saved_regs);
Py_TYPE (self)->tp_free (self); Py_TYPE (self)->tp_free (self);
} }
@ -560,9 +556,7 @@ pyuw_sniffer (const struct frame_unwind *self, struct frame_info *this_frame,
{ {
unwind_info_object *unwind_info = unwind_info_object *unwind_info =
(unwind_info_object *) pyo_unwind_info.get (); (unwind_info_object *) pyo_unwind_info.get ();
int reg_count = VEC_length (saved_reg, unwind_info->saved_regs); int reg_count = unwind_info->saved_regs->size ();
saved_reg *reg;
int i;
cached_frame cached_frame
= ((cached_frame_info *) = ((cached_frame_info *)
@ -573,9 +567,11 @@ pyuw_sniffer (const struct frame_unwind *self, struct frame_info *this_frame,
cached_frame->reg_count = reg_count; cached_frame->reg_count = reg_count;
/* Populate registers array. */ /* Populate registers array. */
for (i = 0; VEC_iterate (saved_reg, unwind_info->saved_regs, i, reg); i++) for (int i = 0; i < unwind_info->saved_regs->size (); ++i)
{ {
struct value *value = value_object_to_value (reg->value); saved_reg *reg = &(*unwind_info->saved_regs)[i];
struct value *value = value_object_to_value (reg->value.get ());
size_t data_size = register_size (gdbarch, reg->number); size_t data_size = register_size (gdbarch, reg->number);
cached_frame->reg[i].num = reg->number; cached_frame->reg[i].num = reg->number;