forked from M-Labs/nac3
nac3artiq: support RISC-V with and without FPU. Closes #83
This commit is contained in:
parent
4547eee82a
commit
978eaf16a4
nac3artiq
@ -10,7 +10,7 @@ device_db = {
|
|||||||
"host": "kc705",
|
"host": "kc705",
|
||||||
"ref_period": 1e-9,
|
"ref_period": 1e-9,
|
||||||
"ref_multiplier": 8,
|
"ref_multiplier": 8,
|
||||||
"target": "riscv"
|
"target": "rv32g"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -38,7 +38,8 @@ use timeline::TimeFns;
|
|||||||
#[derive(PartialEq, Clone, Copy)]
|
#[derive(PartialEq, Clone, Copy)]
|
||||||
enum Isa {
|
enum Isa {
|
||||||
Host,
|
Host,
|
||||||
RiscV,
|
RiscV32G,
|
||||||
|
RiscV32IMA,
|
||||||
CortexA9,
|
CortexA9,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -204,13 +205,15 @@ impl Nac3 {
|
|||||||
fn new(isa: &str, py: Python) -> PyResult<Self> {
|
fn new(isa: &str, py: Python) -> PyResult<Self> {
|
||||||
let isa = match isa {
|
let isa = match isa {
|
||||||
"host" => Isa::Host,
|
"host" => Isa::Host,
|
||||||
"riscv" => Isa::RiscV,
|
"rv32g" => Isa::RiscV32G,
|
||||||
|
"rv32ima" => Isa::RiscV32IMA,
|
||||||
"cortexa9" => Isa::CortexA9,
|
"cortexa9" => Isa::CortexA9,
|
||||||
_ => return Err(exceptions::PyValueError::new_err("invalid ISA")),
|
_ => return Err(exceptions::PyValueError::new_err("invalid ISA")),
|
||||||
};
|
};
|
||||||
let time_fns: &(dyn TimeFns + Sync) = match isa {
|
let time_fns: &(dyn TimeFns + Sync) = match isa {
|
||||||
Isa::Host => &timeline::EXTERN_TIME_FNS,
|
Isa::Host => &timeline::EXTERN_TIME_FNS,
|
||||||
Isa::RiscV => &timeline::NOW_PINNING_TIME_FNS,
|
Isa::RiscV32G => &timeline::NOW_PINNING_TIME_FNS,
|
||||||
|
Isa::RiscV32IMA => &timeline::NOW_PINNING_TIME_FNS,
|
||||||
Isa::CortexA9 => &timeline::EXTERN_TIME_FNS,
|
Isa::CortexA9 => &timeline::EXTERN_TIME_FNS,
|
||||||
};
|
};
|
||||||
let primitive: PrimitiveStore = TopLevelComposer::make_primitives().0;
|
let primitive: PrimitiveStore = TopLevelComposer::make_primitives().0;
|
||||||
@ -452,7 +455,8 @@ impl Nac3 {
|
|||||||
|
|
||||||
let (triple, features) = match isa {
|
let (triple, features) = match isa {
|
||||||
Isa::Host => (TargetMachine::get_default_triple(), TargetMachine::get_host_cpu_features().to_string()),
|
Isa::Host => (TargetMachine::get_default_triple(), TargetMachine::get_host_cpu_features().to_string()),
|
||||||
Isa::RiscV => (TargetTriple::create("riscv32-unknown-linux"), "+a,+m".to_string()),
|
Isa::RiscV32G => (TargetTriple::create("riscv32-unknown-linux"), "+a,+m,+f,+d".to_string()),
|
||||||
|
Isa::RiscV32IMA => (TargetTriple::create("riscv32-unknown-linux"), "+a,+m".to_string()),
|
||||||
Isa::CortexA9 => (
|
Isa::CortexA9 => (
|
||||||
TargetTriple::create("armv7-unknown-linux-gnueabihf"),
|
TargetTriple::create("armv7-unknown-linux-gnueabihf"),
|
||||||
"+dsp,+fp16,+neon,+vfp3".to_string(),
|
"+dsp,+fp16,+neon,+vfp3".to_string(),
|
||||||
|
Loading…
Reference in New Issue
Block a user