xref: /aosp_15_r20/frameworks/base/tools/preload/PrintCsv.java (revision d57664e9bc4670b3ecf6748a746a57c557b6bc9e)
1*d57664e9SAndroid Build Coastguard Worker /*
2*d57664e9SAndroid Build Coastguard Worker  * Copyright (C) 2008 The Android Open Source Project
3*d57664e9SAndroid Build Coastguard Worker  *
4*d57664e9SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*d57664e9SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*d57664e9SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*d57664e9SAndroid Build Coastguard Worker  *
8*d57664e9SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*d57664e9SAndroid Build Coastguard Worker  *
10*d57664e9SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*d57664e9SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*d57664e9SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*d57664e9SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*d57664e9SAndroid Build Coastguard Worker  * limitations under the License.
15*d57664e9SAndroid Build Coastguard Worker  */
16*d57664e9SAndroid Build Coastguard Worker 
17*d57664e9SAndroid Build Coastguard Worker import java.io.IOException;
18*d57664e9SAndroid Build Coastguard Worker import java.io.FileInputStream;
19*d57664e9SAndroid Build Coastguard Worker import java.io.ObjectInputStream;
20*d57664e9SAndroid Build Coastguard Worker import java.io.BufferedInputStream;
21*d57664e9SAndroid Build Coastguard Worker import java.io.Writer;
22*d57664e9SAndroid Build Coastguard Worker import java.io.PrintStream;
23*d57664e9SAndroid Build Coastguard Worker import java.util.Set;
24*d57664e9SAndroid Build Coastguard Worker import java.util.HashSet;
25*d57664e9SAndroid Build Coastguard Worker import java.util.TreeSet;
26*d57664e9SAndroid Build Coastguard Worker import java.util.Iterator;
27*d57664e9SAndroid Build Coastguard Worker 
28*d57664e9SAndroid Build Coastguard Worker /**
29*d57664e9SAndroid Build Coastguard Worker  * Prints raw information in CSV format.
30*d57664e9SAndroid Build Coastguard Worker  */
31*d57664e9SAndroid Build Coastguard Worker public class PrintCsv {
32*d57664e9SAndroid Build Coastguard Worker 
main(String[] args)33*d57664e9SAndroid Build Coastguard Worker     public static void main(String[] args)
34*d57664e9SAndroid Build Coastguard Worker             throws IOException, ClassNotFoundException {
35*d57664e9SAndroid Build Coastguard Worker         if (args.length != 1) {
36*d57664e9SAndroid Build Coastguard Worker             System.err.println("Usage: PrintCsv [compiled log file]");
37*d57664e9SAndroid Build Coastguard Worker             System.exit(0);
38*d57664e9SAndroid Build Coastguard Worker         }
39*d57664e9SAndroid Build Coastguard Worker 
40*d57664e9SAndroid Build Coastguard Worker         Root root = Root.fromFile(args[0]);
41*d57664e9SAndroid Build Coastguard Worker 
42*d57664e9SAndroid Build Coastguard Worker         printHeaders(System.out);
43*d57664e9SAndroid Build Coastguard Worker 
44*d57664e9SAndroid Build Coastguard Worker         MemoryUsage baseline = MemoryUsage.baseline();
45*d57664e9SAndroid Build Coastguard Worker 
46*d57664e9SAndroid Build Coastguard Worker         for (LoadedClass loadedClass : root.loadedClasses.values()) {
47*d57664e9SAndroid Build Coastguard Worker             if (!loadedClass.systemClass) {
48*d57664e9SAndroid Build Coastguard Worker                 continue;
49*d57664e9SAndroid Build Coastguard Worker             }
50*d57664e9SAndroid Build Coastguard Worker 
51*d57664e9SAndroid Build Coastguard Worker             printRow(System.out, baseline, loadedClass);
52*d57664e9SAndroid Build Coastguard Worker         }
53*d57664e9SAndroid Build Coastguard Worker     }
54*d57664e9SAndroid Build Coastguard Worker 
printHeaders(PrintStream out)55*d57664e9SAndroid Build Coastguard Worker     static void printHeaders(PrintStream out) {
56*d57664e9SAndroid Build Coastguard Worker         out.println("Name"
57*d57664e9SAndroid Build Coastguard Worker                 + ",Preloaded"
58*d57664e9SAndroid Build Coastguard Worker                 + ",Median Load Time (us)"
59*d57664e9SAndroid Build Coastguard Worker                 + ",Median Init Time (us)"
60*d57664e9SAndroid Build Coastguard Worker                 + ",Process Names"
61*d57664e9SAndroid Build Coastguard Worker                 + ",Load Count"
62*d57664e9SAndroid Build Coastguard Worker                 + ",Init Count"
63*d57664e9SAndroid Build Coastguard Worker                 + ",Managed Heap (B)"
64*d57664e9SAndroid Build Coastguard Worker                 + ",Native Heap (B)"
65*d57664e9SAndroid Build Coastguard Worker                 + ",Managed Pages (kB)"
66*d57664e9SAndroid Build Coastguard Worker                 + ",Native Pages (kB)"
67*d57664e9SAndroid Build Coastguard Worker                 + ",Other Pages (kB)");
68*d57664e9SAndroid Build Coastguard Worker     }
69*d57664e9SAndroid Build Coastguard Worker 
printRow(PrintStream out, MemoryUsage baseline, LoadedClass loadedClass)70*d57664e9SAndroid Build Coastguard Worker     static void printRow(PrintStream out, MemoryUsage baseline,
71*d57664e9SAndroid Build Coastguard Worker             LoadedClass loadedClass) {
72*d57664e9SAndroid Build Coastguard Worker         out.print(loadedClass.name);
73*d57664e9SAndroid Build Coastguard Worker         out.print(',');
74*d57664e9SAndroid Build Coastguard Worker         out.print(loadedClass.preloaded);
75*d57664e9SAndroid Build Coastguard Worker         out.print(',');
76*d57664e9SAndroid Build Coastguard Worker         out.print(loadedClass.medianLoadTimeMicros());
77*d57664e9SAndroid Build Coastguard Worker         out.print(',');
78*d57664e9SAndroid Build Coastguard Worker         out.print(loadedClass.medianInitTimeMicros());
79*d57664e9SAndroid Build Coastguard Worker         out.print(',');
80*d57664e9SAndroid Build Coastguard Worker         out.print('"');
81*d57664e9SAndroid Build Coastguard Worker 
82*d57664e9SAndroid Build Coastguard Worker         Set<String> procNames = new TreeSet<String>();
83*d57664e9SAndroid Build Coastguard Worker         for (Operation op : loadedClass.loads)
84*d57664e9SAndroid Build Coastguard Worker             procNames.add(op.process.name);
85*d57664e9SAndroid Build Coastguard Worker         for (Operation op : loadedClass.initializations)
86*d57664e9SAndroid Build Coastguard Worker             procNames.add(op.process.name);
87*d57664e9SAndroid Build Coastguard Worker 
88*d57664e9SAndroid Build Coastguard Worker         if (procNames.size() <= 3) {
89*d57664e9SAndroid Build Coastguard Worker             for (String name : procNames) {
90*d57664e9SAndroid Build Coastguard Worker                 out.print(name + "\n");
91*d57664e9SAndroid Build Coastguard Worker             }
92*d57664e9SAndroid Build Coastguard Worker         } else {
93*d57664e9SAndroid Build Coastguard Worker             Iterator<String> i = procNames.iterator();
94*d57664e9SAndroid Build Coastguard Worker             out.print(i.next() + "\n");
95*d57664e9SAndroid Build Coastguard Worker             out.print(i.next() + "\n");
96*d57664e9SAndroid Build Coastguard Worker             out.print("...and " + (procNames.size() - 2)
97*d57664e9SAndroid Build Coastguard Worker                     + " others.");
98*d57664e9SAndroid Build Coastguard Worker         }
99*d57664e9SAndroid Build Coastguard Worker 
100*d57664e9SAndroid Build Coastguard Worker         out.print('"');
101*d57664e9SAndroid Build Coastguard Worker         out.print(',');
102*d57664e9SAndroid Build Coastguard Worker         out.print(loadedClass.loads.size());
103*d57664e9SAndroid Build Coastguard Worker         out.print(',');
104*d57664e9SAndroid Build Coastguard Worker         out.print(loadedClass.initializations.size());
105*d57664e9SAndroid Build Coastguard Worker 
106*d57664e9SAndroid Build Coastguard Worker         if (loadedClass.memoryUsage.isAvailable()) {
107*d57664e9SAndroid Build Coastguard Worker             MemoryUsage subtracted
108*d57664e9SAndroid Build Coastguard Worker                     = loadedClass.memoryUsage.subtract(baseline);
109*d57664e9SAndroid Build Coastguard Worker 
110*d57664e9SAndroid Build Coastguard Worker             out.print(',');
111*d57664e9SAndroid Build Coastguard Worker             out.print(subtracted.javaHeapSize());
112*d57664e9SAndroid Build Coastguard Worker             out.print(',');
113*d57664e9SAndroid Build Coastguard Worker             out.print(subtracted.nativeHeapSize);
114*d57664e9SAndroid Build Coastguard Worker             out.print(',');
115*d57664e9SAndroid Build Coastguard Worker             out.print(subtracted.javaPagesInK());
116*d57664e9SAndroid Build Coastguard Worker             out.print(',');
117*d57664e9SAndroid Build Coastguard Worker             out.print(subtracted.nativePagesInK());
118*d57664e9SAndroid Build Coastguard Worker             out.print(',');
119*d57664e9SAndroid Build Coastguard Worker             out.print(subtracted.otherPagesInK());
120*d57664e9SAndroid Build Coastguard Worker 
121*d57664e9SAndroid Build Coastguard Worker         } else {
122*d57664e9SAndroid Build Coastguard Worker             out.print(",n/a,n/a,n/a,n/a,n/a");
123*d57664e9SAndroid Build Coastguard Worker         }
124*d57664e9SAndroid Build Coastguard Worker 
125*d57664e9SAndroid Build Coastguard Worker         out.println();
126*d57664e9SAndroid Build Coastguard Worker     }
127*d57664e9SAndroid Build Coastguard Worker }
128