mirror of
https://github.com/roc-lang/roc.git
synced 2025-10-02 16:21:11 +00:00
gen_dev working
This commit is contained in:
parent
123c963ff1
commit
02d4828946
2 changed files with 30 additions and 22 deletions
|
@ -1,5 +1,6 @@
|
||||||
use crate::{Backend, Env, Relocation};
|
use crate::{Backend, Env, Relocation};
|
||||||
use bumpalo::collections::Vec;
|
use bumpalo::collections::Vec;
|
||||||
|
use roc_builtins::bitcode::{FloatWidth, IntWidth};
|
||||||
use roc_collections::all::{MutMap, MutSet};
|
use roc_collections::all::{MutMap, MutSet};
|
||||||
use roc_module::symbol::Symbol;
|
use roc_module::symbol::Symbol;
|
||||||
use roc_mono::ir::{BranchInfo, JoinPointId, Literal, Param, SelfRecursive, Stmt};
|
use roc_mono::ir::{BranchInfo, JoinPointId, Literal, Param, SelfRecursive, Stmt};
|
||||||
|
@ -493,12 +494,12 @@ impl<
|
||||||
|
|
||||||
// move return value to dst.
|
// move return value to dst.
|
||||||
match ret_layout {
|
match ret_layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let dst_reg = self.claim_general_reg(dst)?;
|
let dst_reg = self.claim_general_reg(dst)?;
|
||||||
ASM::mov_reg64_reg64(&mut self.buf, dst_reg, CC::GENERAL_RETURN_REGS[0]);
|
ASM::mov_reg64_reg64(&mut self.buf, dst_reg, CC::GENERAL_RETURN_REGS[0]);
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
Layout::Builtin(Builtin::Float64) => {
|
Layout::Builtin(Builtin::Float(FloatWidth::F64)) => {
|
||||||
let dst_reg = self.claim_float_reg(dst)?;
|
let dst_reg = self.claim_float_reg(dst)?;
|
||||||
ASM::mov_freg64_freg64(&mut self.buf, dst_reg, CC::FLOAT_RETURN_REGS[0]);
|
ASM::mov_freg64_freg64(&mut self.buf, dst_reg, CC::FLOAT_RETURN_REGS[0]);
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -733,13 +734,13 @@ impl<
|
||||||
layout: &Layout<'a>,
|
layout: &Layout<'a>,
|
||||||
) -> Result<(), String> {
|
) -> Result<(), String> {
|
||||||
match layout {
|
match layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let dst_reg = self.claim_general_reg(dst)?;
|
let dst_reg = self.claim_general_reg(dst)?;
|
||||||
let src_reg = self.load_to_general_reg(src)?;
|
let src_reg = self.load_to_general_reg(src)?;
|
||||||
ASM::abs_reg64_reg64(&mut self.buf, dst_reg, src_reg);
|
ASM::abs_reg64_reg64(&mut self.buf, dst_reg, src_reg);
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
Layout::Builtin(Builtin::Float64) => {
|
Layout::Builtin(Builtin::Float(FloatWidth::F64)) => {
|
||||||
let dst_reg = self.claim_float_reg(dst)?;
|
let dst_reg = self.claim_float_reg(dst)?;
|
||||||
let src_reg = self.load_to_float_reg(src)?;
|
let src_reg = self.load_to_float_reg(src)?;
|
||||||
ASM::abs_freg64_freg64(&mut self.buf, &mut self.relocs, dst_reg, src_reg);
|
ASM::abs_freg64_freg64(&mut self.buf, &mut self.relocs, dst_reg, src_reg);
|
||||||
|
@ -757,14 +758,14 @@ impl<
|
||||||
layout: &Layout<'a>,
|
layout: &Layout<'a>,
|
||||||
) -> Result<(), String> {
|
) -> Result<(), String> {
|
||||||
match layout {
|
match layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let dst_reg = self.claim_general_reg(dst)?;
|
let dst_reg = self.claim_general_reg(dst)?;
|
||||||
let src1_reg = self.load_to_general_reg(src1)?;
|
let src1_reg = self.load_to_general_reg(src1)?;
|
||||||
let src2_reg = self.load_to_general_reg(src2)?;
|
let src2_reg = self.load_to_general_reg(src2)?;
|
||||||
ASM::add_reg64_reg64_reg64(&mut self.buf, dst_reg, src1_reg, src2_reg);
|
ASM::add_reg64_reg64_reg64(&mut self.buf, dst_reg, src1_reg, src2_reg);
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
Layout::Builtin(Builtin::Float64) => {
|
Layout::Builtin(Builtin::Float(FloatWidth::F64)) => {
|
||||||
let dst_reg = self.claim_float_reg(dst)?;
|
let dst_reg = self.claim_float_reg(dst)?;
|
||||||
let src1_reg = self.load_to_float_reg(src1)?;
|
let src1_reg = self.load_to_float_reg(src1)?;
|
||||||
let src2_reg = self.load_to_float_reg(src2)?;
|
let src2_reg = self.load_to_float_reg(src2)?;
|
||||||
|
@ -783,7 +784,7 @@ impl<
|
||||||
layout: &Layout<'a>,
|
layout: &Layout<'a>,
|
||||||
) -> Result<(), String> {
|
) -> Result<(), String> {
|
||||||
match layout {
|
match layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let dst_reg = self.claim_general_reg(dst)?;
|
let dst_reg = self.claim_general_reg(dst)?;
|
||||||
let src1_reg = self.load_to_general_reg(src1)?;
|
let src1_reg = self.load_to_general_reg(src1)?;
|
||||||
let src2_reg = self.load_to_general_reg(src2)?;
|
let src2_reg = self.load_to_general_reg(src2)?;
|
||||||
|
@ -801,7 +802,7 @@ impl<
|
||||||
layout: &Layout<'a>,
|
layout: &Layout<'a>,
|
||||||
) -> Result<(), String> {
|
) -> Result<(), String> {
|
||||||
match layout {
|
match layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let dst_reg = self.claim_general_reg(dst)?;
|
let dst_reg = self.claim_general_reg(dst)?;
|
||||||
let src_reg = self.load_to_general_reg(src)?;
|
let src_reg = self.load_to_general_reg(src)?;
|
||||||
ASM::neg_reg64_reg64(&mut self.buf, dst_reg, src_reg);
|
ASM::neg_reg64_reg64(&mut self.buf, dst_reg, src_reg);
|
||||||
|
@ -819,7 +820,7 @@ impl<
|
||||||
layout: &Layout<'a>,
|
layout: &Layout<'a>,
|
||||||
) -> Result<(), String> {
|
) -> Result<(), String> {
|
||||||
match layout {
|
match layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let dst_reg = self.claim_general_reg(dst)?;
|
let dst_reg = self.claim_general_reg(dst)?;
|
||||||
let src1_reg = self.load_to_general_reg(src1)?;
|
let src1_reg = self.load_to_general_reg(src1)?;
|
||||||
let src2_reg = self.load_to_general_reg(src2)?;
|
let src2_reg = self.load_to_general_reg(src2)?;
|
||||||
|
@ -838,7 +839,7 @@ impl<
|
||||||
arg_layout: &Layout<'a>,
|
arg_layout: &Layout<'a>,
|
||||||
) -> Result<(), String> {
|
) -> Result<(), String> {
|
||||||
match arg_layout {
|
match arg_layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let dst_reg = self.claim_general_reg(dst)?;
|
let dst_reg = self.claim_general_reg(dst)?;
|
||||||
let src1_reg = self.load_to_general_reg(src1)?;
|
let src1_reg = self.load_to_general_reg(src1)?;
|
||||||
let src2_reg = self.load_to_general_reg(src2)?;
|
let src2_reg = self.load_to_general_reg(src2)?;
|
||||||
|
@ -857,7 +858,7 @@ impl<
|
||||||
arg_layout: &Layout<'a>,
|
arg_layout: &Layout<'a>,
|
||||||
) -> Result<(), String> {
|
) -> Result<(), String> {
|
||||||
match arg_layout {
|
match arg_layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let dst_reg = self.claim_general_reg(dst)?;
|
let dst_reg = self.claim_general_reg(dst)?;
|
||||||
let src1_reg = self.load_to_general_reg(src1)?;
|
let src1_reg = self.load_to_general_reg(src1)?;
|
||||||
let src2_reg = self.load_to_general_reg(src2)?;
|
let src2_reg = self.load_to_general_reg(src2)?;
|
||||||
|
@ -1104,10 +1105,10 @@ impl<
|
||||||
ASM::mov_freg64_freg64(&mut self.buf, CC::FLOAT_RETURN_REGS[0], *reg);
|
ASM::mov_freg64_freg64(&mut self.buf, CC::FLOAT_RETURN_REGS[0], *reg);
|
||||||
}
|
}
|
||||||
Some(SymbolStorage::Base { offset, size, .. }) => match layout {
|
Some(SymbolStorage::Base { offset, size, .. }) => match layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
ASM::mov_reg64_base32(&mut self.buf, CC::GENERAL_RETURN_REGS[0], *offset);
|
ASM::mov_reg64_base32(&mut self.buf, CC::GENERAL_RETURN_REGS[0], *offset);
|
||||||
}
|
}
|
||||||
Layout::Builtin(Builtin::Float64) => {
|
Layout::Builtin(Builtin::Float(FloatWidth::F64)) => {
|
||||||
ASM::mov_freg64_base32(&mut self.buf, CC::FLOAT_RETURN_REGS[0], *offset);
|
ASM::mov_freg64_base32(&mut self.buf, CC::FLOAT_RETURN_REGS[0], *offset);
|
||||||
}
|
}
|
||||||
Layout::Builtin(Builtin::Str) => {
|
Layout::Builtin(Builtin::Str) => {
|
||||||
|
@ -1460,12 +1461,12 @@ impl<
|
||||||
layout: &Layout<'a>,
|
layout: &Layout<'a>,
|
||||||
) -> Result<(), String> {
|
) -> Result<(), String> {
|
||||||
match layout {
|
match layout {
|
||||||
Layout::Builtin(Builtin::Int64) => {
|
Layout::Builtin(Builtin::Int(IntWidth::I64 | IntWidth::U64)) => {
|
||||||
let reg = self.load_to_general_reg(sym)?;
|
let reg = self.load_to_general_reg(sym)?;
|
||||||
ASM::mov_base32_reg64(&mut self.buf, to_offset, reg);
|
ASM::mov_base32_reg64(&mut self.buf, to_offset, reg);
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
Layout::Builtin(Builtin::Float64) => {
|
Layout::Builtin(Builtin::Float(FloatWidth::F64)) => {
|
||||||
let reg = self.load_to_float_reg(sym)?;
|
let reg = self.load_to_float_reg(sym)?;
|
||||||
ASM::mov_base32_freg64(&mut self.buf, to_offset, reg);
|
ASM::mov_base32_freg64(&mut self.buf, to_offset, reg);
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -1545,19 +1546,25 @@ impl<
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
macro_rules! single_register_integers {
|
macro_rules! single_register_integers {
|
||||||
() => {
|
() => {
|
||||||
Builtin::Int1
|
Builtin::Usize
|
||||||
| Builtin::Int8
|
| Builtin::Bool
|
||||||
| Builtin::Int16
|
| Builtin::Int(
|
||||||
| Builtin::Int32
|
IntWidth::I8
|
||||||
| Builtin::Int64
|
| IntWidth::I16
|
||||||
| Builtin::Usize
|
| IntWidth::I32
|
||||||
|
| IntWidth::I64
|
||||||
|
| IntWidth::U8
|
||||||
|
| IntWidth::U16
|
||||||
|
| IntWidth::U32
|
||||||
|
| IntWidth::U64,
|
||||||
|
)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
macro_rules! single_register_floats {
|
macro_rules! single_register_floats {
|
||||||
() => {
|
() => {
|
||||||
Builtin::Float32 | Builtin::Float64
|
Builtin::Float(FloatWidth::F32 | FloatWidth::F64)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,7 @@ use crate::{
|
||||||
single_register_builtins, single_register_floats, single_register_integers, Relocation,
|
single_register_builtins, single_register_floats, single_register_integers, Relocation,
|
||||||
};
|
};
|
||||||
use bumpalo::collections::Vec;
|
use bumpalo::collections::Vec;
|
||||||
|
use roc_builtins::bitcode::{FloatWidth, IntWidth};
|
||||||
use roc_collections::all::MutMap;
|
use roc_collections::all::MutMap;
|
||||||
use roc_module::symbol::Symbol;
|
use roc_module::symbol::Symbol;
|
||||||
use roc_mono::layout::{Builtin, Layout};
|
use roc_mono::layout::{Builtin, Layout};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue