summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--arch/mips/isa/decoder.isa196
1 files changed, 146 insertions, 50 deletions
diff --git a/arch/mips/isa/decoder.isa b/arch/mips/isa/decoder.isa
index b9774c6b1..6f1081dab 100644
--- a/arch/mips/isa/decoder.isa
+++ b/arch/mips/isa/decoder.isa
@@ -589,49 +589,54 @@ decode OPCODE_HI default Unknown::unknown() {
0x6: decode FUNCTION_LO {
format FloatCompareOp {
0x0: c_f_s({{ cond = 0; }});
+
0x1: c_un_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 1;
else
cond = 0;
}});
+
0x2: c_eq_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 0;
else
- cond = (Fs == Ft);
+ cond = (Fs.sf == Ft.sf);
}});
+
0x3: c_ueq_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 1;
else
- cond = (Fs == Ft);
+ cond = (Fs.sf == Ft.sf);
}});
+
0x4: c_olt_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 0;
else
- cond = ;
- ;
+ cond = (Fs.sf < Ft.sf);
}});
+
0x5: c_ult_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 1;
else
- cond = ;
- ;
+ cond = (Fs.sf < Ft.sf);
}});
+
0x6: c_ole_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 0;
else
- cond = ;
+ cond = (Fs.sf <= Ft.sf);
}});
+
0x7: c_ule_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 1;
else
- cond = ;
+ cond = (Fs.sf <= Ft.sf);
}});
}
}
@@ -639,47 +644,54 @@ decode OPCODE_HI default Unknown::unknown() {
0x7: decode FUNCTION_LO {
format FloatCompareWithXcptOp {
0x0: c_sf_s({{ cond = 0; }});
+
0x1: c_ngle_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 1;
else
- cond = ;
+ cond = 0;
}});
+
0x2: c_seq_s({{
- if (unordered(Rs) || unordered(Rt))
- cond = 1;
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
+ cond = 0;
else
- cond = ;
+ cond = (Fs.sf == Ft.sf);
}});
+
0x3: c_ngl_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 1;
else
- cond = ;
+ cond = (Fs.sf == Ft.sf);
}});
+
0x4: c_lt_s({{
- if (unordered(Rs) || unordered(Rt))
- cond = 1;
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
+ cond = 0;
else
- cond = ;
+ cond = (Fs.sf < Ft.sf);
}});
+
0x5: c_nge_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 1;
else
- cond = ;
+ cond = (Fs.sf < Ft.sf);
}});
+
0x6: c_le_s({{
- if (unordered(Rs) || unordered(Rt))
- cond = 1;
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
+ cond = 0;
else
- cond = ;
+ cond = (Fs.sf <= Ft.sf);
}});
+
0x7: c_ngt_s({{
- if (unordered(Rs) || unordered(Rt))
+ if (unorderedFP(Fs.uw) || unorderedFP(Ft.uw))
cond = 1;
else
- cond = ;
+ cond = (Fs.sf <= Ft.sf);
}});
}
}
@@ -780,28 +792,112 @@ decode OPCODE_HI default Unknown::unknown() {
}
0x6: decode FUNCTION_LO {
- format FloatOp {
- 0x0: c_f_d({{ ; }});
- 0x1: c_un_d({{ ; }});
- 0x2: c_eq_d({{ ; }});
- 0x3: c_ueq_d({{ ; }});
- 0x4: c_olt_d({{ ; }});
- 0x5: c_ult_d({{ ; }});
- 0x6: c_ole_d({{ ; }});
- 0x7: c_ule_d({{ ; }});
+ format FloatCompareOp {
+ 0x0: c_f_d({{ cond = 0; }});
+
+ 0x1: c_un_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 1;
+ else
+ cond = 0;
+ }});
+
+ 0x2: c_eq_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 0;
+ else
+ cond = (Fs.df == Ft.df);
+ }});
+
+ 0x3: c_ueq_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 1;
+ else
+ cond = (Fs.df == Ft.df);
+ }});
+
+ 0x4: c_olt_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 0;
+ else
+ cond = (Fs.df < Ft.df);
+ }});
+
+ 0x5: c_ult_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 1;
+ else
+ cond = (Fs.df < Ft.df);
+ }});
+
+ 0x6: c_ole_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 0;
+ else
+ cond = (Fs.df <= Ft.df);
+ }});
+
+ 0x7: c_ule_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 1;
+ else
+ cond = (Fs.df <= Ft.df);
+ }});
}
}
0x7: decode FUNCTION_LO {
- format FloatOp {
- 0x0: c_sf_d({{ ; }});
- 0x1: c_ngle_d({{ ; }});
- 0x2: c_seq_d({{ ; }});
- 0x3: c_ngl_d({{ ; }});
- 0x4: c_lt_d({{ ; }});
- 0x5: c_nge_d({{ ; }});
- 0x6: c_le_d({{ ; }});
- 0x7: c_ngt_d({{ ; }});
+ format FloatCompareWithXcptOp {
+ 0x0: c_sf_d({{ cond = 0; }});
+
+ 0x1: c_ngle_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 1;
+ else
+ cond = 0;
+ }});
+
+ 0x2: c_seq_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 0;
+ else
+ cond = (Fs.df == Ft.df);
+ }});
+
+ 0x3: c_ngl_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 1;
+ else
+ cond = (Fs.df == Ft.df);
+ }});
+
+ 0x4: c_lt_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 0;
+ else
+ cond = (Fs.df < Ft.df);
+ }});
+
+ 0x5: c_nge_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 1;
+ else
+ cond = (Fs.df < Ft.df);
+ }});
+
+ 0x6: c_le_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 0;
+ else
+ cond = (Fs.df <= Ft.df);
+ }});
+
+ 0x7: c_ngt_d({{
+ if (unorderedFP(Fs.ud) || unorderedFP(Ft.ud))
+ cond = 1;
+ else
+ cond = (Fs.df <= Ft.df);
+ }});
}
}
}