/***************************************************************************** * McPAT * SOFTWARE LICENSE AGREEMENT * Copyright 2012 Hewlett-Packard Development Company, L.P. * All Rights Reserved * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer; * redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution; * neither the name of the copyright holders nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.” * ***************************************************************************/ #include #include "XML_Parse.h" #include "globalvar.h" #include "io.h" #include "processor.h" #include "version.h" #include "xmlParser.h" using namespace std; void print_usage(char * argv0); int main(int argc,char *argv[]) { char * fb ; bool infile_specified = false; int plevel = 2; opt_for_clk =true; //cout.precision(10); if (argc <= 1 || argv[1] == string("-h") || argv[1] == string("--help")) { print_usage(argv[0]); } for (int32_t i = 0; i < argc; i++) { if (argv[i] == string("-infile")) { infile_specified = true; i++; fb = argv[ i]; } if (argv[i] == string("-print_level")) { i++; plevel = atoi(argv[i]); } if (argv[i] == string("-opt_for_clk")) { i++; opt_for_clk = (bool)atoi(argv[i]); } } if (infile_specified == false) { print_usage(argv[0]); } cout<<"McPAT (version "<< VER_MAJOR <<"."<< VER_MINOR << " of " << VER_UPDATE << ") is computing the target processor...\n "<parse(fb); Processor proc(p1); proc.displayEnergy(2, plevel); delete p1; return 0; } void print_usage(char * argv0) { cerr << "How to use McPAT:" << endl; cerr << " mcpat -infile -print_level < level of details 0~5 > -opt_for_clk < 0 (optimize for ED^2P only)/1 (optimzed for target clock rate)>"<< endl; //cerr << " Note:default print level is at processor level, please increase it to see the details" << endl; exit(1); }