Commit 2d0e944d1c985a0d4639ee5d98c3c371cd63afa3
1 parent
23be50f1
Build fix for 64bit machines. (This is still not correct mul/div handling.)
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2587 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
12 additions
and
6 deletions
target-mips/op_helper.c
... | ... | @@ -17,6 +17,7 @@ |
17 | 17 | * License along with this library; if not, write to the Free Software |
18 | 18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
19 | 19 | */ |
20 | +#include <stdlib.h> | |
20 | 21 | #include "exec.h" |
21 | 22 | |
22 | 23 | #define MIPS_DEBUG_DISAS |
... | ... | @@ -222,29 +223,34 @@ void do_msubu (void) |
222 | 223 | #ifdef TARGET_MIPS64 |
223 | 224 | void do_dmult (void) |
224 | 225 | { |
226 | + env->LO = (int64_t)T0 * (int64_t)T1; | |
225 | 227 | /* XXX */ |
226 | - set_HILO((int64_t)T0 * (int64_t)T1); | |
228 | + env->HI = (env->LO | (1ULL << 63)) ? ~0ULL : 0ULL; | |
227 | 229 | } |
228 | 230 | |
229 | 231 | void do_dmultu (void) |
230 | 232 | { |
233 | + env->LO = T0 * T1; | |
231 | 234 | /* XXX */ |
232 | - set_HILO((uint64_t)T0 * (uint64_t)T1); | |
235 | + env->HI = 0; | |
233 | 236 | } |
234 | 237 | |
235 | 238 | void do_ddiv (void) |
236 | 239 | { |
237 | 240 | if (T1 != 0) { |
238 | - env->LO = (int64_t)T0 / (int64_t)T1; | |
239 | - env->HI = (int64_t)T0 % (int64_t)T1; | |
241 | + lldiv_t res = lldiv((int64_t)T0, (int64_t)T1); | |
242 | + env->LO = res.quot; | |
243 | + env->HI = res.rem; | |
240 | 244 | } |
241 | 245 | } |
242 | 246 | |
243 | 247 | void do_ddivu (void) |
244 | 248 | { |
245 | 249 | if (T1 != 0) { |
246 | - env->LO = T0 / T1; | |
247 | - env->HI = T0 % T1; | |
250 | + /* XXX: lldivu? */ | |
251 | + lldiv_t res = lldiv(T0, T1); | |
252 | + env->LO = (uint64_t)res.quot; | |
253 | + env->HI = (uint64_t)res.rem; | |
248 | 254 | } |
249 | 255 | } |
250 | 256 | #endif | ... | ... |