xref: /aosp_15_r20/build/soong/ui/tracer/microfactory.go (revision 333d2b3687b3a337dbcca9d65000bca186795e39)
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