mirror of
				https://github.com/rust-lang/rust.git
				synced 2025-10-30 20:44:34 +00:00 
			
		
		
		
	 a98546b961
			
		
	
	
		a98546b961
		
	
	
	
	
		
			
			Adds KCFI arity indicator support to the Rust compiler (see rust-lang/rust#138311, https://github.com/llvm/llvm-project/pull/121070, and https://lore.kernel.org/lkml/CANiq72=3ghFxy8E=AU9p+0imFxKr5iU3sd0hVUXed5BA+KjdNQ@mail.gmail.com/).
		
			
				
	
	
		
			224 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			224 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| use std::ffi::CString;
 | |
| use std::path::Path;
 | |
| 
 | |
| use rustc_data_structures::small_c_str::SmallCStr;
 | |
| use rustc_errors::{Diag, DiagCtxtHandle, Diagnostic, EmissionGuarantee, Level};
 | |
| use rustc_macros::{Diagnostic, Subdiagnostic};
 | |
| use rustc_span::Span;
 | |
| 
 | |
| use crate::fluent_generated as fluent;
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_unknown_ctarget_feature_prefix)]
 | |
| #[note]
 | |
| pub(crate) struct UnknownCTargetFeaturePrefix<'a> {
 | |
|     pub feature: &'a str,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_unknown_ctarget_feature)]
 | |
| #[note]
 | |
| pub(crate) struct UnknownCTargetFeature<'a> {
 | |
|     pub feature: &'a str,
 | |
|     #[subdiagnostic]
 | |
|     pub rust_feature: PossibleFeature<'a>,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_unstable_ctarget_feature)]
 | |
| #[note]
 | |
| pub(crate) struct UnstableCTargetFeature<'a> {
 | |
|     pub feature: &'a str,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_forbidden_ctarget_feature)]
 | |
| #[note]
 | |
| #[note(codegen_llvm_forbidden_ctarget_feature_issue)]
 | |
| pub(crate) struct ForbiddenCTargetFeature<'a> {
 | |
|     pub feature: &'a str,
 | |
|     pub enabled: &'a str,
 | |
|     pub reason: &'a str,
 | |
| }
 | |
| 
 | |
| #[derive(Subdiagnostic)]
 | |
| pub(crate) enum PossibleFeature<'a> {
 | |
|     #[help(codegen_llvm_possible_feature)]
 | |
|     Some { rust_feature: &'a str },
 | |
|     #[help(codegen_llvm_consider_filing_feature_request)]
 | |
|     None,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_symbol_already_defined)]
 | |
| pub(crate) struct SymbolAlreadyDefined<'a> {
 | |
|     #[primary_span]
 | |
|     pub span: Span,
 | |
|     pub symbol_name: &'a str,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_invalid_minimum_alignment_not_power_of_two)]
 | |
| pub(crate) struct InvalidMinimumAlignmentNotPowerOfTwo {
 | |
|     pub align: u64,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_invalid_minimum_alignment_too_large)]
 | |
| pub(crate) struct InvalidMinimumAlignmentTooLarge {
 | |
|     pub align: u64,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_sanitizer_memtag_requires_mte)]
 | |
| pub(crate) struct SanitizerMemtagRequiresMte;
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_dynamic_linking_with_lto)]
 | |
| #[note]
 | |
| pub(crate) struct DynamicLinkingWithLTO;
 | |
| 
 | |
| pub(crate) struct ParseTargetMachineConfig<'a>(pub LlvmError<'a>);
 | |
| 
 | |
| impl<G: EmissionGuarantee> Diagnostic<'_, G> for ParseTargetMachineConfig<'_> {
 | |
|     fn into_diag(self, dcx: DiagCtxtHandle<'_>, level: Level) -> Diag<'_, G> {
 | |
|         let diag: Diag<'_, G> = self.0.into_diag(dcx, level);
 | |
|         let (message, _) = diag.messages.first().expect("`LlvmError` with no message");
 | |
|         let message = dcx.eagerly_translate_to_string(message.clone(), diag.args.iter());
 | |
|         Diag::new(dcx, level, fluent::codegen_llvm_parse_target_machine_config)
 | |
|             .with_arg("error", message)
 | |
|     }
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_autodiff_without_lto)]
 | |
| pub(crate) struct AutoDiffWithoutLTO;
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_autodiff_without_enable)]
 | |
| pub(crate) struct AutoDiffWithoutEnable;
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_lto_disallowed)]
 | |
| pub(crate) struct LtoDisallowed;
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_lto_dylib)]
 | |
| pub(crate) struct LtoDylib;
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_lto_proc_macro)]
 | |
| pub(crate) struct LtoProcMacro;
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_lto_bitcode_from_rlib)]
 | |
