1 /*
2  * Copyright (C) 2019 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 #include "src/kallsyms/lazy_kernel_symbolizer.h"
18 
19 #include <cinttypes>
20 
21 #include "perfetto/ext/base/file_utils.h"
22 #include "perfetto/ext/base/temp_file.h"
23 
24 #include "test/gtest_and_gmock.h"
25 
26 namespace perfetto {
27 namespace {
28 
29 const char kUnrestrictedKallsyms[] = R"(
30 0000000000000000 A fixed_percpu_data
31 0000000000000000 A __per_cpu_start
32 0000000000001000 A cpu_debug_store
33 0000000000002000 A irq_stack_backing_store
34 0000000000006000 A cpu_tss_rw
35 0000000000009000 A gdt_page
36 000000000000a000 A entry_stack_storage
37 000000000000b000 A exception_stacks
38 0000000000010000 A espfix_stack
39 0000000000010008 A espfix_waddr
40 0000000000010010 A cpu_llc_id
41 0000000000010020 A mce_banks_array
42 0000000000010220 A mce_num_banks
43 0000000000010228 A cpu_sibling_map
44 0000000000010230 A cpu_core_map
45 0000000000010238 A cpu_die_map
46 0000000000010240 A cpu_info
47 0000000000010330 A cpu_llc_shared_map
48 0000000000010338 A cpu_number
49 0000000000010340 A this_cpu_off
50 0000000000010348 A x86_cpu_to_apicid
51 000000000001034a A x86_bios_cpu_apicid
52 000000000001034c A x86_cpu_to_acpiid
53 0000000000010350 A sched_core_priority
54 0000000000011000 A svm_data
55 0000000000011008 A current_tsc_ratio
56 0000000000011010 A saved_epb
57 0000000000011018 A cluster_masks
58 0000000000011020 A x86_cpu_to_logical_apicid
59 0000000000011028 A ipi_mask
60 0000000000011030 A menu_devices
61 0000000000011098 A cpu_loops_per_jiffy
62 00000000000110a0 A cpu_hw_events
63 00000000000123b0 A pmc_prev_left
64 00000000000125b0 A perf_nmi_tstamp
65 0000000000013000 A bts_ctx
66 0000000000016000 A insn_buffer
67 0000000000016008 A pt_ctx
68 00000000000160b0 A cpu_tsc_khz
69 00000000000160b8 A current_vcpu
70 00000000000160c0 A loaded_vmcss_on_cpu
71 00000000000160d0 A current_vmcs
72 00000000000160d8 A vmxarea
73 00000000000160e0 A blocked_vcpu_on_cpu
74 00000000000160f0 A blocked_vcpu_on_cpu_lock
75 00000000000160f8 A irq_regs
76 0000000000016100 A nmi_state
77 0000000000016108 A nmi_cr2
78 0000000000016110 A update_debug_stack
79 0000000000016118 A last_nmi_rip
80 0000000000016120 A nmi_stats
81 0000000000016130 A swallow_nmi
82 0000000000016140 A vector_irq
83 0000000000028458 A processor_device_array
84 0000000000028460 A acpi_cpuidle_device
85 0000000000028470 A acpi_cstate
86 00000000000284c0 A cpufreq_thermal_reduction_pctg
87 00000000000284c8 A cpc_desc_ptr
88 00000000000284d0 A cpu_pcc_subspace_idx
89 00000000000284d8 A irq_randomness
90 00000000000284f8 A batched_entropy_u64
91 0000000000028540 A batched_entropy_u32
92 00000000000285c0 A drm_unplug_srcu_srcu_data
93 0000000000028740 A device_links_srcu_srcu_data
94 00000000000288c0 A cpu_sys_devices
95 00000000000288c8 A ci_cpu_cacheinfo
96 00000000000288e0 A ci_cache_dev
97 00000000000288e8 A ci_index_dev
98 0000000000028900 A wakeup_srcu_srcu_data
99 0000000000028a80 A flush_idx
100 0000000000028ac0 A dax_srcu_srcu_data
101 0000000000028c40 A cpufreq_cpu_data
102 0000000000028c80 A cpufreq_transition_notifier_list_head_srcu_data
103 0000000000028e00 A cpu_dbs
104 0000000000028e30 A cpuidle_devices
105 0000000000028e38 A cpuidle_dev
106 00000000000290f8 A netdev_alloc_cache
107 0000000000029110 A napi_alloc_cache
108 0000000000029330 A flush_works
109 0000000000029360 A bpf_redirect_info
110 0000000000029388 A bpf_sp
111 0000000000029588 A nf_skb_duplicated
112 000000000002958c A xt_recseq
113 0000000000029590 A rt_cache_stat
114 00000000000295b0 A tsq_tasklet
115 00000000000295e8 A xfrm_trans_tasklet
116 0000000000029628 A radix_tree_preloads
117 0000000000029640 A irq_stat
118 00000000000296c0 A cyc2ns
119 0000000000029700 A cpu_tlbstate
120 0000000000029780 A flush_tlb_info
121 00000000000297c0 A cpu_worker_pools
122 0000000000029ec0 A runqueues
123 000000000002aa80 A sched_clock_data
124 000000000002aac0 A osq_node
125 000000000002ab00 A qnodes
126 000000000002ab40 A rcu_data
127 000000000002ae80 A cfd_data
128 000000000002aec0 A call_single_queue
129 000000000002af00 A csd_data
130 000000000002af40 A softnet_data
131 000000000002b200 A rt_uncached_list
132 000000000002b240 A rt6_uncached_list
133 000000000002b258 A __per_cpu_end
134 ffffffffb7e00000 T startup_64
135 ffffffffb7e00000 T _stext
136 ffffffffb7e00000 T _text
137 ffffffffb7e00030 T secondary_startup_64
138 ffffffffb7e000e0 T verify_cpu
139 ffffffffb7e001e0 T start_cpu0
140 ffffffffb7e001f0 T __startup_64
141 )";
142 
143 const char kRestrictedKallsyms[] = R"(
144 0000000000000000 A fixed_percpu_data
145 0000000000000000 A __per_cpu_start
146 0000000000000000 A cpu_debug_store
147 0000000000000000 A irq_stack_backing_store
148 0000000000000000 A cpu_tss_rw
149 0000000000000000 A gdt_page
150 0000000000000000 A entry_stack_storage
151 0000000000000000 A exception_stacks
152 0000000000000000 A espfix_stack
153 0000000000000000 A espfix_waddr
154 0000000000000000 A cpu_llc_id
155 0000000000000000 A mce_banks_array
156 0000000000000000 A mce_num_banks
157 0000000000000000 A cpu_sibling_map
158 0000000000000000 A cpu_core_map
159 0000000000000000 A cpu_die_map
160 0000000000000000 A cpu_info
161 0000000000000000 A cpu_llc_shared_map
162 0000000000000000 A cpu_number
163 0000000000000000 A this_cpu_off
164 0000000000000000 A x86_cpu_to_apicid
165 0000000000000000 A x86_bios_cpu_apicid
166 0000000000000000 A x86_cpu_to_acpiid
167 0000000000000000 A sched_core_priority
168 0000000000000000 A svm_data
169 0000000000000000 A current_tsc_ratio
170 0000000000000000 A saved_epb
171 0000000000000000 A cluster_masks
172 0000000000000000 A x86_cpu_to_logical_apicid
173 0000000000000000 A ipi_mask
174 0000000000000000 A menu_devices
175 0000000000000000 A cpu_loops_per_jiffy
176 0000000000000000 A cpu_hw_events
177 0000000000000000 A pmc_prev_left
178 0000000000000000 A perf_nmi_tstamp
179 0000000000000000 A bts_ctx
180 0000000000000000 A insn_buffer
181 0000000000000000 A pt_ctx
182 0000000000000000 A cpu_tsc_khz
183 0000000000000000 A current_vcpu
184 0000000000000000 A loaded_vmcss_on_cpu
185 0000000000000000 A current_vmcs
186 0000000000000000 A vmxarea
187 0000000000000000 A blocked_vcpu_on_cpu
188 0000000000000000 A blocked_vcpu_on_cpu_lock
189 0000000000000000 A irq_regs
190 0000000000000000 A nmi_state
191 0000000000000000 A nmi_cr2
192 0000000000000000 A update_debug_stack
193 0000000000000000 A last_nmi_rip
194 0000000000000000 A nmi_stats
195 0000000000000000 A swallow_nmi
196 0000000000000000 A vector_irq
197 0000000000000000 A processor_device_array
198 0000000000000000 A acpi_cpuidle_device
199 0000000000000000 A acpi_cstate
200 0000000000000000 A cpufreq_thermal_reduction_pctg
201 0000000000000000 A cpc_desc_ptr
202 0000000000000000 A cpu_pcc_subspace_idx
203 0000000000000000 A irq_randomness
204 0000000000000000 A batched_entropy_u64
205 0000000000000000 A batched_entropy_u32
206 0000000000000000 A drm_unplug_srcu_srcu_data
207 0000000000000000 A device_links_srcu_srcu_data
208 0000000000000000 A cpu_sys_devices
209 0000000000000000 A ci_cpu_cacheinfo
210 0000000000000000 A ci_cache_dev
211 0000000000000000 A ci_index_dev
212 0000000000000000 A wakeup_srcu_srcu_data
213 0000000000000000 A flush_idx
214 0000000000000000 A dax_srcu_srcu_data
215 0000000000000000 A cpufreq_cpu_data
216 0000000000000000 A cpufreq_transition_notifier_list_head_srcu_data
217 0000000000000000 A cpu_dbs
218 0000000000000000 A cpuidle_devices
219 0000000000000000 A cpuidle_dev
220 0000000000000000 A netdev_alloc_cache
221 0000000000000000 A napi_alloc_cache
222 0000000000000000 A flush_works
223 0000000000000000 A bpf_redirect_info
224 0000000000000000 A bpf_sp
225 0000000000000000 A nf_skb_duplicated
226 0000000000000000 A xt_recseq
227 0000000000000000 A rt_cache_stat
228 0000000000000000 A tsq_tasklet
229 0000000000000000 A xfrm_trans_tasklet
230 0000000000000000 A radix_tree_preloads
231 0000000000000000 A irq_stat
232 0000000000000000 A cyc2ns
233 0000000000000000 A cpu_tlbstate
234 0000000000000000 A flush_tlb_info
235 0000000000000000 A cpu_worker_pools
236 0000000000000000 A runqueues
237 0000000000000000 A sched_clock_data
238 0000000000000000 A osq_node
239 0000000000000000 A qnodes
240 0000000000000000 A rcu_data
241 0000000000000000 A cfd_data
242 0000000000000000 A call_single_queue
243 0000000000000000 A csd_data
244 0000000000000000 A softnet_data
245 0000000000000000 A rt_uncached_list
246 0000000000000000 A rt6_uncached_list
247 0000000000000000 A __per_cpu_end
248 0000000000000000 T startup_64
249 0000000000000000 T _stext
250 0000000000000000 T _text
251 0000000000000000 T secondary_startup_64
252 0000000000000000 T verify_cpu
253 0000000000000000 T start_cpu0
254 0000000000000000 T __startup_64
255 )";
256 
TEST(LazyKernelSymbolizerTest,CanReadKernelSymbolAddresses)257 TEST(LazyKernelSymbolizerTest, CanReadKernelSymbolAddresses) {
258   {
259     base::TempFile tmp = base::TempFile::Create();
260     base::WriteAll(tmp.fd(), kRestrictedKallsyms, sizeof(kRestrictedKallsyms));
261     base::FlushFile(tmp.fd());
262     EXPECT_FALSE(
263         LazyKernelSymbolizer::CanReadKernelSymbolAddresses(tmp.path().c_str()));
264   }
265 
266   {
267     base::TempFile tmp = base::TempFile::Create();
268     base::WriteAll(tmp.fd(), kUnrestrictedKallsyms,
269                    sizeof(kUnrestrictedKallsyms));
270     base::FlushFile(tmp.fd());
271     EXPECT_TRUE(
272         LazyKernelSymbolizer::CanReadKernelSymbolAddresses(tmp.path().c_str()));
273   }
274 }
275 
276 }  // namespace
277 }  // namespace perfetto
278