1 //! Cranelift code generation library. 2 #![deny(missing_docs)] 3 // Display feature requirements in the documentation when building on docs.rs 4 #![cfg_attr(docsrs, feature(doc_auto_cfg))] 5 #![no_std] 6 // Various bits and pieces of this crate might only be used for one platform or 7 // another, but it's not really too useful to learn about that all the time. On 8 // CI we build at least one version of this crate with `--features all-arch` 9 // which means we'll always detect truly dead code, otherwise if this is only 10 // built for one platform we don't have to worry too much about trimming 11 // everything down. 12 #![cfg_attr( 13 not(feature = "all-arch"), 14 allow(dead_code, reason = "see comment above") 15 )] 16 17 extern crate alloc; 18 19 #[cfg(feature = "std")] 20 #[macro_use] 21 extern crate std; 22 23 #[cfg(not(feature = "std"))] 24 use hashbrown::{HashMap, HashSet, hash_map}; 25 #[cfg(feature = "std")] 26 use std::collections::{HashMap, HashSet, hash_map}; 27 28 pub use crate::context::Context; 29 pub use crate::value_label::{LabelValueLoc, ValueLabelsRanges, ValueLocRange}; 30 pub use crate::verifier::verify_function; 31 pub use crate::write::write_function; 32 33 pub use cranelift_bforest as bforest; 34 pub use cranelift_bitset as bitset; 35 pub use cranelift_control as control; 36 pub use cranelift_entity as entity; 37 #[cfg(feature = "unwind")] 38 pub use gimli; 39 40 // Pull in generated the `isle_numerics_methods` macro. 41 include!(concat!(env!("ISLE_DIR"), "/isle_numerics.rs")); 42 43 #[macro_use] 44 mod machinst; 45 46 pub mod binemit; 47 pub mod cfg_printer; 48 pub mod cursor; 49 pub mod data_value; 50 pub mod dbg; 51 pub mod dominator_tree; 52 pub mod flowgraph; 53 pub mod inline; 54 pub mod ir; 55 pub mod isa; 56 pub mod loop_analysis; 57 pub mod print_errors; 58 pub mod settings; 59 pub mod timing; 60 pub mod traversals; 61 pub mod verifier; 62 pub mod write; 63 64 pub use crate::entity::packed_option; 65 pub use crate::machinst::buffer::{ 66 FinalizedMachCallSite, FinalizedMachReloc, FinalizedRelocTarget, MachCallSite, MachSrcLoc, 67 MachTextSectionBuilder, MachTrap, OpenPatchRegion, PatchRegion, 68 }; 69 pub use crate::machinst::{ 70 CallInfo, CompiledCode, Final, MachBuffer, MachBufferFinalized, MachInst, MachInstEmit, 71 MachInstEmitState, MachLabel, RealReg, Reg, RelocDistance, TextSectionBuilder, VCodeConstant, 72 VCodeConstantData, VCodeConstants, VCodeInst, Writable, 73 }; 74 75 mod alias_analysis; 76 mod constant_hash; 77 mod context; 78 mod ctxhash; 79 mod egraph; 80 mod inst_predicates; 81 mod isle_prelude; 82 mod legalizer; 83 mod nan_canonicalization; 84 mod opts; 85 mod ranges; 86 mod remove_constant_phis; 87 mod result; 88 mod scoped_hash_map; 89 mod take_and_replace; 90 mod unreachable_code; 91 mod value_label; 92 93 #[cfg(feature = "souper-harvest")] 94 mod souper_harvest; 95 96 pub use crate::result::{CodegenError, CodegenResult, CompileError}; 97 pub use crate::take_and_replace::TakeAndReplace; 98 99 #[cfg(feature = "incremental-cache")] 100 pub mod incremental_cache; 101 102 /// Even when trace logging is disabled, the trace macro has a significant performance cost so we 103 /// disable it by default. 104 #[macro_export] 105 macro_rules! trace { 106 ($($tt:tt)*) => { 107 if cfg!(any(feature = "trace-log", debug_assertions)) { 108 ::log::trace!($($tt)*); 109 } 110 }; 111 } 112 113 /// Dynamic check for whether trace logging is enabled. 114 #[macro_export] 115 macro_rules! trace_log_enabled { 116 () => { 117 cfg!(any(feature = "trace-log", debug_assertions)) 118 && ::log::log_enabled!(::log::Level::Trace) 119 }; 120 } 121 122 include!(concat!(env!("OUT_DIR"), "/version.rs")); 123