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