Replace the isa::Legalize enumeration with a function pointer. This allows an ISA to define its own specific legalization actions instead of relying on the default two. Generate a LEGALIZE_ACTIONS table for each ISA which contains legalization function pointers indexed by the legalization codes that are already in the encoding tables. Include this table in isa/*/enc_tables.rs. Give the `Encodings` iterator a reference to the action table and change its `legalize()` method to return a function pointer instead of an ISA-specific code. The Result<> returned from TargetIsa::encode() no longer implements Debug, so eliminate uses of unwrap and expect on that type.
11 lines
259 B
Rust
11 lines
259 B
Rust
//! Encoding tables for ARM64 ISA.
|
|
|
|
use ir::types;
|
|
use isa;
|
|
use isa::constraints::*;
|
|
use isa::enc_tables::*;
|
|
use isa::encoding::RecipeSizing;
|
|
|
|
include!(concat!(env!("OUT_DIR"), "/encoding-arm64.rs"));
|
|
include!(concat!(env!("OUT_DIR"), "/legalize-arm64.rs"));
|