1*333d2b36SAndroid Build Coastguard Worker// Copyright 2017 Google Inc. All rights reserved. 2*333d2b36SAndroid Build Coastguard Worker// 3*333d2b36SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License"); 4*333d2b36SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License. 5*333d2b36SAndroid Build Coastguard Worker// You may obtain a copy of the License at 6*333d2b36SAndroid Build Coastguard Worker// 7*333d2b36SAndroid Build Coastguard Worker// http://www.apache.org/licenses/LICENSE-2.0 8*333d2b36SAndroid Build Coastguard Worker// 9*333d2b36SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software 10*333d2b36SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS, 11*333d2b36SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*333d2b36SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and 13*333d2b36SAndroid Build Coastguard Worker// limitations under the License. 14*333d2b36SAndroid Build Coastguard Worker 15*333d2b36SAndroid Build Coastguard Workerpackage tracer 16*333d2b36SAndroid Build Coastguard Worker 17*333d2b36SAndroid Build Coastguard Workerimport ( 18*333d2b36SAndroid Build Coastguard Worker "bufio" 19*333d2b36SAndroid Build Coastguard Worker "os" 20*333d2b36SAndroid Build Coastguard Worker "sort" 21*333d2b36SAndroid Build Coastguard Worker "strconv" 22*333d2b36SAndroid Build Coastguard Worker "strings" 23*333d2b36SAndroid Build Coastguard Worker) 24*333d2b36SAndroid Build Coastguard Worker 25*333d2b36SAndroid Build Coastguard Workertype eventEntry struct { 26*333d2b36SAndroid Build Coastguard Worker Name string 27*333d2b36SAndroid Build Coastguard Worker Begin uint64 28*333d2b36SAndroid Build Coastguard Worker End uint64 29*333d2b36SAndroid Build Coastguard Worker} 30*333d2b36SAndroid Build Coastguard Worker 31*333d2b36SAndroid Build Coastguard Workerfunc (t *tracerImpl) importEvents(entries []*eventEntry) { 32*333d2b36SAndroid Build Coastguard Worker sort.Slice(entries, func(i, j int) bool { 33*333d2b36SAndroid Build Coastguard Worker return entries[i].Begin < entries[j].Begin 34*333d2b36SAndroid Build Coastguard Worker }) 35*333d2b36SAndroid Build Coastguard Worker 36*333d2b36SAndroid Build Coastguard Worker cpus := []uint64{} 37*333d2b36SAndroid Build Coastguard Worker for _, entry := range entries { 38*333d2b36SAndroid Build Coastguard Worker tid := -1 39*333d2b36SAndroid Build Coastguard Worker for cpu, endTime := range cpus { 40*333d2b36SAndroid Build Coastguard Worker if endTime <= entry.Begin { 41*333d2b36SAndroid Build Coastguard Worker tid = cpu 42*333d2b36SAndroid Build Coastguard Worker cpus[cpu] = entry.End 43*333d2b36SAndroid Build Coastguard Worker break 44*333d2b36SAndroid Build Coastguard Worker } 45*333d2b36SAndroid Build Coastguard Worker } 46*333d2b36SAndroid Build Coastguard Worker if tid == -1 { 47*333d2b36SAndroid Build Coastguard Worker tid = len(cpus) 48*333d2b36SAndroid Build Coastguard Worker cpus = append(cpus, entry.End) 49*333d2b36SAndroid Build Coastguard Worker } 50*333d2b36SAndroid Build Coastguard Worker 51*333d2b36SAndroid Build Coastguard Worker t.writeEvent(&viewerEvent{ 52*333d2b36SAndroid Build Coastguard Worker Name: entry.Name, 53*333d2b36SAndroid Build Coastguard Worker Phase: "X", 54*333d2b36SAndroid Build Coastguard Worker Time: entry.Begin, 55*333d2b36SAndroid Build Coastguard Worker Dur: entry.End - entry.Begin, 56*333d2b36SAndroid Build Coastguard Worker Pid: 1, 57*333d2b36SAndroid Build Coastguard Worker Tid: uint64(tid), 58*333d2b36SAndroid Build Coastguard Worker }) 59*333d2b36SAndroid Build Coastguard Worker } 60*333d2b36SAndroid Build Coastguard Worker} 61*333d2b36SAndroid Build Coastguard Worker 62*333d2b36SAndroid Build Coastguard Workerfunc (t *tracerImpl) ImportMicrofactoryLog(filename string) { 63*333d2b36SAndroid Build Coastguard Worker if _, err := os.Stat(filename); err != nil { 64*333d2b36SAndroid Build Coastguard Worker return 65*333d2b36SAndroid Build Coastguard Worker } 66*333d2b36SAndroid Build Coastguard Worker 67*333d2b36SAndroid Build Coastguard Worker f, err := os.Open(filename) 68*333d2b36SAndroid Build Coastguard Worker if err != nil { 69*333d2b36SAndroid Build Coastguard Worker t.log.Verboseln("Error opening microfactory trace:", err) 70*333d2b36SAndroid Build Coastguard Worker return 71*333d2b36SAndroid Build Coastguard Worker } 72*333d2b36SAndroid Build Coastguard Worker defer f.Close() 73*333d2b36SAndroid Build Coastguard Worker 74*333d2b36SAndroid Build Coastguard Worker entries := []*eventEntry{} 75*333d2b36SAndroid Build Coastguard Worker begin := map[string][]uint64{} 76*333d2b36SAndroid Build Coastguard Worker s := bufio.NewScanner(f) 77*333d2b36SAndroid Build Coastguard Worker for s.Scan() { 78*333d2b36SAndroid Build Coastguard Worker fields := strings.SplitN(s.Text(), " ", 3) 79*333d2b36SAndroid Build Coastguard Worker if len(fields) != 3 { 80*333d2b36SAndroid Build Coastguard Worker t.log.Verboseln("Unknown line in microfactory trace:", s.Text()) 81*333d2b36SAndroid Build Coastguard Worker continue 82*333d2b36SAndroid Build Coastguard Worker } 83*333d2b36SAndroid Build Coastguard Worker timestamp, err := strconv.ParseUint(fields[0], 10, 64) 84*333d2b36SAndroid Build Coastguard Worker if err != nil { 85*333d2b36SAndroid Build Coastguard Worker t.log.Verboseln("Failed to parse timestamp in microfactory trace:", err) 86*333d2b36SAndroid Build Coastguard Worker } 87*333d2b36SAndroid Build Coastguard Worker 88*333d2b36SAndroid Build Coastguard Worker if fields[1] == "B" { 89*333d2b36SAndroid Build Coastguard Worker begin[fields[2]] = append(begin[fields[2]], timestamp) 90*333d2b36SAndroid Build Coastguard Worker } else if beginTimestamps, ok := begin[fields[2]]; ok { 91*333d2b36SAndroid Build Coastguard Worker entries = append(entries, &eventEntry{ 92*333d2b36SAndroid Build Coastguard Worker Name: fields[2], 93*333d2b36SAndroid Build Coastguard Worker Begin: beginTimestamps[len(beginTimestamps)-1], 94*333d2b36SAndroid Build Coastguard Worker End: timestamp, 95*333d2b36SAndroid Build Coastguard Worker }) 96*333d2b36SAndroid Build Coastguard Worker begin[fields[2]] = beginTimestamps[:len(beginTimestamps)-1] 97*333d2b36SAndroid Build Coastguard Worker } 98*333d2b36SAndroid Build Coastguard Worker } 99*333d2b36SAndroid Build Coastguard Worker 100*333d2b36SAndroid Build Coastguard Worker t.importEvents(entries) 101*333d2b36SAndroid Build Coastguard Worker} 102