Commit 2d0e944d1c985a0d4639ee5d98c3c371cd63afa3

Authored by ths
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
... ...