pull/1017/merge^2
Davide Bertola 4 months ago
parent a9175127e9
commit 8b2ef5d5c1

@ -544,23 +544,24 @@ impl Btf {
target_var_name: &str, target_var_name: &str,
) -> Result<(String, Var), BtfError> { ) -> Result<(String, Var), BtfError> {
for t in &self.types.types { for t in &self.types.types {
if let BtfType::DataSec(d) = t { let BtfType::DataSec(d) = t else {
continue;
};
let sec_name = self.string_at(d.name_offset)?; let sec_name = self.string_at(d.name_offset)?;
for d in &d.entries { for d in &d.entries {
if let BtfType::Var(var) = self.types.type_by_id(d.btf_type)? { let BtfType::Var(var) = self.types.type_by_id(d.btf_type)? else {
let var_name = self.string_at(var.name_offset)?; continue;
};
if target_var_name == var_name { if target_var_name == self.string_at(var.name_offset)? {
if var.linkage != VarLinkage::Extern { if var.linkage == VarLinkage::Extern {
return Ok((sec_name.into(), var.clone()));
} else {
return Err(BtfError::InvalidExternalSymbol { return Err(BtfError::InvalidExternalSymbol {
symbol_name: var_name.into(), symbol_name: target_var_name.into(),
}); });
} }
return Ok((sec_name.into(), var.clone()));
}
}
} }
} }
} }

Loading…
Cancel
Save