1 /*
2  * Copyright (C) 2015 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef SIMPLE_PERF_RECORD_FILE_FORMAT_H_
18 #define SIMPLE_PERF_RECORD_FILE_FORMAT_H_
19 
20 #include <string>
21 
22 #include "perf_event.h"
23 
24 /*
25 The file structure of perf.data:
26     file_header
27     id_section
28     attr section
29     data section
30     feature section
31 
32 The feature section has the following structure:
33     a section descriptor array, each element contains the section information of one add_feature.
34     data section of feature 1
35     data section of feature 2
36     ....
37 
38 file feature section:
39   file_struct files[];
40 
41   struct file_struct {
42     uint32_t size;  // size of rest fields in file_struct
43     char file_path[];
44     uint32_t file_type;
45     uint64_t min_vaddr;
46     uint32_t symbol_count;
47     struct {
48       uint64_t start_vaddr;
49       uint32_t len;
50       char symbol_name[len+1];
51     } symbol_table[symbol_count];
52 
53     uint32_t dex_file_offset_count;  // Only when file_type = DSO_DEX_FILE
54     uint64_t dex_file_offsets[dex_file_offset_count];  // Only when file_type = DSO_DEX_FILE
55     uint64_t file_offset_of_min_vaddr;  // Only when file_type = DSO_ELF_FILE
56     uint64_t memory_offset_of_min_vaddr;  // Only when file_type = DSO_KERNEL_MODULE
57   };
58 
59 meta_info feature section:
60   meta_info infos[];
61 
62   struct meta_info {
63     char key[];
64     char value[];
65   };
66   keys in meta_info feature section include:
67     simpleperf_version,
68 
69 debug_unwind feature section:
70   message DebugUnwindFeature from record_file.proto
71 
72 debug_unwind_file feature section:
73   data for file 1
74   data for file 2
75   ...
76 
77   The file list is stored in debug_unwind feature section.
78 
79 file2 feature section (used to replace file feature section):
80   uint32_t file_msg1_size;
81   FileFeature file_msg1;  // FileFeature from record_file.proto
82   uint32_t file_msg2_size;
83   FileFeature file_msg2;
84   ...
85 
86 etm_branch_list feature section:
87   ETMBranchList etm_branch_list;  // from etm_branch_list.proto
88 */
89 
90 namespace simpleperf {
91 namespace PerfFileFormat {
92 
93 enum {
94   FEAT_RESERVED = 0,
95   FEAT_FIRST_FEATURE = 1,
96   FEAT_TRACING_DATA = 1,
97   FEAT_BUILD_ID,
98   FEAT_HOSTNAME,
99   FEAT_OSRELEASE,
100   FEAT_VERSION,
101   FEAT_ARCH,
102   FEAT_NRCPUS,
103   FEAT_CPUDESC,
104   FEAT_CPUID,
105   FEAT_TOTAL_MEM,
106   FEAT_CMDLINE,
107   FEAT_EVENT_DESC,
108   FEAT_CPU_TOPOLOGY,
109   FEAT_NUMA_TOPOLOGY,
110   FEAT_BRANCH_STACK,
111   FEAT_PMU_MAPPINGS,
112   FEAT_GROUP_DESC,
113   FEAT_AUXTRACE,
114   FEAT_LAST_FEATURE,
115 
116   FEAT_SIMPLEPERF_START = 128,
117   FEAT_FILE = FEAT_SIMPLEPERF_START,
118   FEAT_META_INFO,
119   FEAT_DEBUG_UNWIND,
120   FEAT_DEBUG_UNWIND_FILE,
121   FEAT_FILE2,
122   FEAT_ETM_BRANCH_LIST,
123   FEAT_MAX_NUM = 256,
124 };
125 
126 std::string GetFeatureName(int feature_id);
127 int GetFeatureId(const std::string& feature_name);
128 
129 struct SectionDesc {
130   uint64_t offset;
131   uint64_t size;
132 };
133 
134 constexpr char PERF_MAGIC[] = "PERFILE2";
135 
136 struct FileHeader {
137   char magic[8];
138   uint64_t header_size;
139   uint64_t attr_size;
140   SectionDesc attrs;
141   SectionDesc data;
142   SectionDesc event_types;
143   unsigned char features[FEAT_MAX_NUM / 8];
144 };
145 
146 struct FileAttr {
147   perf_event_attr attr;
148   SectionDesc ids;
149 };
150 
151 }  // namespace PerfFileFormat
152 }  // namespace simpleperf
153 
154 #endif  // SIMPLE_PERF_RECORD_FILE_FORMAT_H_
155