/* Copyright (C) 2021-2024 Free Software Foundation, Inc. Contributed by Oracle. This file is part of GNU Binutils. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef _CALLSTACK_H #define _CALLSTACK_H #include #include "dbe_structs.h" #include "Experiment.h" #include "DbeLock.h" class DataDescriptor; class FramePacket; class DbeInstr; class Histable; template class Vector; class CallStackNode; class Descendants /* : public DbeLock */ { public: Descendants (); ~Descendants (); CallStackNode *find (Histable *hi, int *index); void append (CallStackNode *item); void insert (int ind, CallStackNode *item); int volatile count; private: enum { DELTA = 8 }; int limit; CallStackNode **data; CallStackNode *first_data[4]; }; class CallStackNode : public Descendants { public: CallStackNode (CallStackNode *_ancestor, Histable *_instr); ~CallStackNode (); bool compare (long start, long end, Vector *objs, CallStackNode *mRoot); void dump (); CallStackNode * get_ancestor () { return ancestor; } Histable * get_instr () { return instr; } CallStackNode *alt_node; Histable *instr; CallStackNode *ancestor; }; class CallStack { public: static CallStack *getInstance (Experiment *exp); virtual ~CallStack () { }; virtual void add_stack (DataDescriptor *dDscr, long idx, FramePacket *frp, cstk_ctx_chunk* cstCtxChunk) = 0; // Creates a call stack representation for objs and // returns an opaque pointer to it virtual void *add_stack (Vector *objs) = 0; // Debugging methods virtual void print (FILE *) = 0; // Call stack inquiries static int stackSize (void *stack); static Histable *getStackPC (void *stack, int n); static Vector *getStackPCs (void *stack, bool get_hide_stack = false); static void setHideStack (void *stack, void *hideStack); static int compare (void *stack1, void *stack2); virtual CallStackNode * get_node (int) { return NULL; }; }; #endif /* _CALLSTACK_H */