stacktrace.hh revision 4145
14120Sgblack@eecs.umich.edu/*
24120Sgblack@eecs.umich.edu * Copyright (c) 2006 The Regents of The University of Michigan
34120Sgblack@eecs.umich.edu * All rights reserved.
44120Sgblack@eecs.umich.edu *
54120Sgblack@eecs.umich.edu * Redistribution and use in source and binary forms, with or without
64120Sgblack@eecs.umich.edu * modification, are permitted provided that the following conditions are
74120Sgblack@eecs.umich.edu * met: redistributions of source code must retain the above copyright
84120Sgblack@eecs.umich.edu * notice, this list of conditions and the following disclaimer;
94120Sgblack@eecs.umich.edu * redistributions in binary form must reproduce the above copyright
104120Sgblack@eecs.umich.edu * notice, this list of conditions and the following disclaimer in the
114120Sgblack@eecs.umich.edu * documentation and/or other materials provided with the distribution;
124120Sgblack@eecs.umich.edu * neither the name of the copyright holders nor the names of its
134120Sgblack@eecs.umich.edu * contributors may be used to endorse or promote products derived from
144120Sgblack@eecs.umich.edu * this software without specific prior written permission.
154120Sgblack@eecs.umich.edu *
164120Sgblack@eecs.umich.edu * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
174120Sgblack@eecs.umich.edu * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
184120Sgblack@eecs.umich.edu * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
194120Sgblack@eecs.umich.edu * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
204120Sgblack@eecs.umich.edu * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
214120Sgblack@eecs.umich.edu * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
224120Sgblack@eecs.umich.edu * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
234120Sgblack@eecs.umich.edu * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
244120Sgblack@eecs.umich.edu * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
254120Sgblack@eecs.umich.edu * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
264120Sgblack@eecs.umich.edu * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
274120Sgblack@eecs.umich.edu *
284120Sgblack@eecs.umich.edu * Authors: Nathan Binkert
294120Sgblack@eecs.umich.edu */
304120Sgblack@eecs.umich.edu
314120Sgblack@eecs.umich.edu#ifndef __ARCH_X86_STACKTRACE_HH__
324120Sgblack@eecs.umich.edu#define __ARCH_X86_STACKTRACE_HH__
334120Sgblack@eecs.umich.edu
344145Sgblack@eecs.umich.edu#include "base/trace.hh"
354145Sgblack@eecs.umich.edu#include "cpu/static_inst.hh"
364120Sgblack@eecs.umich.edu
374145Sgblack@eecs.umich.educlass ThreadContext;
384120Sgblack@eecs.umich.edunamespace X86ISA
394120Sgblack@eecs.umich.edu{
404145Sgblack@eecs.umich.edu    class StackTrace;
414145Sgblack@eecs.umich.edu
424145Sgblack@eecs.umich.edu    class ProcessInfo
434145Sgblack@eecs.umich.edu    {
444145Sgblack@eecs.umich.edu      private:
454145Sgblack@eecs.umich.edu        ThreadContext *tc;
464145Sgblack@eecs.umich.edu
474145Sgblack@eecs.umich.edu        int thread_info_size;
484145Sgblack@eecs.umich.edu        int task_struct_size;
494145Sgblack@eecs.umich.edu        int task_off;
504145Sgblack@eecs.umich.edu        int pid_off;
514145Sgblack@eecs.umich.edu        int name_off;
524145Sgblack@eecs.umich.edu
534145Sgblack@eecs.umich.edu      public:
544145Sgblack@eecs.umich.edu        ProcessInfo(ThreadContext *_tc);
554145Sgblack@eecs.umich.edu
564145Sgblack@eecs.umich.edu        Addr task(Addr ksp) const;
574145Sgblack@eecs.umich.edu        int pid(Addr ksp) const;
584145Sgblack@eecs.umich.edu        std::string name(Addr ksp) const;
594145Sgblack@eecs.umich.edu    };
604145Sgblack@eecs.umich.edu
614145Sgblack@eecs.umich.edu    class StackTrace
624145Sgblack@eecs.umich.edu    {
634145Sgblack@eecs.umich.edu      private:
644145Sgblack@eecs.umich.edu        ThreadContext *tc;
654145Sgblack@eecs.umich.edu        std::vector<Addr> stack;
664145Sgblack@eecs.umich.edu
674145Sgblack@eecs.umich.edu      private:
684145Sgblack@eecs.umich.edu        bool isEntry(Addr addr);
694145Sgblack@eecs.umich.edu        bool decodePrologue(Addr sp, Addr callpc, Addr func, int &size, Addr &ra);
704145Sgblack@eecs.umich.edu        bool decodeSave(MachInst inst, int &reg, int &disp);
714145Sgblack@eecs.umich.edu        bool decodeStack(MachInst inst, int &disp);
724145Sgblack@eecs.umich.edu
734145Sgblack@eecs.umich.edu        void trace(ThreadContext *tc, bool is_call);
744145Sgblack@eecs.umich.edu
754145Sgblack@eecs.umich.edu      public:
764145Sgblack@eecs.umich.edu        StackTrace();
774145Sgblack@eecs.umich.edu        StackTrace(ThreadContext *tc, StaticInstPtr inst);
784145Sgblack@eecs.umich.edu        ~StackTrace();
794145Sgblack@eecs.umich.edu
804145Sgblack@eecs.umich.edu        void clear()
814145Sgblack@eecs.umich.edu        {
824145Sgblack@eecs.umich.edu            tc = 0;
834145Sgblack@eecs.umich.edu            stack.clear();
844145Sgblack@eecs.umich.edu        }
854145Sgblack@eecs.umich.edu
864145Sgblack@eecs.umich.edu        bool valid() const { return tc != NULL; }
874145Sgblack@eecs.umich.edu        bool trace(ThreadContext *tc, StaticInstPtr inst);
884145Sgblack@eecs.umich.edu
894145Sgblack@eecs.umich.edu      public:
904145Sgblack@eecs.umich.edu        const std::vector<Addr> &getstack() const { return stack; }
914145Sgblack@eecs.umich.edu
924145Sgblack@eecs.umich.edu        static const int user = 1;
934145Sgblack@eecs.umich.edu        static const int console = 2;
944145Sgblack@eecs.umich.edu        static const int unknown = 3;
954145Sgblack@eecs.umich.edu
964145Sgblack@eecs.umich.edu#if TRACING_ON
974145Sgblack@eecs.umich.edu      private:
984145Sgblack@eecs.umich.edu        void dump();
994145Sgblack@eecs.umich.edu
1004145Sgblack@eecs.umich.edu      public:
1014145Sgblack@eecs.umich.edu        void dprintf() { if (DTRACE(Stack)) dump(); }
1024145Sgblack@eecs.umich.edu#else
1034145Sgblack@eecs.umich.edu      public:
1044145Sgblack@eecs.umich.edu        void dprintf() {}
1054145Sgblack@eecs.umich.edu#endif
1064145Sgblack@eecs.umich.edu    };
1074145Sgblack@eecs.umich.edu
1084145Sgblack@eecs.umich.edu    inline bool
1094145Sgblack@eecs.umich.edu    StackTrace::trace(ThreadContext *tc, StaticInstPtr inst)
1104145Sgblack@eecs.umich.edu    {
1114145Sgblack@eecs.umich.edu        if (!inst->isCall() && !inst->isReturn())
1124145Sgblack@eecs.umich.edu            return false;
1134145Sgblack@eecs.umich.edu
1144145Sgblack@eecs.umich.edu        if (valid())
1154145Sgblack@eecs.umich.edu            clear();
1164145Sgblack@eecs.umich.edu
1174145Sgblack@eecs.umich.edu        trace(tc, !inst->isReturn());
1184145Sgblack@eecs.umich.edu        return true;
1194145Sgblack@eecs.umich.edu    }
1204145Sgblack@eecs.umich.edu}
1214120Sgblack@eecs.umich.edu
1224120Sgblack@eecs.umich.edu#endif // __ARCH_X86_STACKTRACE_HH__
123