|
|
@ -1,5 +1,5 @@
|
|
|
|
/*******************************************************************************
|
|
|
|
/*******************************************************************************
|
|
|
|
* Copyright (C) 2017, 2023 MINRES Technologies GmbH
|
|
|
|
* Copyright (C) 2017-2024 MINRES Technologies GmbH
|
|
|
|
* All rights reserved.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
@ -339,7 +339,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -385,7 +385,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -431,7 +431,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(imm%static_cast<uint32_t>(traits::INSTR_ALIGNMENT)){
|
|
|
|
if(imm%static_cast<uint32_t>(traits::INSTR_ALIGNMENT)){
|
|
|
@ -486,7 +486,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto addr_mask = (uint32_t)- 2;
|
|
|
|
auto addr_mask = (uint32_t)- 2;
|
|
|
@ -554,7 +554,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -612,7 +612,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -670,7 +670,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -730,7 +730,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -790,7 +790,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -848,7 +848,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -906,7 +906,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
@ -959,7 +959,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
@ -1012,7 +1012,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
@ -1065,7 +1065,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
@ -1117,7 +1117,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
|
auto load_address = gen_ext(jh,
|
|
|
@ -1169,7 +1169,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto store_address = gen_ext(jh,
|
|
|
|
auto store_address = gen_ext(jh,
|
|
|
@ -1217,7 +1217,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto store_address = gen_ext(jh,
|
|
|
|
auto store_address = gen_ext(jh,
|
|
|
@ -1265,7 +1265,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto store_address = gen_ext(jh,
|
|
|
|
auto store_address = gen_ext(jh,
|
|
|
@ -1313,7 +1313,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1362,7 +1362,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1424,7 +1424,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1485,7 +1485,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1533,7 +1533,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1581,7 +1581,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1629,7 +1629,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1677,7 +1677,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1725,7 +1725,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1733,7 +1733,7 @@ private:
|
|
|
|
gen_ext(jh,
|
|
|
|
gen_ext(jh,
|
|
|
|
(gen_operation(jh, sar, gen_ext(jh,
|
|
|
|
(gen_operation(jh, sar, gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), shamt)
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), shamt)
|
|
|
|
), 32, true));
|
|
|
|
), 32, false));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
auto returnValue = CONT;
|
|
|
|
auto returnValue = CONT;
|
|
|
@ -1775,7 +1775,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1824,7 +1824,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1873,7 +1873,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1922,7 +1922,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -1985,7 +1985,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -2046,7 +2046,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -2094,7 +2094,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -2143,7 +2143,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -2194,7 +2194,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -2242,7 +2242,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -2471,7 +2471,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto xrs1 = load_reg_from_mem(jh, traits::X0 + rs1);
|
|
|
|
auto xrs1 = load_reg_from_mem(jh, traits::X0 + rs1);
|
|
|
@ -2524,7 +2524,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
@ -2577,7 +2577,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
@ -2630,7 +2630,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
@ -2679,7 +2679,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
@ -2731,7 +2731,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
|
auto xrd = gen_read_mem(jh, traits::CSR, csr, 4);
|
|
|
@ -2822,16 +2822,13 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto res = gen_ext(jh,
|
|
|
|
auto res = gen_operation(jh, imul, gen_ext(jh,
|
|
|
|
(gen_operation(jh, imul, gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), gen_ext(jh,
|
|
|
|
gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 32, true))
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), 64, true), gen_ext(jh,
|
|
|
|
;
|
|
|
|
gen_ext(jh,
|
|
|
|
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 32, true), 64, true))
|
|
|
|
|
|
|
|
), 64, true);
|
|
|
|
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
gen_ext(jh,
|
|
|
|
gen_ext(jh,
|
|
|
@ -2877,16 +2874,13 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto res = gen_ext(jh,
|
|
|
|
auto res = gen_operation(jh, imul, gen_ext(jh,
|
|
|
|
(gen_operation(jh, imul, gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), gen_ext(jh,
|
|
|
|
gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 32, true))
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), 64, true), gen_ext(jh,
|
|
|
|
;
|
|
|
|
gen_ext(jh,
|
|
|
|
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 32, true), 64, true))
|
|
|
|
|
|
|
|
), 64, true);
|
|
|
|
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
gen_ext(jh,
|
|
|
|
gen_ext(jh,
|
|
|
@ -2933,15 +2927,12 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto res = gen_ext(jh,
|
|
|
|
auto res = gen_operation(jh, imul, gen_ext(jh,
|
|
|
|
(gen_operation(jh, imul, gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), load_reg_from_mem(jh, traits::X0 + rs2))
|
|
|
|
gen_ext(jh,
|
|
|
|
;
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), 64, true), gen_ext(jh,
|
|
|
|
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 64, false))
|
|
|
|
|
|
|
|
), 64, true);
|
|
|
|
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
gen_ext(jh,
|
|
|
|
gen_ext(jh,
|
|
|
@ -2988,14 +2979,12 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto res = gen_ext(jh,
|
|
|
|
auto res = gen_operation(jh, mul,
|
|
|
|
(gen_operation(jh, mul, gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1),
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 64, false), gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2));
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 64, false))
|
|
|
|
|
|
|
|
), 64, false);
|
|
|
|
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
gen_ext(jh,
|
|
|
|
gen_ext(jh,
|
|
|
@ -3042,13 +3031,13 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto dividend = gen_ext(jh,
|
|
|
|
auto dividend = gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, false);
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true);
|
|
|
|
auto divisor = gen_ext(jh,
|
|
|
|
auto divisor = gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 32, false);
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 32, true);
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
cc.cmp(gen_operation(jh, ne, divisor, 0)
|
|
|
|
cc.cmp(gen_operation(jh, ne, divisor, 0)
|
|
|
@ -3126,7 +3115,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -3137,9 +3126,8 @@ private:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
gen_ext(jh,
|
|
|
|
gen_operation(jh, div, load_reg_from_mem(jh, traits::X0 + rs1), load_reg_from_mem(jh, traits::X0 + rs2))
|
|
|
|
(gen_operation(jh, div, load_reg_from_mem(jh, traits::X0 + rs1), load_reg_from_mem(jh, traits::X0 + rs2))
|
|
|
|
);
|
|
|
|
), 32, false));
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
cc.jmp(label_merge);
|
|
|
|
cc.jmp(label_merge);
|
|
|
@ -3191,7 +3179,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -3223,9 +3211,9 @@ private:
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
gen_ext(jh,
|
|
|
|
gen_ext(jh,
|
|
|
|
(gen_operation(jh, srem, gen_ext(jh,
|
|
|
|
(gen_operation(jh, srem, gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, false), gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs1), 32, true), gen_ext(jh,
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 32, false))
|
|
|
|
load_reg_from_mem(jh, traits::X0 + rs2), 32, true))
|
|
|
|
), 32, true));
|
|
|
|
), 32, false));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
cc.bind(label_merge);
|
|
|
|
cc.bind(label_merge);
|
|
|
@ -3279,7 +3267,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rs1>=static_cast<uint32_t>(traits::RFS)||rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
|
auto label_merge = cc.newLabel();
|
|
|
@ -3348,7 +3336,7 @@ private:
|
|
|
|
), 32, false));
|
|
|
|
), 32, false));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
auto returnValue = CONT;
|
|
|
|
auto returnValue = CONT;
|
|
|
|
|
|
|
|
|
|
|
@ -3476,7 +3464,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rs1!=0){
|
|
|
|
if(rs1!=0){
|
|
|
@ -3600,7 +3588,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -3646,7 +3634,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(imm==0||rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(imm==0||rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
|
cc.mov(get_ptr_for(jh, traits::X0+ rd),
|
|
|
@ -3695,7 +3683,7 @@ private:
|
|
|
|
), 32, true));
|
|
|
|
), 32, true));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
auto returnValue = CONT;
|
|
|
|
auto returnValue = CONT;
|
|
|
|
|
|
|
|
|
|
|
@ -3732,7 +3720,7 @@ private:
|
|
|
|
gen_instr_prologue(jh);
|
|
|
|
gen_instr_prologue(jh);
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
auto returnValue = CONT;
|
|
|
|
auto returnValue = CONT;
|
|
|
|
|
|
|
|
|
|
|
|
gen_instr_epilogue(jh);
|
|
|
|
gen_instr_epilogue(jh);
|
|
|
@ -4199,7 +4187,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rs1!=0){
|
|
|
|
if(rs1!=0){
|
|
|
@ -4246,7 +4234,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rd==0){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)||rd==0){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto offs = gen_ext(jh,
|
|
|
|
auto offs = gen_ext(jh,
|
|
|
@ -4295,7 +4283,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -4421,7 +4409,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rd>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
if(rd!=0){
|
|
|
|
if(rd!=0){
|
|
|
@ -4468,7 +4456,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs1>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto new_pc = load_reg_from_mem(jh, traits::X0 + rs1);
|
|
|
|
auto new_pc = load_reg_from_mem(jh, traits::X0 + rs1);
|
|
|
@ -4552,7 +4540,7 @@ private:
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
if(rs2>=static_cast<uint32_t>(traits::RFS)){
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
else{
|
|
|
|
auto offs = gen_ext(jh,
|
|
|
|
auto offs = gen_ext(jh,
|
|
|
@ -4595,7 +4583,7 @@ private:
|
|
|
|
gen_instr_prologue(jh);
|
|
|
|
gen_instr_prologue(jh);
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
cc.comment("//behavior:");
|
|
|
|
/*generate behavior*/
|
|
|
|
/*generate behavior*/
|
|
|
|
gen_raise(jh, 0, 2);
|
|
|
|
gen_raise(jh, 0, static_cast<int32_t>(traits::RV_CAUSE_ILLEGAL_INSTRUCTION));
|
|
|
|
auto returnValue = CONT;
|
|
|
|
auto returnValue = CONT;
|
|
|
|
|
|
|
|
|
|
|
|
gen_instr_epilogue(jh);
|
|
|
|
gen_instr_epilogue(jh);
|
|
|
@ -4617,6 +4605,7 @@ private:
|
|
|
|
this->gen_sync(jh, POST_SYNC, instr_descr.size());
|
|
|
|
this->gen_sync(jh, POST_SYNC, instr_descr.size());
|
|
|
|
return BRANCH;
|
|
|
|
return BRANCH;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//decoding functionality
|
|
|
|
//decoding functionality
|
|
|
|
|
|
|
|
|
|
|
|
void populate_decoding_tree(decoding_tree_node* root){
|
|
|
|
void populate_decoding_tree(decoding_tree_node* root){
|
|
|
|