statetrace.cc revision 4245
15081Sgblack@eecs.umich.edu/*
25081Sgblack@eecs.umich.edu * Copyright (c) 2006-2007 The Regents of The University of Michigan
35081Sgblack@eecs.umich.edu * All rights reserved.
47087Snate@binkert.org *
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;
125081Sgblack@eecs.umich.edu * neither the name of the copyright holders nor the names of its
137087Snate@binkert.org * 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,
215081Sgblack@eecs.umich.edu * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
227087Snate@binkert.org * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
235081Sgblack@eecs.umich.edu * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
245081Sgblack@eecs.umich.edu * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
255081Sgblack@eecs.umich.edu * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
265081Sgblack@eecs.umich.edu * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
275081Sgblack@eecs.umich.edu *
285081Sgblack@eecs.umich.edu * Authors: Gabe Black
295081Sgblack@eecs.umich.edu */
305081Sgblack@eecs.umich.edu
315081Sgblack@eecs.umich.edu#include <iostream>
325081Sgblack@eecs.umich.edu#include <fstream>
335081Sgblack@eecs.umich.edu#include <string>
345081Sgblack@eecs.umich.edu#include <sys/types.h>
355081Sgblack@eecs.umich.edu#include <sys/wait.h>
365081Sgblack@eecs.umich.edu#include <sys/ptrace.h>
375081Sgblack@eecs.umich.edu#include <unistd.h>
385081Sgblack@eecs.umich.edu#include <stdio.h>
396563Sgblack@eecs.umich.edu#include <sys/types.h>
406563Sgblack@eecs.umich.edu#include <sys/socket.h>
416563Sgblack@eecs.umich.edu#include <netinet/in.h>
426563Sgblack@eecs.umich.edu#include <netdb.h>
436563Sgblack@eecs.umich.edu#include <errno.h>
446563Sgblack@eecs.umich.edu
456563Sgblack@eecs.umich.edu#include "printer.hh"
466563Sgblack@eecs.umich.edu#include "tracechild.hh"
476563Sgblack@eecs.umich.edu
486563Sgblack@eecs.umich.eduusing namespace std;
496563Sgblack@eecs.umich.edu
506563Sgblack@eecs.umich.eduvoid printUsage(const char * execName)
516563Sgblack@eecs.umich.edu{
526563Sgblack@eecs.umich.edu        cout << execName << " -h | -r -- <command> <arguments>" << endl;
536563Sgblack@eecs.umich.edu}
546563Sgblack@eecs.umich.edu
556563Sgblack@eecs.umich.eduint main(int argc, char * argv[], char * envp[])
566563Sgblack@eecs.umich.edu{
576563Sgblack@eecs.umich.edu        TraceChild * child = genTraceChild();
586563Sgblack@eecs.umich.edu        string args;
596563Sgblack@eecs.umich.edu        int startProgramArgs;
606563Sgblack@eecs.umich.edu
616563Sgblack@eecs.umich.edu        //Parse the command line arguments
626563Sgblack@eecs.umich.edu        bool printInitial = false;
636563Sgblack@eecs.umich.edu        bool printTrace = true;
646563Sgblack@eecs.umich.edu        for(int x = 1; x < argc; x++)
656563Sgblack@eecs.umich.edu        {
666563Sgblack@eecs.umich.edu                if(!strcmp(argv[x], "-h"))
676563Sgblack@eecs.umich.edu                {
686563Sgblack@eecs.umich.edu                        printUsage(argv[0]);
696563Sgblack@eecs.umich.edu                        return 0;
706563Sgblack@eecs.umich.edu                }
715081Sgblack@eecs.umich.edu                else if(!strcmp(argv[x], "-r"))
72                {
73                    cout << "Legal register names:" << endl;
74                    int numRegs = child->getNumRegs();
75                    for(unsigned int x = 0; x < numRegs; x++)
76                    {
77                            cout << "\t" << child->getRegName(x) << endl;
78                    }
79                    return 0;
80                }
81                else if(!strcmp(argv[x], "-i"))
82                {
83                    printInitial = true;
84                }
85                else if(!strcmp(argv[x], "-nt"))
86                {
87                    printTrace = false;
88                }
89                else if(!strcmp(argv[x], "--"))
90                {
91                        x++;
92                        if(x >= argc)
93                        {
94                                cerr << "Incorrect usage.\n" << endl;
95                                printUsage(argv[0]);
96                                return 1;
97                        }
98                        startProgramArgs = x;
99                        break;
100                }
101                else
102                {
103                        cerr << "Incorrect usage.\n" << endl;
104                        printUsage(argv[0]);
105                        return 1;
106                }
107        }
108        if(!child->startTracing(argv[startProgramArgs],
109                    argv + startProgramArgs))
110        {
111                cerr << "Couldn't start target program" << endl;
112                return 1;
113        }
114        if(printInitial)
115        {
116            child->outputStartState(cout);
117        }
118        if(printTrace)
119        {
120            // Connect to m5
121            bool portSet = false;
122            int port;
123            int sock = socket(AF_INET, SOCK_STREAM, 0);
124            if(sock < 0)
125            {
126                cerr << "Error opening socket! " << strerror(errno) << endl;
127                return 1;
128            }
129            struct hostent *server;
130            server = gethostbyname("zower.eecs.umich.edu");
131            if(!server)
132            {
133                cerr << "Couldn't get host ip! " << strerror(errno) << endl;
134                return 1;
135            }
136            struct sockaddr_in serv_addr;
137            bzero((char *)&serv_addr, sizeof(serv_addr));
138            serv_addr.sin_family = AF_INET;
139            bcopy((char *)server->h_addr,
140                    (char *)&serv_addr.sin_addr.s_addr,
141                    server->h_length);
142            serv_addr.sin_port = htons(8000);
143            if(connect(sock, (sockaddr *)&serv_addr, sizeof(serv_addr)) < 0)
144            {
145                cerr << "Couldn't connect to server! " << strerror(errno) << endl;
146                return 1;
147            }
148            child->step();
149            while(child->isTracing())
150            {
151                    if(!child->sendState(sock))
152                        break;
153                    child->step();
154            }
155        }
156        if(!child->stopTracing())
157        {
158                cerr << "Couldn't stop child" << endl;
159                return 1;
160        }
161        return 0;
162}
163
164