113540Sandrea.mondelli@ucf.edu#!/usr/bin/env python2.7 210259SAndrew.Bardsley@arm.com# 310259SAndrew.Bardsley@arm.com# Copyright (c) 2013 ARM Limited 410259SAndrew.Bardsley@arm.com# All rights reserved 510259SAndrew.Bardsley@arm.com# 610259SAndrew.Bardsley@arm.com# The license below extends only to copyright in the software and shall 710259SAndrew.Bardsley@arm.com# not be construed as granting a license to any other intellectual 810259SAndrew.Bardsley@arm.com# property including but not limited to intellectual property relating 910259SAndrew.Bardsley@arm.com# to a hardware implementation of the functionality of the software 1010259SAndrew.Bardsley@arm.com# licensed hereunder. You may use the software subject to the license 1110259SAndrew.Bardsley@arm.com# terms below provided that you ensure that this notice is replicated 1210259SAndrew.Bardsley@arm.com# unmodified and in its entirety in all distributions of the software, 1310259SAndrew.Bardsley@arm.com# modified or unmodified, in source code or in binary form. 1410259SAndrew.Bardsley@arm.com# 1510259SAndrew.Bardsley@arm.com# Redistribution and use in source and binary forms, with or without 1610259SAndrew.Bardsley@arm.com# modification, are permitted provided that the following conditions are 1710259SAndrew.Bardsley@arm.com# met: redistributions of source code must retain the above copyright 1810259SAndrew.Bardsley@arm.com# notice, this list of conditions and the following disclaimer; 1910259SAndrew.Bardsley@arm.com# redistributions in binary form must reproduce the above copyright 2010259SAndrew.Bardsley@arm.com# notice, this list of conditions and the following disclaimer in the 2110259SAndrew.Bardsley@arm.com# documentation and/or other materials provided with the distribution; 2210259SAndrew.Bardsley@arm.com# neither the name of the copyright holders nor the names of its 2310259SAndrew.Bardsley@arm.com# contributors may be used to endorse or promote products derived from 2410259SAndrew.Bardsley@arm.com# this software without specific prior written permission. 2510259SAndrew.Bardsley@arm.com# 2610259SAndrew.Bardsley@arm.com# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 2710259SAndrew.Bardsley@arm.com# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 2810259SAndrew.Bardsley@arm.com# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 2910259SAndrew.Bardsley@arm.com# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 3010259SAndrew.Bardsley@arm.com# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 3110259SAndrew.Bardsley@arm.com# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 3210259SAndrew.Bardsley@arm.com# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 3310259SAndrew.Bardsley@arm.com# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 3410259SAndrew.Bardsley@arm.com# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 3510259SAndrew.Bardsley@arm.com# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 3610259SAndrew.Bardsley@arm.com# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 3710259SAndrew.Bardsley@arm.com# 3810259SAndrew.Bardsley@arm.com# Authors: Andrew Bardsley 3910259SAndrew.Bardsley@arm.com# 4010259SAndrew.Bardsley@arm.com# minorview.py: Minorview visuliser for MinorCPU model MinorTrace output 4110259SAndrew.Bardsley@arm.com# 4210259SAndrew.Bardsley@arm.com 4310259SAndrew.Bardsley@arm.comimport gtk 4410259SAndrew.Bardsley@arm.comimport os 4510259SAndrew.Bardsley@arm.comimport sys 4610259SAndrew.Bardsley@arm.comimport argparse 4710259SAndrew.Bardsley@arm.com 4810259SAndrew.Bardsley@arm.com# Find MinorView modules even if not called from minorview directory 4910259SAndrew.Bardsley@arm.comminorviewDir = os.path.dirname(os.path.realpath(__file__)) 5010259SAndrew.Bardsley@arm.comsys.path.append(minorviewDir) 5110259SAndrew.Bardsley@arm.com 5210259SAndrew.Bardsley@arm.comfrom minorview.model import BlobModel 5310259SAndrew.Bardsley@arm.comfrom minorview.view import BlobView, BlobController, BlobWindow 5410259SAndrew.Bardsley@arm.comfrom minorview.point import Point 5510259SAndrew.Bardsley@arm.com 5610259SAndrew.Bardsley@arm.comif __name__ == '__main__': 5710259SAndrew.Bardsley@arm.com parser = argparse.ArgumentParser(description='Minor visualiser') 5810259SAndrew.Bardsley@arm.com 5910259SAndrew.Bardsley@arm.com parser.add_argument('--picture', metavar='picture-file', 6010259SAndrew.Bardsley@arm.com default=minorviewDir + '/minorview/minor.pic', 6110259SAndrew.Bardsley@arm.com help='markup file containing blob information ' 6210259SAndrew.Bardsley@arm.com + '(default: <minorview-path>/minor.pic)') 6310259SAndrew.Bardsley@arm.com parser.add_argument('--prefix', metavar='name', default='system.cpu', 6410259SAndrew.Bardsley@arm.com help='name prefix in trace for CPU to be visualised (default: ' 6510259SAndrew.Bardsley@arm.com + 'system.cpu)') 6610259SAndrew.Bardsley@arm.com parser.add_argument('--start-time', metavar='time', type=int, default=0, 6710259SAndrew.Bardsley@arm.com help='time of first event to load from file') 6810259SAndrew.Bardsley@arm.com parser.add_argument('--end-time', metavar='time', type=int, default=None, 6910259SAndrew.Bardsley@arm.com help='time of last event to load from file') 7010259SAndrew.Bardsley@arm.com parser.add_argument('--mini-views', action='store_true', default=False, 7110259SAndrew.Bardsley@arm.com help='show tiny views of the next 10 time steps') 7210259SAndrew.Bardsley@arm.com parser.add_argument('eventFile', metavar='event-file', default='ev') 7310259SAndrew.Bardsley@arm.com 7410259SAndrew.Bardsley@arm.com args = parser.parse_args(sys.argv[1:]) 7510259SAndrew.Bardsley@arm.com 7610259SAndrew.Bardsley@arm.com model = BlobModel(unitNamePrefix=args.prefix) 7710259SAndrew.Bardsley@arm.com 7810259SAndrew.Bardsley@arm.com if args.picture and os.access(args.picture, os.O_RDONLY): 7910259SAndrew.Bardsley@arm.com model.load_picture(args.picture) 8010259SAndrew.Bardsley@arm.com else: 8110259SAndrew.Bardsley@arm.com parser.error('Can\'t read picture file: ' + args.picture) 8210259SAndrew.Bardsley@arm.com 8310259SAndrew.Bardsley@arm.com # Make the key objects 8410259SAndrew.Bardsley@arm.com view = BlobView(model) 8510259SAndrew.Bardsley@arm.com controller = BlobController(model, view, 8610259SAndrew.Bardsley@arm.com defaultEventFile=args.eventFile, 8710259SAndrew.Bardsley@arm.com defaultPictureFile=args.picture) 8810259SAndrew.Bardsley@arm.com window = BlobWindow(model, view, controller) 8910259SAndrew.Bardsley@arm.com window.add_control_bar(controller.bar) 9010259SAndrew.Bardsley@arm.com 9110259SAndrew.Bardsley@arm.com # Miniviews allow future timesteps to appear at the bottom of the 9210259SAndrew.Bardsley@arm.com # display. 9310259SAndrew.Bardsley@arm.com if args.mini_views: 9410259SAndrew.Bardsley@arm.com window.miniViewCount = 10 9510259SAndrew.Bardsley@arm.com 9610259SAndrew.Bardsley@arm.com window.show_window() 9710259SAndrew.Bardsley@arm.com 9810259SAndrew.Bardsley@arm.com if args.eventFile and os.access(args.eventFile, os.O_RDONLY): 9910259SAndrew.Bardsley@arm.com controller.startTime = args.start_time 10010259SAndrew.Bardsley@arm.com controller.endTime = args.end_time 10110259SAndrew.Bardsley@arm.com model.load_events(args.eventFile, startTime=args.start_time, 10210259SAndrew.Bardsley@arm.com endTime=args.end_time) 10310259SAndrew.Bardsley@arm.com controller.set_time_index(0) 10410259SAndrew.Bardsley@arm.com else: 10510259SAndrew.Bardsley@arm.com parser.error('Can\'t read event file: ' + args.eventFile) 10610259SAndrew.Bardsley@arm.com 10710259SAndrew.Bardsley@arm.com gtk.main() 108