use crate::cdsl::cpu_modes::CpuMode; use crate::cdsl::isa::TargetIsa; use crate::cdsl::types::{ReferenceType, VectorType}; use crate::shared::types::Bool::B1; use crate::shared::types::Float::{F32, F64}; use crate::shared::types::Int::{I16, I32, I64, I8}; use crate::shared::types::Reference::{R32, R64}; use crate::shared::Definitions as SharedDefinitions; mod encodings; mod instructions; mod legalize; mod opcodes; mod recipes; mod registers; pub(crate) mod settings; pub(crate) fn define(shared_defs: &mut SharedDefinitions) -> TargetIsa { let settings = settings::define(&shared_defs.settings); let regs = registers::define(); let inst_group = instructions::define( &mut shared_defs.all_instructions, &shared_defs.formats, &shared_defs.imm, &shared_defs.entities, ); legalize::define(shared_defs, &inst_group); // CPU modes for 32-bit and 64-bit operations. let mut x86_64 = CpuMode::new("I64"); let mut x86_32 = CpuMode::new("I32"); let expand_flags = shared_defs.transform_groups.by_name("expand_flags"); let x86_widen = shared_defs.transform_groups.by_name("x86_widen"); let x86_narrow = shared_defs.transform_groups.by_name("x86_narrow"); let x86_narrow_avx = shared_defs.transform_groups.by_name("x86_narrow_avx"); let x86_expand = shared_defs.transform_groups.by_name("x86_expand"); x86_32.legalize_monomorphic(expand_flags); x86_32.legalize_default(x86_narrow); x86_32.legalize_type(B1, expand_flags); x86_32.legalize_type(I8, x86_widen); x86_32.legalize_type(I16, x86_widen); x86_32.legalize_type(I32, x86_expand); x86_32.legalize_value_type(ReferenceType(R32), x86_expand); x86_32.legalize_type(F32, x86_expand); x86_32.legalize_type(F64, x86_expand); x86_32.legalize_value_type(VectorType::new(I32.into(), 4), x86_narrow_avx); x86_32.legalize_value_type(VectorType::new(I64.into(), 2), x86_narrow_avx); x86_32.legalize_value_type(VectorType::new(F32.into(), 4), x86_narrow_avx); x86_64.legalize_monomorphic(expand_flags); x86_64.legalize_default(x86_narrow); x86_64.legalize_type(B1, expand_flags); x86_64.legalize_type(I8, x86_widen); x86_64.legalize_type(I16, x86_widen); x86_64.legalize_type(I32, x86_expand); x86_64.legalize_type(I64, x86_expand); x86_64.legalize_value_type(ReferenceType(R64), x86_expand); x86_64.legalize_type(F32, x86_expand); x86_64.legalize_type(F64, x86_expand); x86_64.legalize_value_type(VectorType::new(I32.into(), 4), x86_narrow_avx); x86_64.legalize_value_type(VectorType::new(I64.into(), 2), x86_narrow_avx); x86_64.legalize_value_type(VectorType::new(F32.into(), 4), x86_narrow_avx); let recipes = recipes::define(shared_defs, &settings, ®s); let encodings = encodings::define(shared_defs, &settings, &inst_group, &recipes); x86_32.set_encodings(encodings.enc32); x86_64.set_encodings(encodings.enc64); let encodings_predicates = encodings.inst_pred_reg.extract(); let recipes = encodings.recipes; let cpu_modes = vec![x86_64, x86_32]; TargetIsa::new( "x86", settings, regs, recipes, cpu_modes, encodings_predicates, ) }