@@ -1331,6 +1331,21 @@ void HELPER(iround_FP0)(CPUState *env)
floatx80_to_FP0(env, res);
}
+void HELPER(sinh_FP0)(CPUState *env)
+{
+ floatx80 res;
+ long double val;
+
+ res = FP0_to_floatx80(env);
+ val = floatx80_to_ldouble(res);
+
+ DBG_FPUH("sinh_FP0 %Lg", val);
+ val = sinhl(val);
+ DBG_FPU(" = %Lg", val);
+ res = ldouble_to_floatx80(val);
+ floatx80_to_FP0(env, res);
+}
+
void HELPER(itrunc_FP0)(CPUState *env)
{
floatx80 res;
@@ -63,6 +63,7 @@ DEF_HELPER_4(fmovem, void, env, i32, i32, i32)
DEF_HELPER_2(set_fpcr, void, env, i32)
DEF_HELPER_2(const_FP0, void, env, i32)
DEF_HELPER_1(iround_FP0, void, env)
+DEF_HELPER_1(sinh_FP0, void, env)
DEF_HELPER_1(itrunc_FP0, void, env)
DEF_HELPER_1(sqrt_FP0, void, env)
DEF_HELPER_1(atan_FP0, void, env)
@@ -3727,6 +3727,9 @@ DISAS_INSN(fpu)
gen_helper_iround_FP0(cpu_env);
round = 0;
break;
+ case 2: /* fsinh */
+ gen_helper_sinh_FP0(cpu_env);
+ break;
case 3: /* fintrz */
gen_helper_itrunc_FP0(cpu_env);
round = 0;