2014-09-12 15:17:58 +00:00
|
|
|
//! LLVM diagnostic reports.
|
|
|
|
|
2014-11-06 08:05:53 +00:00
|
|
|
pub use self::Diagnostic::*;
|
2019-12-22 22:42:04 +00:00
|
|
|
pub use self::OptimizationDiagnosticKind::*;
|
2014-11-06 08:05:53 +00:00
|
|
|
|
2019-02-17 18:58:58 +00:00
|
|
|
use crate::value::Value;
|
2019-12-22 22:42:04 +00:00
|
|
|
use libc::c_uint;
|
2014-09-12 15:17:58 +00:00
|
|
|
|
2018-07-13 10:59:41 +00:00
|
|
|
use super::{DiagnosticInfo, Twine};
|
2014-09-12 15:17:58 +00:00
|
|
|
|
2015-03-30 13:38:44 +00:00
|
|
|
#[derive(Copy, Clone)]
|
2014-09-12 15:17:58 +00:00
|
|
|
pub enum OptimizationDiagnosticKind {
|
|
|
|
OptimizationRemark,
|
|
|
|
OptimizationMissed,
|
|
|
|
OptimizationAnalysis,
|
2016-08-01 23:35:09 +00:00
|
|
|
OptimizationAnalysisFPCommute,
|
|
|
|
OptimizationAnalysisAliasing,
|
2014-09-12 15:17:58 +00:00
|
|
|
OptimizationFailure,
|
2016-08-01 23:35:09 +00:00
|
|
|
OptimizationRemarkOther,
|
2014-09-12 15:17:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl OptimizationDiagnosticKind {
|
|
|
|
pub fn describe(self) -> &'static str {
|
|
|
|
match self {
|
2016-10-22 13:07:35 +00:00
|
|
|
OptimizationRemark | OptimizationRemarkOther => "remark",
|
2014-09-12 15:17:58 +00:00
|
|
|
OptimizationMissed => "missed",
|
|
|
|
OptimizationAnalysis => "analysis",
|
2016-08-01 23:35:09 +00:00
|
|
|
OptimizationAnalysisFPCommute => "floating-point",
|
|
|
|
OptimizationAnalysisAliasing => "aliasing",
|
2014-09-12 15:17:58 +00:00
|
|
|
OptimizationFailure => "failure",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-10 10:28:39 +00:00
|
|
|
pub struct OptimizationDiagnostic<'ll> {
|
2014-09-12 15:17:58 +00:00
|
|
|
pub kind: OptimizationDiagnosticKind,
|
2016-11-28 14:15:51 +00:00
|
|
|
pub pass_name: String,
|
2018-07-10 10:28:39 +00:00
|
|
|
pub function: &'ll Value,
|
2017-07-21 12:29:23 +00:00
|
|
|
pub line: c_uint,
|
|
|
|
pub column: c_uint,
|
|
|
|
pub filename: String,
|
2016-11-24 16:33:47 +00:00
|
|
|
pub message: String,
|
2014-09-12 15:17:58 +00:00
|
|
|
}
|
|
|
|
|
2018-07-10 10:28:39 +00:00
|
|
|
impl OptimizationDiagnostic<'ll> {
|
2019-12-22 22:42:04 +00:00
|
|
|
unsafe fn unpack(kind: OptimizationDiagnosticKind, di: &'ll DiagnosticInfo) -> Self {
|
2018-07-10 10:28:39 +00:00
|
|
|
let mut function = None;
|
2017-07-21 12:29:23 +00:00
|
|
|
let mut line = 0;
|
|
|
|
let mut column = 0;
|
2014-09-12 15:17:58 +00:00
|
|
|
|
2016-11-28 14:15:51 +00:00
|
|
|
let mut message = None;
|
2017-07-21 12:29:23 +00:00
|
|
|
let mut filename = None;
|
2019-12-22 22:42:04 +00:00
|
|
|
let pass_name = super::build_string(|pass_name| {
|
|
|
|
message = super::build_string(|message| {
|
|
|
|
filename = super::build_string(|filename| {
|
|
|
|
super::LLVMRustUnpackOptimizationDiagnostic(
|
|
|
|
di,
|
|
|
|
pass_name,
|
|
|
|
&mut function,
|
|
|
|
&mut line,
|
|
|
|
&mut column,
|
|
|
|
filename,
|
|
|
|
message,
|
|
|
|
)
|
|
|
|
})
|
|
|
|
.ok()
|
|
|
|
})
|
|
|
|
.ok()
|
|
|
|
})
|
|
|
|
.ok();
|
2014-09-12 15:17:58 +00:00
|
|
|
|
2018-10-12 14:16:00 +00:00
|
|
|
let mut filename = filename.unwrap_or_default();
|
2017-07-21 12:29:23 +00:00
|
|
|
if filename.is_empty() {
|
|
|
|
filename.push_str("<unknown file>");
|
|
|
|
}
|
|
|
|
|
2016-11-24 16:33:47 +00:00
|
|
|
OptimizationDiagnostic {
|
2017-08-07 05:54:09 +00:00
|
|
|
kind,
|
2016-11-28 14:15:51 +00:00
|
|
|
pass_name: pass_name.expect("got a non-UTF8 pass name from LLVM"),
|
2018-07-10 10:28:39 +00:00
|
|
|
function: function.unwrap(),
|
2017-08-07 05:54:09 +00:00
|
|
|
line,
|
|
|
|
column,
|
|
|
|
filename,
|
2019-12-22 22:42:04 +00:00
|
|
|
message: message.expect("got a non-UTF8 OptimizationDiagnostic message from LLVM"),
|
2016-11-24 16:33:47 +00:00
|
|
|
}
|
2014-09-12 15:17:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-30 13:38:44 +00:00
|
|
|
#[derive(Copy, Clone)]
|
2018-07-10 10:28:39 +00:00
|
|
|
pub struct InlineAsmDiagnostic<'ll> {
|
2015-01-22 18:43:39 +00:00
|
|
|
pub cookie: c_uint,
|
2018-07-13 10:59:41 +00:00
|
|
|
pub message: &'ll Twine,
|
2018-10-19 00:34:01 +00:00
|
|
|
pub instruction: Option<&'ll Value>,
|
2015-01-22 18:43:39 +00:00
|
|
|
}
|
|
|
|
|
2018-07-10 10:28:39 +00:00
|
|
|
impl InlineAsmDiagnostic<'ll> {
|
2018-07-13 10:59:41 +00:00
|
|
|
unsafe fn unpack(di: &'ll DiagnosticInfo) -> Self {
|
2018-07-10 10:28:39 +00:00
|
|
|
let mut cookie = 0;
|
2018-07-13 10:59:41 +00:00
|
|
|
let mut message = None;
|
2018-07-10 10:28:39 +00:00
|
|
|
let mut instruction = None;
|
|
|
|
|
2019-12-22 22:42:04 +00:00
|
|
|
super::LLVMRustUnpackInlineAsmDiagnostic(di, &mut cookie, &mut message, &mut instruction);
|
|
|
|
|
|
|
|
InlineAsmDiagnostic { cookie, message: message.unwrap(), instruction }
|
2015-01-22 18:43:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-10 10:28:39 +00:00
|
|
|
pub enum Diagnostic<'ll> {
|
|
|
|
Optimization(OptimizationDiagnostic<'ll>),
|
|
|
|
InlineAsm(InlineAsmDiagnostic<'ll>),
|
2018-07-13 10:59:41 +00:00
|
|
|
PGO(&'ll DiagnosticInfo),
|
2018-07-17 23:20:51 +00:00
|
|
|
Linker(&'ll DiagnosticInfo),
|
2014-09-12 15:17:58 +00:00
|
|
|
|
|
|
|
/// LLVM has other types that we do not wrap here.
|
2018-07-13 10:59:41 +00:00
|
|
|
UnknownDiagnostic(&'ll DiagnosticInfo),
|
2014-09-12 15:17:58 +00:00
|
|
|
}
|
|
|
|
|
2018-07-10 10:28:39 +00:00
|
|
|
impl Diagnostic<'ll> {
|
2018-07-13 10:59:41 +00:00
|
|
|
pub unsafe fn unpack(di: &'ll DiagnosticInfo) -> Self {
|
2016-08-01 23:35:09 +00:00
|
|
|
use super::DiagnosticKind as Dk;
|
|
|
|
let kind = super::LLVMRustGetDiagInfoKind(di);
|
2014-09-12 15:17:58 +00:00
|
|
|
|
|
|
|
match kind {
|
2016-08-01 23:35:09 +00:00
|
|
|
Dk::InlineAsm => InlineAsm(InlineAsmDiagnostic::unpack(di)),
|
2015-01-22 18:43:39 +00:00
|
|
|
|
2016-08-01 23:35:09 +00:00
|
|
|
Dk::OptimizationRemark => {
|
2016-05-29 09:27:34 +00:00
|
|
|
Optimization(OptimizationDiagnostic::unpack(OptimizationRemark, di))
|
|
|
|
}
|
2016-08-01 23:35:09 +00:00
|
|
|
Dk::OptimizationRemarkOther => {
|
|
|
|
Optimization(OptimizationDiagnostic::unpack(OptimizationRemarkOther, di))
|
|
|
|
}
|
|
|
|
Dk::OptimizationRemarkMissed => {
|
2016-05-29 09:27:34 +00:00
|
|
|
Optimization(OptimizationDiagnostic::unpack(OptimizationMissed, di))
|
|
|
|
}
|
2014-09-12 15:17:58 +00:00
|
|
|
|
2016-08-01 23:35:09 +00:00
|
|
|
Dk::OptimizationRemarkAnalysis => {
|
2016-05-29 09:27:34 +00:00
|
|
|
Optimization(OptimizationDiagnostic::unpack(OptimizationAnalysis, di))
|
|
|
|
}
|
2014-09-12 15:17:58 +00:00
|
|
|
|
2016-08-01 23:35:09 +00:00
|
|
|
Dk::OptimizationRemarkAnalysisFPCommute => {
|
2016-10-22 13:07:35 +00:00
|
|
|
Optimization(OptimizationDiagnostic::unpack(OptimizationAnalysisFPCommute, di))
|
2016-08-01 23:35:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Dk::OptimizationRemarkAnalysisAliasing => {
|
2016-10-22 13:07:35 +00:00
|
|
|
Optimization(OptimizationDiagnostic::unpack(OptimizationAnalysisAliasing, di))
|
2016-08-01 23:35:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Dk::OptimizationFailure => {
|
2016-05-29 09:27:34 +00:00
|
|
|
Optimization(OptimizationDiagnostic::unpack(OptimizationFailure, di))
|
|
|
|
}
|
2014-09-12 15:17:58 +00:00
|
|
|
|
2019-12-22 22:42:04 +00:00
|
|
|
Dk::PGOProfile => PGO(di),
|
|
|
|
Dk::Linker => Linker(di),
|
2018-03-12 17:11:59 +00:00
|
|
|
|
2016-05-29 09:27:34 +00:00
|
|
|
_ => UnknownDiagnostic(di),
|
2014-09-12 15:17:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|