gdb: Use vector::emplace_back
[deliverable/binutils-gdb.git] / gdb / python / py-inferior.c
CommitLineData
595939de
PM
1/* Python interface to inferiors.
2
618f726f 3 Copyright (C) 2009-2016 Free Software Foundation, Inc.
595939de
PM
4
5 This file is part of GDB.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
19
20#include "defs.h"
595939de
PM
21#include "gdbcore.h"
22#include "gdbthread.h"
23#include "inferior.h"
20c168b5 24#include "objfiles.h"
595939de
PM
25#include "observer.h"
26#include "python-internal.h"
27#include "arch-utils.h"
28#include "language.h"
505500db
SW
29#include "gdb_signals.h"
30#include "py-event.h"
31#include "py-stopevent.h"
595939de
PM
32
33struct threadlist_entry {
34 thread_object *thread_obj;
35 struct threadlist_entry *next;
36};
37
38typedef struct
39{
40 PyObject_HEAD
41
42 /* The inferior we represent. */
43 struct inferior *inferior;
44
45 /* thread_object instances under this inferior. This list owns a
46 reference to each object it contains. */
47 struct threadlist_entry *threads;
48
49 /* Number of threads in the list. */
50 int nthreads;
51} inferior_object;
52
e36122e9 53extern PyTypeObject inferior_object_type
62eec1a5 54 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("inferior_object");
595939de
PM
55
56static const struct inferior_data *infpy_inf_data_key;
57
58typedef struct {
59 PyObject_HEAD
60 void *buffer;
61
62 /* These are kept just for mbpy_str. */
63 CORE_ADDR addr;
64 CORE_ADDR length;
65} membuf_object;
66
e36122e9 67extern PyTypeObject membuf_object_type
62eec1a5 68 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("membuf_object");
595939de
PM
69
70/* Require that INFERIOR be a valid inferior ID. */
71#define INFPY_REQUIRE_VALID(Inferior) \
72 do { \
73 if (!Inferior->inferior) \
74 { \
75 PyErr_SetString (PyExc_RuntimeError, \
76 _("Inferior no longer exists.")); \
77 return NULL; \
78 } \
79 } while (0)
80
505500db
SW
81static void
82python_on_normal_stop (struct bpstats *bs, int print_frame)
83{
84 struct cleanup *cleanup;
2ea28649 85 enum gdb_signal stop_signal;
505500db 86
0646da15
TT
87 if (!gdb_python_initialized)
88 return;
89
505500db
SW
90 if (!find_thread_ptid (inferior_ptid))
91 return;
92
93 stop_signal = inferior_thread ()->suspend.stop_signal;
94
95 cleanup = ensure_python_env (get_current_arch (), current_language);
96
97 if (emit_stop_event (bs, stop_signal) < 0)
98 gdbpy_print_stack ();
99
100 do_cleanups (cleanup);
101}
102
103static void
104python_on_resume (ptid_t ptid)
105{
106 struct cleanup *cleanup;
107
0646da15
TT
108 if (!gdb_python_initialized)
109 return;
110
f5656ead 111 cleanup = ensure_python_env (target_gdbarch (), current_language);
505500db
SW
112
113 if (emit_continue_event (ptid) < 0)
114 gdbpy_print_stack ();
115
116 do_cleanups (cleanup);
117}
118
162078c8
NB
119/* Callback, registered as an observer, that notifies Python listeners
120 when an inferior function call is about to be made. */
121
122static void
123python_on_inferior_call_pre (ptid_t thread, CORE_ADDR address)
124{
125 struct cleanup *cleanup;
126
127 cleanup = ensure_python_env (target_gdbarch (), current_language);
128
129 if (emit_inferior_call_event (INFERIOR_CALL_PRE, thread, address) < 0)
130 gdbpy_print_stack ();
131
132 do_cleanups (cleanup);
133}
134
135/* Callback, registered as an observer, that notifies Python listeners
136 when an inferior function call has completed. */
137
138static void
139python_on_inferior_call_post (ptid_t thread, CORE_ADDR address)
140{
141 struct cleanup *cleanup;
142
143 cleanup = ensure_python_env (target_gdbarch (), current_language);
144
145 if (emit_inferior_call_event (INFERIOR_CALL_POST, thread, address) < 0)
146 gdbpy_print_stack ();
147
148 do_cleanups (cleanup);
149}
150
151/* Callback, registered as an observer, that notifies Python listeners
152 when a part of memory has been modified by user action (eg via a
153 'set' command). */
154
155static void
156python_on_memory_change (struct inferior *inferior, CORE_ADDR addr, ssize_t len, const bfd_byte *data)
157{
158 struct cleanup *cleanup;
159
160 cleanup = ensure_python_env (target_gdbarch (), current_language);
161
162 if (emit_memory_changed_event (addr, len) < 0)
163 gdbpy_print_stack ();
164
165 do_cleanups (cleanup);
166}
167
168/* Callback, registered as an observer, that notifies Python listeners
169 when a register has been modified by user action (eg via a 'set'
170 command). */
171
172static void
173python_on_register_change (struct frame_info *frame, int regnum)
174{
175 struct cleanup *cleanup;
176
177 cleanup = ensure_python_env (target_gdbarch (), current_language);
178
179 if (emit_register_changed_event (frame, regnum) < 0)
180 gdbpy_print_stack ();
181
182 do_cleanups (cleanup);
183}
184
505500db
SW
185static void
186python_inferior_exit (struct inferior *inf)
187{
188 struct cleanup *cleanup;
8cf64490 189 const LONGEST *exit_code = NULL;
505500db 190
0646da15
TT
191 if (!gdb_python_initialized)
192 return;
193
f5656ead 194 cleanup = ensure_python_env (target_gdbarch (), current_language);
505500db 195
8cf64490
TT
196 if (inf->has_exit_code)
197 exit_code = &inf->exit_code;
505500db 198
cb6be26b 199 if (emit_exited_event (exit_code, inf) < 0)
505500db
SW
200 gdbpy_print_stack ();
201
202 do_cleanups (cleanup);
203}
204
20c168b5 205/* Callback used to notify Python listeners about new objfiles loaded in the
4ffbba72
DE
206 inferior. OBJFILE may be NULL which means that the objfile list has been
207 cleared (emptied). */
20c168b5
KP
208
209static void
210python_new_objfile (struct objfile *objfile)
211{
212 struct cleanup *cleanup;
213
0646da15
TT
214 if (!gdb_python_initialized)
215 return;
216
4ffbba72
DE
217 cleanup = ensure_python_env (objfile != NULL
218 ? get_objfile_arch (objfile)
219 : target_gdbarch (),
220 current_language);
20c168b5 221
4ffbba72
DE
222 if (objfile == NULL)
223 {
224 if (emit_clear_objfiles_event () < 0)
225 gdbpy_print_stack ();
226 }
227 else
228 {
229 if (emit_new_objfile_event (objfile) < 0)
230 gdbpy_print_stack ();
231 }
20c168b5
KP
232
233 do_cleanups (cleanup);
234}
235
754eadd1 236/* Return a reference to the Python object of type Inferior
595939de 237 representing INFERIOR. If the object has already been created,
754eadd1
PM
238 return it and increment the reference count, otherwise, create it.
239 Return NULL on failure. */
595939de
PM
240PyObject *
241inferior_to_inferior_object (struct inferior *inferior)
242{
243 inferior_object *inf_obj;
244
19ba03f4 245 inf_obj = (inferior_object *) inferior_data (inferior, infpy_inf_data_key);
595939de
PM
246 if (!inf_obj)
247 {
595939de
PM
248 inf_obj = PyObject_New (inferior_object, &inferior_object_type);
249 if (!inf_obj)
595939de 250 return NULL;
595939de
PM
251
252 inf_obj->inferior = inferior;
253 inf_obj->threads = NULL;
254 inf_obj->nthreads = 0;
255
256 set_inferior_data (inferior, infpy_inf_data_key, inf_obj);
257
595939de 258 }
754eadd1
PM
259 else
260 Py_INCREF ((PyObject *)inf_obj);
595939de
PM
261
262 return (PyObject *) inf_obj;
263}
264
265/* Finds the Python Inferior object for the given PID. Returns a
754eadd1 266 reference, or NULL if PID does not match any inferior object. */
505500db 267
595939de
PM
268PyObject *
269find_inferior_object (int pid)
270{
595939de
PM
271 struct inferior *inf = find_inferior_pid (pid);
272
273 if (inf)
274 return inferior_to_inferior_object (inf);
275
276 return NULL;
277}
278
279thread_object *
280find_thread_object (ptid_t ptid)
281{
282 int pid;
283 struct threadlist_entry *thread;
284 PyObject *inf_obj;
754eadd1 285 thread_object *found = NULL;
595939de 286
dfd4cc63 287 pid = ptid_get_pid (ptid);
ea976c60
PM
288 if (pid == 0)
289 return NULL;
290
595939de
PM
291 inf_obj = find_inferior_object (pid);
292
754eadd1
PM
293 if (! inf_obj)
294 return NULL;
295
296 for (thread = ((inferior_object *)inf_obj)->threads; thread;
297 thread = thread->next)
298 if (ptid_equal (thread->thread_obj->thread->ptid, ptid))
299 {
300 found = thread->thread_obj;
301 break;
302 }
303
304 Py_DECREF (inf_obj);
305
306 if (found)
307 return found;
595939de
PM
308
309 return NULL;
310}
311
312static void
313add_thread_object (struct thread_info *tp)
314{
315 struct cleanup *cleanup;
316 thread_object *thread_obj;
317 inferior_object *inf_obj;
318 struct threadlist_entry *entry;
319
0646da15
TT
320 if (!gdb_python_initialized)
321 return;
322
595939de
PM
323 cleanup = ensure_python_env (python_gdbarch, python_language);
324
325 thread_obj = create_thread_object (tp);
326 if (!thread_obj)
327 {
328 gdbpy_print_stack ();
329 do_cleanups (cleanup);
330 return;
331 }
332
333 inf_obj = (inferior_object *) thread_obj->inf_obj;
334
8d749320 335 entry = XNEW (struct threadlist_entry);
595939de
PM
336 entry->thread_obj = thread_obj;
337 entry->next = inf_obj->threads;
338
339 inf_obj->threads = entry;
340 inf_obj->nthreads++;
341
342 do_cleanups (cleanup);
343}
344
345static void
346delete_thread_object (struct thread_info *tp, int ignore)
347{
348 struct cleanup *cleanup;
349 inferior_object *inf_obj;
595939de 350 struct threadlist_entry **entry, *tmp;
256458bc 351
0646da15
TT
352 if (!gdb_python_initialized)
353 return;
354
5d9c5995 355 cleanup = ensure_python_env (python_gdbarch, python_language);
595939de 356
dfd4cc63
LM
357 inf_obj
358 = (inferior_object *) find_inferior_object (ptid_get_pid (tp->ptid));
595939de 359 if (!inf_obj)
5d9c5995
PM
360 {
361 do_cleanups (cleanup);
362 return;
363 }
595939de
PM
364
365 /* Find thread entry in its inferior's thread_list. */
366 for (entry = &inf_obj->threads; *entry != NULL; entry =
367 &(*entry)->next)
368 if ((*entry)->thread_obj->thread == tp)
369 break;
370
371 if (!*entry)
754eadd1
PM
372 {
373 Py_DECREF (inf_obj);
5d9c5995 374 do_cleanups (cleanup);
754eadd1
PM
375 return;
376 }
595939de 377
595939de
PM
378 tmp = *entry;
379 tmp->thread_obj->thread = NULL;
380
381 *entry = (*entry)->next;
382 inf_obj->nthreads--;
383
384 Py_DECREF (tmp->thread_obj);
754eadd1 385 Py_DECREF (inf_obj);
595939de
PM
386 xfree (tmp);
387
388 do_cleanups (cleanup);
389}
390
391static PyObject *
392infpy_threads (PyObject *self, PyObject *args)
393{
394 int i;
395 struct threadlist_entry *entry;
396 inferior_object *inf_obj = (inferior_object *) self;
397 PyObject *tuple;
398
399 INFPY_REQUIRE_VALID (inf_obj);
400
492d29ea
PA
401 TRY
402 {
403 update_thread_list ();
404 }
405 CATCH (except, RETURN_MASK_ALL)
406 {
407 GDB_PY_HANDLE_EXCEPTION (except);
408 }
409 END_CATCH
f66713d2 410
595939de
PM
411 tuple = PyTuple_New (inf_obj->nthreads);
412 if (!tuple)
413 return NULL;
414
415 for (i = 0, entry = inf_obj->threads; i < inf_obj->nthreads;
416 i++, entry = entry->next)
417 {
418 Py_INCREF (entry->thread_obj);
419 PyTuple_SET_ITEM (tuple, i, (PyObject *) entry->thread_obj);
420 }
421
422 return tuple;
423}
424
425static PyObject *
426infpy_get_num (PyObject *self, void *closure)
427{
428 inferior_object *inf = (inferior_object *) self;
429
430 INFPY_REQUIRE_VALID (inf);
431
432 return PyLong_FromLong (inf->inferior->num);
433}
434
435static PyObject *
436infpy_get_pid (PyObject *self, void *closure)
437{
438 inferior_object *inf = (inferior_object *) self;
439
440 INFPY_REQUIRE_VALID (inf);
441
442 return PyLong_FromLong (inf->inferior->pid);
443}
444
445static PyObject *
446infpy_get_was_attached (PyObject *self, void *closure)
447{
448 inferior_object *inf = (inferior_object *) self;
449
450 INFPY_REQUIRE_VALID (inf);
451 if (inf->inferior->attach_flag)
452 Py_RETURN_TRUE;
453 Py_RETURN_FALSE;
454}
455
456static int
457build_inferior_list (struct inferior *inf, void *arg)
458{
19ba03f4 459 PyObject *list = (PyObject *) arg;
595939de 460 PyObject *inferior = inferior_to_inferior_object (inf);
754eadd1
PM
461 int success = 0;
462
463 if (! inferior)
464 return 0;
465
466 success = PyList_Append (list, inferior);
467 Py_DECREF (inferior);
595939de 468
754eadd1 469 if (success)
2d565757
MS
470 return 1;
471
595939de
PM
472 return 0;
473}
474
475/* Implementation of gdb.inferiors () -> (gdb.Inferior, ...).
476 Returns a tuple of all inferiors. */
477PyObject *
478gdbpy_inferiors (PyObject *unused, PyObject *unused2)
479{
27ca1a5b 480 PyObject *list, *tuple;
595939de
PM
481
482 list = PyList_New (0);
483 if (!list)
484 return NULL;
485
2d565757
MS
486 if (iterate_over_inferiors (build_inferior_list, list))
487 {
488 Py_DECREF (list);
489 return NULL;
490 }
595939de 491
27ca1a5b
PM
492 tuple = PyList_AsTuple (list);
493 Py_DECREF (list);
494
495 return tuple;
595939de
PM
496}
497
498/* Membuf and memory manipulation. */
499
2678e2af 500/* Implementation of Inferior.read_memory (address, length).
595939de 501 Returns a Python buffer object with LENGTH bytes of the inferior's
8dc78533
JK
502 memory at ADDRESS. Both arguments are integers. Returns NULL on error,
503 with a python exception set. */
595939de
PM
504static PyObject *
505infpy_read_memory (PyObject *self, PyObject *args, PyObject *kw)
506{
595939de 507 CORE_ADDR addr, length;
7c543f7b 508 gdb_byte *buffer = NULL;
595939de 509 membuf_object *membuf_obj;
cc0265cd 510 PyObject *addr_obj, *length_obj, *result;
595939de
PM
511 static char *keywords[] = { "address", "length", NULL };
512
513 if (! PyArg_ParseTupleAndKeywords (args, kw, "OO", keywords,
514 &addr_obj, &length_obj))
515 return NULL;
516
b86af38a
TT
517 if (get_addr_from_python (addr_obj, &addr) < 0
518 || get_addr_from_python (length_obj, &length) < 0)
519 return NULL;
520
492d29ea 521 TRY
595939de 522 {
7c543f7b 523 buffer = (gdb_byte *) xmalloc (length);
595939de
PM
524
525 read_memory (addr, buffer, length);
526 }
492d29ea 527 CATCH (except, RETURN_MASK_ALL)
595939de 528 {
cc0265cd 529 xfree (buffer);
595939de
PM
530 GDB_PY_HANDLE_EXCEPTION (except);
531 }
492d29ea 532 END_CATCH
595939de 533
595939de
PM
534 membuf_obj = PyObject_New (membuf_object, &membuf_object_type);
535 if (membuf_obj == NULL)
536 {
cc0265cd 537 xfree (buffer);
595939de
PM
538 return NULL;
539 }
540
595939de
PM
541 membuf_obj->buffer = buffer;
542 membuf_obj->addr = addr;
543 membuf_obj->length = length;
544
9a27f2c6
PK
545#ifdef IS_PY3K
546 result = PyMemoryView_FromObject ((PyObject *) membuf_obj);
547#else
cc0265cd
TT
548 result = PyBuffer_FromReadWriteObject ((PyObject *) membuf_obj, 0,
549 Py_END_OF_BUFFER);
9a27f2c6 550#endif
cc0265cd 551 Py_DECREF (membuf_obj);
9a27f2c6 552
cc0265cd 553 return result;
595939de
PM
554}
555
2678e2af 556/* Implementation of Inferior.write_memory (address, buffer [, length]).
595939de
PM
557 Writes the contents of BUFFER (a Python object supporting the read
558 buffer protocol) at ADDRESS in the inferior's memory. Write LENGTH
559 bytes from BUFFER, or its entire contents if the argument is not
8dc78533
JK
560 provided. The function returns nothing. Returns NULL on error, with
561 a python exception set. */
595939de
PM
562static PyObject *
563infpy_write_memory (PyObject *self, PyObject *args, PyObject *kw)
564{
492d29ea 565 struct gdb_exception except = exception_none;
ddd49eee 566 Py_ssize_t buf_len;
7c543f7b 567 const gdb_byte *buffer;
595939de
PM
568 CORE_ADDR addr, length;
569 PyObject *addr_obj, *length_obj = NULL;
595939de 570 static char *keywords[] = { "address", "buffer", "length", NULL };
9a27f2c6
PK
571#ifdef IS_PY3K
572 Py_buffer pybuf;
595939de 573
9a27f2c6
PK
574 if (! PyArg_ParseTupleAndKeywords (args, kw, "Os*|O", keywords,
575 &addr_obj, &pybuf,
576 &length_obj))
577 return NULL;
595939de 578
7c543f7b 579 buffer = (const gdb_byte *) pybuf.buf;
9a27f2c6
PK
580 buf_len = pybuf.len;
581#else
595939de
PM
582 if (! PyArg_ParseTupleAndKeywords (args, kw, "Os#|O", keywords,
583 &addr_obj, &buffer, &buf_len,
584 &length_obj))
585 return NULL;
7c543f7b
SM
586
587 buffer = (const gdb_byte *) buffer;
9a27f2c6 588#endif
595939de 589
b86af38a
TT
590 if (get_addr_from_python (addr_obj, &addr) < 0)
591 goto fail;
592
593 if (!length_obj)
594 length = buf_len;
595 else if (get_addr_from_python (length_obj, &length) < 0)
596 goto fail;
597
492d29ea 598 TRY
595939de 599 {
7c543f7b 600 write_memory_with_notification (addr, buffer, length);
595939de 601 }
492d29ea
PA
602 CATCH (ex, RETURN_MASK_ALL)
603 {
604 except = ex;
605 }
606 END_CATCH
607
9a27f2c6
PK
608#ifdef IS_PY3K
609 PyBuffer_Release (&pybuf);
610#endif
595939de
PM
611 GDB_PY_HANDLE_EXCEPTION (except);
612
595939de 613 Py_RETURN_NONE;
b86af38a
TT
614
615 fail:
616#ifdef IS_PY3K
617 PyBuffer_Release (&pybuf);
618#endif
619 return NULL;
595939de
PM
620}
621
622/* Destructor of Membuf objects. */
623static void
624mbpy_dealloc (PyObject *self)
625{
626 xfree (((membuf_object *) self)->buffer);
9a27f2c6 627 Py_TYPE (self)->tp_free (self);
595939de
PM
628}
629
630/* Return a description of the Membuf object. */
631static PyObject *
632mbpy_str (PyObject *self)
633{
634 membuf_object *membuf_obj = (membuf_object *) self;
635
636 return PyString_FromFormat (_("Memory buffer for address %s, \
637which is %s bytes long."),
638 paddress (python_gdbarch, membuf_obj->addr),
639 pulongest (membuf_obj->length));
640}
641
9a27f2c6
PK
642#ifdef IS_PY3K
643
644static int
645get_buffer (PyObject *self, Py_buffer *buf, int flags)
646{
647 membuf_object *membuf_obj = (membuf_object *) self;
648 int ret;
256458bc 649
9a27f2c6 650 ret = PyBuffer_FillInfo (buf, self, membuf_obj->buffer,
256458bc 651 membuf_obj->length, 0,
9a27f2c6
PK
652 PyBUF_CONTIG);
653 buf->format = "c";
654
655 return ret;
656}
657
658#else
659
595939de
PM
660static Py_ssize_t
661get_read_buffer (PyObject *self, Py_ssize_t segment, void **ptrptr)
662{
663 membuf_object *membuf_obj = (membuf_object *) self;
664
665 if (segment)
666 {
667 PyErr_SetString (PyExc_SystemError,
668 _("The memory buffer supports only one segment."));
669 return -1;
670 }
671
672 *ptrptr = membuf_obj->buffer;
673
674 return membuf_obj->length;
675}
676
677static Py_ssize_t
678get_write_buffer (PyObject *self, Py_ssize_t segment, void **ptrptr)
679{
680 return get_read_buffer (self, segment, ptrptr);
681}
682
683static Py_ssize_t
684get_seg_count (PyObject *self, Py_ssize_t *lenp)
685{
686 if (lenp)
687 *lenp = ((membuf_object *) self)->length;
688
689 return 1;
690}
691
692static Py_ssize_t
693get_char_buffer (PyObject *self, Py_ssize_t segment, char **ptrptr)
694{
695 void *ptr = NULL;
696 Py_ssize_t ret;
697
698 ret = get_read_buffer (self, segment, &ptr);
699 *ptrptr = (char *) ptr;
700
701 return ret;
702}
703
9a27f2c6
PK
704#endif /* IS_PY3K */
705
595939de
PM
706/* Implementation of
707 gdb.search_memory (address, length, pattern). ADDRESS is the
708 address to start the search. LENGTH specifies the scope of the
709 search from ADDRESS. PATTERN is the pattern to search for (and
710 must be a Python object supporting the buffer protocol).
711 Returns a Python Long object holding the address where the pattern
8dc78533
JK
712 was located, or if the pattern was not found, returns None. Returns NULL
713 on error, with a python exception set. */
595939de
PM
714static PyObject *
715infpy_search_memory (PyObject *self, PyObject *args, PyObject *kw)
716{
492d29ea 717 struct gdb_exception except = exception_none;
595939de
PM
718 CORE_ADDR start_addr, length;
719 static char *keywords[] = { "address", "length", "pattern", NULL };
9a27f2c6 720 PyObject *start_addr_obj, *length_obj;
595939de 721 Py_ssize_t pattern_size;
7c543f7b 722 const gdb_byte *buffer;
595939de
PM
723 CORE_ADDR found_addr;
724 int found = 0;
9a27f2c6
PK
725#ifdef IS_PY3K
726 Py_buffer pybuf;
595939de 727
9a27f2c6 728 if (! PyArg_ParseTupleAndKeywords (args, kw, "OOs*", keywords,
595939de 729 &start_addr_obj, &length_obj,
9a27f2c6
PK
730 &pybuf))
731 return NULL;
732
7c543f7b 733 buffer = (const gdb_byte *) pybuf.buf;
9a27f2c6
PK
734 pattern_size = pybuf.len;
735#else
736 PyObject *pattern;
7c543f7b 737 const void *vbuffer;
256458bc 738
9a27f2c6
PK
739 if (! PyArg_ParseTupleAndKeywords (args, kw, "OOO", keywords,
740 &start_addr_obj, &length_obj,
595939de 741 &pattern))
9a27f2c6
PK
742 return NULL;
743
744 if (!PyObject_CheckReadBuffer (pattern))
745 {
746 PyErr_SetString (PyExc_RuntimeError,
747 _("The pattern is not a Python buffer."));
748
749 return NULL;
750 }
751
7c543f7b 752 if (PyObject_AsReadBuffer (pattern, &vbuffer, &pattern_size) == -1)
595939de 753 return NULL;
7c543f7b
SM
754
755 buffer = (const gdb_byte *) vbuffer;
9a27f2c6 756#endif
595939de 757
b86af38a
TT
758 if (get_addr_from_python (start_addr_obj, &start_addr) < 0)
759 goto fail;
256458bc 760
b86af38a
TT
761 if (get_addr_from_python (length_obj, &length) < 0)
762 goto fail;
9a27f2c6 763
b86af38a
TT
764 if (!length)
765 {
766 PyErr_SetString (PyExc_ValueError,
767 _("Search range is empty."));
768 goto fail;
769 }
770 /* Watch for overflows. */
771 else if (length > CORE_ADDR_MAX
772 || (start_addr + length - 1) < start_addr)
773 {
774 PyErr_SetString (PyExc_ValueError,
775 _("The search range is too large."));
776 goto fail;
595939de 777 }
595939de 778
492d29ea 779 TRY
595939de
PM
780 {
781 found = target_search_memory (start_addr, length,
782 buffer, pattern_size,
783 &found_addr);
784 }
492d29ea
PA
785 CATCH (ex, RETURN_MASK_ALL)
786 {
787 except = ex;
788 }
789 END_CATCH
790
9a27f2c6
PK
791#ifdef IS_PY3K
792 PyBuffer_Release (&pybuf);
793#endif
b86af38a 794 GDB_PY_HANDLE_EXCEPTION (except);
9a27f2c6 795
595939de
PM
796 if (found)
797 return PyLong_FromLong (found_addr);
798 else
799 Py_RETURN_NONE;
b86af38a
TT
800
801 fail:
802#ifdef IS_PY3K
803 PyBuffer_Release (&pybuf);
804#endif
805 return NULL;
595939de
PM
806}
807
29703da4
PM
808/* Implementation of gdb.Inferior.is_valid (self) -> Boolean.
809 Returns True if this inferior object still exists in GDB. */
810
811static PyObject *
812infpy_is_valid (PyObject *self, PyObject *args)
813{
814 inferior_object *inf = (inferior_object *) self;
815
816 if (! inf->inferior)
817 Py_RETURN_FALSE;
818
819 Py_RETURN_TRUE;
820}
821
754eadd1
PM
822static void
823infpy_dealloc (PyObject *obj)
824{
825 inferior_object *inf_obj = (inferior_object *) obj;
826 struct inferior *inf = inf_obj->inferior;
827
828 if (! inf)
829 return;
830
831 set_inferior_data (inf, infpy_inf_data_key, NULL);
832}
595939de
PM
833
834/* Clear the INFERIOR pointer in an Inferior object and clear the
835 thread list. */
836static void
837py_free_inferior (struct inferior *inf, void *datum)
838{
839
840 struct cleanup *cleanup;
19ba03f4 841 inferior_object *inf_obj = (inferior_object *) datum;
595939de
PM
842 struct threadlist_entry *th_entry, *th_tmp;
843
0646da15
TT
844 if (!gdb_python_initialized)
845 return;
846
595939de
PM
847 cleanup = ensure_python_env (python_gdbarch, python_language);
848
849 inf_obj->inferior = NULL;
850
851 /* Deallocate threads list. */
852 for (th_entry = inf_obj->threads; th_entry != NULL;)
853 {
854 Py_DECREF (th_entry->thread_obj);
855
856 th_tmp = th_entry;
857 th_entry = th_entry->next;
858 xfree (th_tmp);
859 }
860
861 inf_obj->nthreads = 0;
862
863 Py_DECREF ((PyObject *) inf_obj);
864 do_cleanups (cleanup);
865}
866
2aa48337
KP
867/* Implementation of gdb.selected_inferior() -> gdb.Inferior.
868 Returns the current inferior object. */
869
870PyObject *
871gdbpy_selected_inferior (PyObject *self, PyObject *args)
872{
2d57700b 873 return inferior_to_inferior_object (current_inferior ());
2aa48337
KP
874}
875
999633ed 876int
595939de
PM
877gdbpy_initialize_inferior (void)
878{
879 if (PyType_Ready (&inferior_object_type) < 0)
999633ed 880 return -1;
595939de 881
aa36459a
TT
882 if (gdb_pymodule_addobject (gdb_module, "Inferior",
883 (PyObject *) &inferior_object_type) < 0)
999633ed 884 return -1;
595939de
PM
885
886 infpy_inf_data_key =
8e260fc0 887 register_inferior_data_with_cleanup (NULL, py_free_inferior);
595939de
PM
888
889 observer_attach_new_thread (add_thread_object);
890 observer_attach_thread_exit (delete_thread_object);
505500db
SW
891 observer_attach_normal_stop (python_on_normal_stop);
892 observer_attach_target_resumed (python_on_resume);
162078c8
NB
893 observer_attach_inferior_call_pre (python_on_inferior_call_pre);
894 observer_attach_inferior_call_post (python_on_inferior_call_post);
895 observer_attach_memory_changed (python_on_memory_change);
896 observer_attach_register_changed (python_on_register_change);
505500db 897 observer_attach_inferior_exit (python_inferior_exit);
20c168b5 898 observer_attach_new_objfile (python_new_objfile);
595939de 899
6a1b1664 900 membuf_object_type.tp_new = PyType_GenericNew;
595939de 901 if (PyType_Ready (&membuf_object_type) < 0)
999633ed 902 return -1;
595939de 903
aa36459a
TT
904 return gdb_pymodule_addobject (gdb_module, "Membuf", (PyObject *)
905 &membuf_object_type);
595939de
PM
906}
907
908static PyGetSetDef inferior_object_getset[] =
909{
910 { "num", infpy_get_num, NULL, "ID of inferior, as assigned by GDB.", NULL },
911 { "pid", infpy_get_pid, NULL, "PID of inferior, as assigned by the OS.",
912 NULL },
913 { "was_attached", infpy_get_was_attached, NULL,
914 "True if the inferior was created using 'attach'.", NULL },
915 { NULL }
916};
917
918static PyMethodDef inferior_object_methods[] =
919{
29703da4
PM
920 { "is_valid", infpy_is_valid, METH_NOARGS,
921 "is_valid () -> Boolean.\n\
922Return true if this inferior is valid, false if not." },
595939de
PM
923 { "threads", infpy_threads, METH_NOARGS,
924 "Return all the threads of this inferior." },
925 { "read_memory", (PyCFunction) infpy_read_memory,
926 METH_VARARGS | METH_KEYWORDS,
927 "read_memory (address, length) -> buffer\n\
928Return a buffer object for reading from the inferior's memory." },
929 { "write_memory", (PyCFunction) infpy_write_memory,
930 METH_VARARGS | METH_KEYWORDS,
931 "write_memory (address, buffer [, length])\n\
932Write the given buffer object to the inferior's memory." },
933 { "search_memory", (PyCFunction) infpy_search_memory,
934 METH_VARARGS | METH_KEYWORDS,
935 "search_memory (address, length, pattern) -> long\n\
936Return a long with the address of a match, or None." },
937 { NULL }
938};
939
e36122e9 940PyTypeObject inferior_object_type =
595939de 941{
9a27f2c6 942 PyVarObject_HEAD_INIT (NULL, 0)
595939de
PM
943 "gdb.Inferior", /* tp_name */
944 sizeof (inferior_object), /* tp_basicsize */
945 0, /* tp_itemsize */
754eadd1 946 infpy_dealloc, /* tp_dealloc */
595939de
PM
947 0, /* tp_print */
948 0, /* tp_getattr */
949 0, /* tp_setattr */
950 0, /* tp_compare */
951 0, /* tp_repr */
952 0, /* tp_as_number */
953 0, /* tp_as_sequence */
954 0, /* tp_as_mapping */
955 0, /* tp_hash */
956 0, /* tp_call */
957 0, /* tp_str */
958 0, /* tp_getattro */
959 0, /* tp_setattro */
960 0, /* tp_as_buffer */
961 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_ITER, /* tp_flags */
962 "GDB inferior object", /* tp_doc */
963 0, /* tp_traverse */
964 0, /* tp_clear */
965 0, /* tp_richcompare */
966 0, /* tp_weaklistoffset */
967 0, /* tp_iter */
968 0, /* tp_iternext */
969 inferior_object_methods, /* tp_methods */
970 0, /* tp_members */
971 inferior_object_getset, /* tp_getset */
972 0, /* tp_base */
973 0, /* tp_dict */
974 0, /* tp_descr_get */
975 0, /* tp_descr_set */
976 0, /* tp_dictoffset */
977 0, /* tp_init */
978 0 /* tp_alloc */
979};
980
9a27f2c6
PK
981#ifdef IS_PY3K
982
983static PyBufferProcs buffer_procs =
984{
985 get_buffer
986};
987
988#else
989
595939de
PM
990/* Python doesn't provide a decent way to get compatibility here. */
991#if HAVE_LIBPYTHON2_4
992#define CHARBUFFERPROC_NAME getcharbufferproc
993#else
994#define CHARBUFFERPROC_NAME charbufferproc
995#endif
996
997static PyBufferProcs buffer_procs = {
998 get_read_buffer,
999 get_write_buffer,
1000 get_seg_count,
1001 /* The cast here works around a difference between Python 2.4 and
1002 Python 2.5. */
1003 (CHARBUFFERPROC_NAME) get_char_buffer
1004};
9a27f2c6 1005#endif /* IS_PY3K */
595939de 1006
e36122e9 1007PyTypeObject membuf_object_type = {
9a27f2c6 1008 PyVarObject_HEAD_INIT (NULL, 0)
595939de
PM
1009 "gdb.Membuf", /*tp_name*/
1010 sizeof (membuf_object), /*tp_basicsize*/
1011 0, /*tp_itemsize*/
1012 mbpy_dealloc, /*tp_dealloc*/
1013 0, /*tp_print*/
1014 0, /*tp_getattr*/
1015 0, /*tp_setattr*/
1016 0, /*tp_compare*/
1017 0, /*tp_repr*/
1018 0, /*tp_as_number*/
1019 0, /*tp_as_sequence*/
1020 0, /*tp_as_mapping*/
1021 0, /*tp_hash */
1022 0, /*tp_call*/
1023 mbpy_str, /*tp_str*/
1024 0, /*tp_getattro*/
1025 0, /*tp_setattro*/
1026 &buffer_procs, /*tp_as_buffer*/
1027 Py_TPFLAGS_DEFAULT, /*tp_flags*/
1028 "GDB memory buffer object", /*tp_doc*/
1029 0, /* tp_traverse */
1030 0, /* tp_clear */
1031 0, /* tp_richcompare */
1032 0, /* tp_weaklistoffset */
1033 0, /* tp_iter */
1034 0, /* tp_iternext */
1035 0, /* tp_methods */
1036 0, /* tp_members */
1037 0, /* tp_getset */
1038 0, /* tp_base */
1039 0, /* tp_dict */
1040 0, /* tp_descr_get */
1041 0, /* tp_descr_set */
1042 0, /* tp_dictoffset */
1043 0, /* tp_init */
1044 0, /* tp_alloc */
595939de 1045};
This page took 0.651571 seconds and 4 git commands to generate.