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"
368232Snate@binkert.org#include "debug/Stack.hh"
374120Sgblack@eecs.umich.edu
384145Sgblack@eecs.umich.educlass ThreadContext;
394120Sgblack@eecs.umich.edunamespace X86ISA
404120Sgblack@eecs.umich.edu{
414145Sgblack@eecs.umich.edu    class StackTrace;
424145Sgblack@eecs.umich.edu
434145Sgblack@eecs.umich.edu    class ProcessInfo
444145Sgblack@eecs.umich.edu    {
454145Sgblack@eecs.umich.edu      private:
464145Sgblack@eecs.umich.edu        ThreadContext *tc;
474145Sgblack@eecs.umich.edu
484145Sgblack@eecs.umich.edu        int thread_info_size;
494145Sgblack@eecs.umich.edu        int task_struct_size;
504145Sgblack@eecs.umich.edu        int task_off;
514145Sgblack@eecs.umich.edu        int pid_off;
524145Sgblack@eecs.umich.edu        int name_off;
534145Sgblack@eecs.umich.edu
544145Sgblack@eecs.umich.edu      public:
554145Sgblack@eecs.umich.edu        ProcessInfo(ThreadContext *_tc);
564145Sgblack@eecs.umich.edu
574145Sgblack@eecs.umich.edu        Addr task(Addr ksp) const;
584145Sgblack@eecs.umich.edu        int pid(Addr ksp) const;
594145Sgblack@eecs.umich.edu        std::string name(Addr ksp) const;
604145Sgblack@eecs.umich.edu    };
614145Sgblack@eecs.umich.edu
624145Sgblack@eecs.umich.edu    class StackTrace
634145Sgblack@eecs.umich.edu    {
644145Sgblack@eecs.umich.edu      private:
654145Sgblack@eecs.umich.edu        ThreadContext *tc;
664145Sgblack@eecs.umich.edu        std::vector<Addr> stack;
674145Sgblack@eecs.umich.edu
684145Sgblack@eecs.umich.edu      private:
694145Sgblack@eecs.umich.edu        bool isEntry(Addr addr);
704145Sgblack@eecs.umich.edu        bool decodePrologue(Addr sp, Addr callpc, Addr func, int &size, Addr &ra);
714145Sgblack@eecs.umich.edu        bool decodeSave(MachInst inst, int &reg, int &disp);
724145Sgblack@eecs.umich.edu        bool decodeStack(MachInst inst, int &disp);
734145Sgblack@eecs.umich.edu
744145Sgblack@eecs.umich.edu        void trace(ThreadContext *tc, bool is_call);
754145Sgblack@eecs.umich.edu
764145Sgblack@eecs.umich.edu      public:
774145Sgblack@eecs.umich.edu        StackTrace();
7810417Sandreas.hansson@arm.com        StackTrace(ThreadContext *tc, const StaticInstPtr &inst);
794145Sgblack@eecs.umich.edu        ~StackTrace();
804145Sgblack@eecs.umich.edu
814145Sgblack@eecs.umich.edu        void clear()
824145Sgblack@eecs.umich.edu        {
834145Sgblack@eecs.umich.edu            tc = 0;
844145Sgblack@eecs.umich.edu            stack.clear();
854145Sgblack@eecs.umich.edu        }
864145Sgblack@eecs.umich.edu
874145Sgblack@eecs.umich.edu        bool valid() const { return tc != NULL; }
8810417Sandreas.hansson@arm.com        bool trace(ThreadContext *tc, const StaticInstPtr &inst);
894145Sgblack@eecs.umich.edu
904145Sgblack@eecs.umich.edu      public:
914145Sgblack@eecs.umich.edu        const std::vector<Addr> &getstack() const { return stack; }
924145Sgblack@eecs.umich.edu
934145Sgblack@eecs.umich.edu        static const int user = 1;
944145Sgblack@eecs.umich.edu        static const int console = 2;
954145Sgblack@eecs.umich.edu        static const int unknown = 3;
964145Sgblack@eecs.umich.edu
974145Sgblack@eecs.umich.edu#if TRACING_ON
984145Sgblack@eecs.umich.edu      private:
994145Sgblack@eecs.umich.edu        void dump();
1004145Sgblack@eecs.umich.edu
1014145Sgblack@eecs.umich.edu      public:
1024145Sgblack@eecs.umich.edu        void dprintf() { if (DTRACE(Stack)) dump(); }
1034145Sgblack@eecs.umich.edu#else
1044145Sgblack@eecs.umich.edu      public:
1054145Sgblack@eecs.umich.edu        void dprintf() {}
1064145Sgblack@eecs.umich.edu#endif
1074145Sgblack@eecs.umich.edu    };
1084145Sgblack@eecs.umich.edu
1094145Sgblack@eecs.umich.edu    inline bool
11010417Sandreas.hansson@arm.com    StackTrace::trace(ThreadContext *tc, const StaticInstPtr &inst)
1114145Sgblack@eecs.umich.edu    {
1124145Sgblack@eecs.umich.edu        if (!inst->isCall() && !inst->isReturn())
1134145Sgblack@eecs.umich.edu            return false;
1144145Sgblack@eecs.umich.edu
1154145Sgblack@eecs.umich.edu        if (valid())
1164145Sgblack@eecs.umich.edu            clear();
1174145Sgblack@eecs.umich.edu
1184145Sgblack@eecs.umich.edu        trace(tc, !inst->isReturn());
1194145Sgblack@eecs.umich.edu        return true;
1204145Sgblack@eecs.umich.edu    }
1214145Sgblack@eecs.umich.edu}
1224120Sgblack@eecs.umich.edu
1234120Sgblack@eecs.umich.edu#endif // __ARCH_X86_STACKTRACE_HH__
124