target-i386: Update BNDSTATUS for exceptions raised by BOUND Signed-off-by: Richard Henderson <rth@twiddle.net>
diff --git a/target-i386/mem_helper.c b/target-i386/mem_helper.c index 7de7752..85e7516 100644 --- a/target-i386/mem_helper.c +++ b/target-i386/mem_helper.c
@@ -112,6 +112,9 @@ high = cpu_ldsw_data_ra(env, a0 + 2, GETPC()); v = (int16_t)v; if (v < low || v > high) { + if (env->hflags & HF_MPX_EN_MASK) { + env->bndcs_regs.sts = 0; + } raise_exception_ra(env, EXCP05_BOUND, GETPC()); } } @@ -123,6 +126,9 @@ low = cpu_ldl_data_ra(env, a0, GETPC()); high = cpu_ldl_data_ra(env, a0 + 4, GETPC()); if (v < low || v > high) { + if (env->hflags & HF_MPX_EN_MASK) { + env->bndcs_regs.sts = 0; + } raise_exception_ra(env, EXCP05_BOUND, GETPC()); } }