tracechild.hh revision 8118
15647Sgblack@eecs.umich.edu/*
25647Sgblack@eecs.umich.edu * Copyright (c) 2006 The Regents of The University of Michigan
35647Sgblack@eecs.umich.edu * All rights reserved.
45647Sgblack@eecs.umich.edu *
57087Snate@binkert.org * Redistribution and use in source and binary forms, with or without
67087Snate@binkert.org * modification, are permitted provided that the following conditions are
77087Snate@binkert.org * met: redistributions of source code must retain the above copyright
87087Snate@binkert.org * notice, this list of conditions and the following disclaimer;
97087Snate@binkert.org * redistributions in binary form must reproduce the above copyright
107087Snate@binkert.org * notice, this list of conditions and the following disclaimer in the
117087Snate@binkert.org * documentation and/or other materials provided with the distribution;
127087Snate@binkert.org * neither the name of the copyright holders nor the names of its
135647Sgblack@eecs.umich.edu * contributors may be used to endorse or promote products derived from
147087Snate@binkert.org * this software without specific prior written permission.
157087Snate@binkert.org *
167087Snate@binkert.org * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
177087Snate@binkert.org * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
187087Snate@binkert.org * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
197087Snate@binkert.org * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
207087Snate@binkert.org * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
217087Snate@binkert.org * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
225647Sgblack@eecs.umich.edu * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
237087Snate@binkert.org * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
245647Sgblack@eecs.umich.edu * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
255647Sgblack@eecs.umich.edu * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
265647Sgblack@eecs.umich.edu * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
275647Sgblack@eecs.umich.edu *
285647Sgblack@eecs.umich.edu * Authors: Gabe Black
295647Sgblack@eecs.umich.edu */
305647Sgblack@eecs.umich.edu
315647Sgblack@eecs.umich.edu#ifndef REGSTATE_I686_HH
325647Sgblack@eecs.umich.edu#define REGSTATE_I686_HH
335647Sgblack@eecs.umich.edu
345647Sgblack@eecs.umich.edu#include <sys/user.h>
355647Sgblack@eecs.umich.edu#include <sys/types.h>
365647Sgblack@eecs.umich.edu#include <sys/ptrace.h>
375647Sgblack@eecs.umich.edu#include <cassert>
385647Sgblack@eecs.umich.edu#include <string>
395647Sgblack@eecs.umich.edu
405647Sgblack@eecs.umich.edu#include "base/tracechild.hh"
415654Sgblack@eecs.umich.edu
427629Sgblack@eecs.umich.educlass I686TraceChild : public TraceChild
435647Sgblack@eecs.umich.edu{
446137Sgblack@eecs.umich.edu  public:
456137Sgblack@eecs.umich.edu    enum RegNum
466137Sgblack@eecs.umich.edu    {
475654Sgblack@eecs.umich.edu        //GPRs
486046Sgblack@eecs.umich.edu        EAX, EBX, ECX, EDX,
495647Sgblack@eecs.umich.edu        //Index registers
505648Sgblack@eecs.umich.edu        ESI, EDI,
515648Sgblack@eecs.umich.edu        //Base pointer and stack pointer
525647Sgblack@eecs.umich.edu        EBP, ESP,
535647Sgblack@eecs.umich.edu        //Segmentation registers
545647Sgblack@eecs.umich.edu        CS, DS, ES, FS, GS, SS,
555647Sgblack@eecs.umich.edu        //PC
565647Sgblack@eecs.umich.edu        EIP,
575647Sgblack@eecs.umich.edu        numregs
585647Sgblack@eecs.umich.edu    };
595647Sgblack@eecs.umich.edu  private:
605647Sgblack@eecs.umich.edu    int64_t getRegs(user_regs_struct & myregs, int num);
615648Sgblack@eecs.umich.edu    user_regs_struct regs;
625647Sgblack@eecs.umich.edu    user_regs_struct oldregs;
635648Sgblack@eecs.umich.edu    bool regDiffSinceUpdate[numregs];
645648Sgblack@eecs.umich.edu
655648Sgblack@eecs.umich.edu  protected:
665648Sgblack@eecs.umich.edu    bool update(int pid);
675648Sgblack@eecs.umich.edu
685648Sgblack@eecs.umich.edu  public:
695648Sgblack@eecs.umich.edu
705648Sgblack@eecs.umich.edu    I686TraceChild();
715648Sgblack@eecs.umich.edu
725648Sgblack@eecs.umich.edu    int64_t getRegVal(int num);
735648Sgblack@eecs.umich.edu    int64_t getOldRegVal(int num);
745648Sgblack@eecs.umich.edu    uint64_t getPC() {return getRegVal(EIP);}
755648Sgblack@eecs.umich.edu    uint64_t getSP() {return getRegVal(ESP);}
765648Sgblack@eecs.umich.edu    bool sendState(int socket);
775648Sgblack@eecs.umich.edu    std::ostream &
785648Sgblack@eecs.umich.edu    outputStartState(std::ostream & output)
795648Sgblack@eecs.umich.edu    {
805648Sgblack@eecs.umich.edu        output << "Printing i686 initial state not yet implemented"
815648Sgblack@eecs.umich.edu               << std::endl;
825648Sgblack@eecs.umich.edu        return output;
835648Sgblack@eecs.umich.edu    }
845648Sgblack@eecs.umich.edu};
855648Sgblack@eecs.umich.edu
865648Sgblack@eecs.umich.edu#endif
875648Sgblack@eecs.umich.edu