Commit 306ab3e86a94b7547883ca9dac0c86122bb8622c
1 parent
6d35524c
Avoid host FPE for overflowing division on MIPS, by Richard Sandiford.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3856 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
10 additions
and
3 deletions
target-mips/op_helper.c
... | ... | @@ -230,9 +230,16 @@ void do_div (void) |
230 | 230 | void do_ddiv (void) |
231 | 231 | { |
232 | 232 | if (T1 != 0) { |
233 | - lldiv_t res = lldiv((int64_t)T0, (int64_t)T1); | |
234 | - env->LO[0][env->current_tc] = res.quot; | |
235 | - env->HI[0][env->current_tc] = res.rem; | |
233 | + int64_t arg0 = (int64_t)T0; | |
234 | + int64_t arg1 = (int64_t)T1; | |
235 | + if (arg0 == ((int64_t)-1 << 63) && arg1 == (int64_t)-1) { | |
236 | + env->LO[0][env->current_tc] = arg0; | |
237 | + env->HI[0][env->current_tc] = 0; | |
238 | + } else { | |
239 | + lldiv_t res = lldiv(arg0, arg1); | |
240 | + env->LO[0][env->current_tc] = res.quot; | |
241 | + env->HI[0][env->current_tc] = res.rem; | |
242 | + } | |
236 | 243 | } |
237 | 244 | } |
238 | 245 | ... | ... |