rustc_codegen_llvm/coverageinfo/
llvm_cov.rs1use std::ffi::CString;
4
5use crate::coverageinfo::ffi;
6use crate::llvm;
7
8pub(crate) fn covmap_var_name() -> CString {
9 CString::new(llvm::build_byte_buffer(|s| {
10 llvm::LLVMRustCoverageWriteCovmapVarNameToString(s);
11 }))
12 .expect("covmap variable name should not contain NUL")
13}
14
15pub(crate) fn covmap_section_name(llmod: &llvm::Module) -> CString {
16 CString::new(llvm::build_byte_buffer(|s| {
17 llvm::LLVMRustCoverageWriteCovmapSectionNameToString(llmod, s);
18 }))
19 .expect("covmap section name should not contain NUL")
20}
21
22pub(crate) fn covfun_section_name(llmod: &llvm::Module) -> CString {
23 CString::new(llvm::build_byte_buffer(|s| {
24 llvm::LLVMRustCoverageWriteCovfunSectionNameToString(llmod, s);
25 }))
26 .expect("covfun section name should not contain NUL")
27}
28
29pub(crate) fn create_pgo_func_name_var<'ll>(
30 llfn: &'ll llvm::Value,
31 mangled_fn_name: &str,
32) -> &'ll llvm::Value {
33 unsafe {
34 llvm::LLVMRustCoverageCreatePGOFuncNameVar(
35 llfn,
36 mangled_fn_name.as_ptr(),
37 mangled_fn_name.len(),
38 )
39 }
40}
41
42pub(crate) fn write_filenames_to_buffer(filenames: &[impl AsRef<str>]) -> Vec<u8> {
43 let (pointers, lengths) = filenames
44 .into_iter()
45 .map(AsRef::as_ref)
46 .map(|s: &str| (s.as_ptr(), s.len()))
47 .unzip::<_, _, Vec<_>, Vec<_>>();
48
49 llvm::build_byte_buffer(|buffer| unsafe {
50 llvm::LLVMRustCoverageWriteFilenamesToBuffer(
51 pointers.as_ptr(),
52 pointers.len(),
53 lengths.as_ptr(),
54 lengths.len(),
55 buffer,
56 );
57 })
58}
59
60#[derive(Clone, Debug, Default)]
68pub(crate) struct Regions {
69 pub(crate) code_regions: Vec<ffi::CodeRegion>,
70 pub(crate) expansion_regions: Vec<ffi::ExpansionRegion>,
71 pub(crate) branch_regions: Vec<ffi::BranchRegion>,
72}
73
74impl Regions {
75 pub(crate) fn has_no_regions(&self) -> bool {
77 let Self { code_regions, expansion_regions, branch_regions } = self;
78
79 code_regions.is_empty() && expansion_regions.is_empty() && branch_regions.is_empty()
80 }
81}
82
83pub(crate) fn write_function_mappings_to_buffer(
84 virtual_file_mapping: &[u32],
85 expressions: &[ffi::CounterExpression],
86 regions: &Regions,
87) -> Vec<u8> {
88 let Regions { code_regions, expansion_regions, branch_regions } = regions;
89
90 llvm::build_byte_buffer(|buffer| unsafe {
95 llvm::LLVMRustCoverageWriteFunctionMappingsToBuffer(
96 virtual_file_mapping.as_ptr(),
97 virtual_file_mapping.len(),
98 expressions.as_ptr(),
99 expressions.len(),
100 code_regions.as_ptr(),
101 code_regions.len(),
102 expansion_regions.as_ptr(),
103 expansion_regions.len(),
104 branch_regions.as_ptr(),
105 branch_regions.len(),
106 buffer,
107 )
108 })
109}
110
111pub(crate) fn hash_bytes(bytes: &[u8]) -> u64 {
114 unsafe { llvm::LLVMRustCoverageHashBytes(bytes.as_ptr(), bytes.len()) }
115}
116
117pub(crate) fn mapping_version() -> u32 {
121 llvm::LLVMRustCoverageMappingVersion()
122}