Call dummy_frame_dtor_ftype also from remove_dummy_frame
[deliverable/binutils-gdb.git] / gdb / dummy-frame.h
CommitLineData
9c1412c1
AC
1/* Code dealing with dummy stack frames, for GDB, the GNU debugger.
2
32d0add0 3 Copyright (C) 2002-2015 Free Software Foundation, Inc.
9c1412c1
AC
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
a9762ec7 9 the Free Software Foundation; either version 3 of the License, or
9c1412c1
AC
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
a9762ec7 18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
9c1412c1
AC
19
20#if !defined (DUMMY_FRAME_H)
21#define DUMMY_FRAME_H 1
22
52163a60
DD
23#include "frame.h"
24
16c381f0 25struct infcall_suspend_state;
494cca16 26struct frame_unwind;
9c1412c1 27
96860204
AC
28/* Push the information needed to identify, and unwind from, a dummy
29 frame onto the dummy frame stack. */
30
96860204
AC
31/* NOTE: cagney/2004-08-02: In the case of ABIs using push_dummy_code
32 containing more than one instruction, this interface many need to
33 be expanded so that it knowns the lower/upper extent of the dummy
34 frame's code. */
35
16c381f0 36extern void dummy_frame_push (struct infcall_suspend_state *caller_state,
b67a2c6f 37 const struct frame_id *dummy_id, ptid_t ptid);
b89667eb
DE
38
39/* Pop the dummy frame DUMMY_ID, restoring program state to that before the
40 frame was created.
41 On return reinit_frame_cache has been called.
42 If the frame isn't found, flag an internal error.
43
44 NOTE: This can only pop the one frame, even if it is in the middle of the
45 stack, because the other frames may be for different threads, and there's
46 currently no way to tell which stack frame is for which thread. */
96860204 47
b67a2c6f 48extern void dummy_frame_pop (struct frame_id dummy_id, ptid_t ptid);
a45ae3ed 49
b67a2c6f 50extern void dummy_frame_discard (struct frame_id dummy_id, ptid_t ptid);
e2e4d78b 51
494cca16
AC
52/* If the PC falls in a dummy frame, return a dummy frame
53 unwinder. */
9c1412c1 54
39d7b0e2 55extern const struct frame_unwind dummy_frame_unwind;
c689142b 56
5e970501
JK
57/* Destructor for dummy_frame. DATA is supplied by registrant.
58 REGISTERS_VALID is 1 for dummy_frame_pop, 0 for dummy_frame_discard. */
59typedef void (dummy_frame_dtor_ftype) (void *data, int registers_valid);
558e5469 60
233a8fb3
JK
61/* Call DTOR with DTOR_DATA when DUMMY_ID frame of thread PTID gets discarded.
62 Dummy frame with DUMMY_ID must exist. There must be no other call of
63 register_dummy_frame_dtor for that dummy frame. */
233a8fb3
JK
64extern void register_dummy_frame_dtor (struct frame_id dummy_id, ptid_t ptid,
65 dummy_frame_dtor_ftype *dtor,
66 void *dtor_data);
67
68/* Return 1 if there exists dummy frame with registered DTOR and DTOR_DATA.
69 Return 0 otherwise. */
70extern int find_dummy_frame_dtor (dummy_frame_dtor_ftype *dtor,
71 void *dtor_data);
72
9c1412c1 73#endif /* !defined (DUMMY_FRAME_H) */
This page took 0.841114 seconds and 4 git commands to generate.