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