| pub(crate) struct LtoBitcodeFromRlib {
 | |
|     pub llvm_err: String,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| pub enum LlvmError<'a> {
 | |
|     #[diag(codegen_llvm_write_output)]
 | |
|     WriteOutput { path: &'a Path },
 | |
|     #[diag(codegen_llvm_target_machine)]
 | |
|     CreateTargetMachine { triple: SmallCStr },
 | |
|     #[diag(codegen_llvm_run_passes)]
 | |
|     RunLlvmPasses,
 | |
|     #[diag(codegen_llvm_serialize_module)]
 | |
|     SerializeModule { name: &'a str },
 | |
|     #[diag(codegen_llvm_write_ir)]
 | |
|     WriteIr { path: &'a Path },
 | |
|     #[diag(codegen_llvm_prepare_thin_lto_context)]
 | |
|     PrepareThinLtoContext,
 | |
|     #[diag(codegen_llvm_load_bitcode)]
 | |
|     LoadBitcode { name: CString },
 | |
|     #[diag(codegen_llvm_write_thinlto_key)]
 | |
|     WriteThinLtoKey { err: std::io::Error },
 | |
|     #[diag(codegen_llvm_prepare_thin_lto_module)]
 | |
|     PrepareThinLtoModule,
 | |
|     #[diag(codegen_llvm_parse_bitcode)]
 | |
|     ParseBitcode,
 | |
|     #[diag(codegen_llvm_prepare_autodiff)]
 | |
|     PrepareAutoDiff { src: String, target: String, error: String },
 | |
| }
 | |
| 
 | |
| pub(crate) struct WithLlvmError<'a>(pub LlvmError<'a>, pub String);
 | |
| 
 | |
| impl<G: EmissionGuarantee> Diagnostic<'_, G> for WithLlvmError<'_> {
 | |
|     fn into_diag(self, dcx: DiagCtxtHandle<'_>, level: Level) -> Diag<'_, G> {
 | |
|         use LlvmError::*;
 | |
|         let msg_with_llvm_err = match &self.0 {
 | |
|             WriteOutput { .. } => fluent::codegen_llvm_write_output_with_llvm_err,
 | |
|             CreateTargetMachine { .. } => fluent::codegen_llvm_target_machine_with_llvm_err,
 | |
|             RunLlvmPasses => fluent::codegen_llvm_run_passes_with_llvm_err,
 | |
|             SerializeModule { .. } => fluent::codegen_llvm_serialize_module_with_llvm_err,
 | |
|             WriteIr { .. } => fluent::codegen_llvm_write_ir_with_llvm_err,
 | |
|             PrepareThinLtoContext => fluent::codegen_llvm_prepare_thin_lto_context_with_llvm_err,
 | |
|             LoadBitcode { .. } => fluent::codegen_llvm_load_bitcode_with_llvm_err,
 | |
|             WriteThinLtoKey { .. } => fluent::codegen_llvm_write_thinlto_key_with_llvm_err,
 | |
|             PrepareThinLtoModule => fluent::codegen_llvm_prepare_thin_lto_module_with_llvm_err,
 | |
|             ParseBitcode => fluent::codegen_llvm_parse_bitcode_with_llvm_err,
 | |
|             PrepareAutoDiff { .. } => fluent::codegen_llvm_prepare_autodiff_with_llvm_err,
 | |
|         };
 | |
|         self.0
 | |
|             .into_diag(dcx, level)
 | |
|             .with_primary_message(msg_with_llvm_err)
 | |
|             .with_arg("llvm_err", self.1)
 | |
|     }
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_from_llvm_optimization_diag)]
 | |
| pub(crate) struct FromLlvmOptimizationDiag<'a> {
 | |
|     pub filename: &'a str,
 | |
|     pub line: std::ffi::c_uint,
 | |
|     pub column: std::ffi::c_uint,
 | |
|     pub pass_name: &'a str,
 | |
|     pub kind: &'a str,
 | |
|     pub message: &'a str,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_from_llvm_diag)]
 | |
| pub(crate) struct FromLlvmDiag {
 | |
|     pub message: String,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_write_bytecode)]
 | |
| pub(crate) struct WriteBytecode<'a> {
 | |
|     pub path: &'a Path,
 | |
|     pub err: std::io::Error,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_copy_bitcode)]
 | |
| pub(crate) struct CopyBitcode {
 | |
|     pub err: std::io::Error,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_unknown_debuginfo_compression)]
 | |
| pub(crate) struct UnknownCompression {
 | |
|     pub algorithm: &'static str,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_mismatch_data_layout)]
 | |
| pub(crate) struct MismatchedDataLayout<'a> {
 | |
|     pub rustc_target: &'a str,
 | |
|     pub rustc_layout: &'a str,
 | |
|     pub llvm_target: &'a str,
 | |
|     pub llvm_layout: &'a str,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_fixed_x18_invalid_arch)]
 | |
| pub(crate) struct FixedX18InvalidArch<'a> {
 | |
|     pub arch: &'a str,
 | |
| }
 | |
| 
 | |
| #[derive(Diagnostic)]
 | |
| #[diag(codegen_llvm_sanitizer_kcfi_arity_requires_llvm_21_0_0)]
 | |
| pub(crate) struct SanitizerKcfiArityRequiresLLVM2100;
 |