2001-03-02 01:01:52 +03:00
|
|
|
/* $NetBSD: fpu_calcea.c,v 1.11 2001/03/01 22:01:52 is Exp $ */
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 1995 Gordon W. Ross
|
|
|
|
* portion Copyright (c) 1995 Ken Nakata
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. The name of the author may not be used to endorse or promote products
|
|
|
|
* derived from this software without specific prior written permission.
|
|
|
|
* 4. All advertising materials mentioning features or use of this software
|
|
|
|
* must display the following acknowledgement:
|
|
|
|
* This product includes software developed by Gordon Ross
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
1996-02-04 05:17:38 +03:00
|
|
|
#include <sys/param.h>
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#include <sys/signal.h>
|
1996-04-30 15:52:09 +04:00
|
|
|
#include <sys/systm.h>
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#include <machine/frame.h>
|
2001-01-05 22:54:30 +03:00
|
|
|
#include <m68k/m68k.h>
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
#include "fpu_emulate.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Prototypes of static functions
|
|
|
|
*/
|
|
|
|
static int decode_ea6 __P((struct frame *frame, struct instruction *insn,
|
|
|
|
struct insn_ea *ea, int modreg));
|
|
|
|
static int fetch_immed __P((struct frame *frame, struct instruction *insn,
|
|
|
|
int *dst));
|
|
|
|
static int fetch_disp __P((struct frame *frame, struct instruction *insn,
|
|
|
|
int size, int *res));
|
|
|
|
static int calc_ea __P((struct insn_ea *ea, char *ptr, char **eaddr));
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Helper routines for dealing with "effective address" values.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Decode an effective address into internal form.
|
|
|
|
* Returns zero on success, else signal number.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
fpu_decode_ea(frame, insn, ea, modreg)
|
|
|
|
struct frame *frame;
|
|
|
|
struct instruction *insn;
|
|
|
|
struct insn_ea *ea;
|
|
|
|
int modreg;
|
|
|
|
{
|
1996-04-30 15:52:09 +04:00
|
|
|
int sig;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
#ifdef DEBUG
|
|
|
|
if (insn->is_datasize < 0) {
|
|
|
|
panic("decode_ea: called with uninitialized datasize\n");
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
sig = 0;
|
|
|
|
|
|
|
|
/* Set the most common value here. */
|
|
|
|
ea->ea_regnum = 8 + (modreg & 7);
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
if ((modreg & 060) == 0) {
|
|
|
|
/* register direct */
|
|
|
|
ea->ea_regnum = modreg & 0xf;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
ea->ea_flags = EA_DIRECT;
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: register direct reg=%d\n", ea->ea_regnum);
|
|
|
|
#endif
|
2000-06-13 16:28:13 +04:00
|
|
|
} else if ((modreg & 077) == 074) {
|
1999-05-31 00:17:48 +04:00
|
|
|
/* immediate */
|
|
|
|
ea->ea_flags = EA_IMMED;
|
|
|
|
sig = fetch_immed(frame, insn, &ea->ea_immed[0]);
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: immediate size=%d\n", insn->is_datasize);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
* rest of the address modes need to be separately
|
|
|
|
* handled for the LC040 and the others.
|
|
|
|
*/
|
2001-01-05 22:54:30 +03:00
|
|
|
#if 0 /* XXX */
|
|
|
|
else if (frame->f_format == 4 && frame->f_fmt4.f_fa) {
|
1999-05-31 00:17:48 +04:00
|
|
|
/* LC040 */
|
|
|
|
ea->ea_flags = EA_FRAME_EA;
|
|
|
|
ea->ea_fea = frame->f_fmt4.f_fa;
|
|
|
|
#ifdef DEBUG_FPE
|
2001-01-05 22:54:30 +03:00
|
|
|
printf("decode_ea: 68LC040 - in-frame EA (%p) size %d\n",
|
|
|
|
(void *)ea->ea_fea, insn->is_datasize);
|
1999-05-31 00:17:48 +04:00
|
|
|
#endif
|
|
|
|
if ((modreg & 070) == 030) {
|
|
|
|
/* postincrement mode */
|
|
|
|
ea->ea_flags |= EA_POSTINCR;
|
|
|
|
} else if ((modreg & 070) == 040) {
|
|
|
|
/* predecrement mode */
|
|
|
|
ea->ea_flags |= EA_PREDECR;
|
2001-01-05 22:54:30 +03:00
|
|
|
#ifdef M68060
|
|
|
|
#if defined(M68020) || defined(M68030) || defined(M68040)
|
|
|
|
if (cputype == CPU_68060)
|
|
|
|
#endif
|
|
|
|
if (insn->is_datasize == 12)
|
|
|
|
ea->ea_fea -= 8;
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
2001-01-05 22:54:30 +03:00
|
|
|
}
|
|
|
|
#endif /* XXX */
|
|
|
|
else {
|
1999-05-31 00:17:48 +04:00
|
|
|
/* 020/030 */
|
|
|
|
switch (modreg & 070) {
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
case 020: /* (An) */
|
|
|
|
ea->ea_flags = 0;
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: register indirect reg=%d\n", ea->ea_regnum);
|
|
|
|
#endif
|
|
|
|
break;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
case 030: /* (An)+ */
|
|
|
|
ea->ea_flags = EA_POSTINCR;
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: reg indirect postincrement reg=%d\n",
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
ea->ea_regnum);
|
1999-05-31 00:17:48 +04:00
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
break;
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
case 040: /* -(An) */
|
|
|
|
ea->ea_flags = EA_PREDECR;
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: reg indirect predecrement reg=%d\n",
|
|
|
|
ea->ea_regnum);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
break;
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
case 050: /* (d16,An) */
|
|
|
|
ea->ea_flags = EA_OFFSET;
|
|
|
|
sig = fetch_disp(frame, insn, 1, &ea->ea_offset);
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: reg indirect with displacement reg=%d\n",
|
|
|
|
ea->ea_regnum);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
break;
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
case 060: /* (d8,An,Xn) */
|
|
|
|
ea->ea_flags = EA_INDEXED;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
sig = decode_ea6(frame, insn, ea, modreg);
|
|
|
|
break;
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
case 070: /* misc. */
|
|
|
|
ea->ea_regnum = (modreg & 7);
|
|
|
|
switch (modreg & 7) {
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
case 0: /* (xxxx).W */
|
|
|
|
ea->ea_flags = EA_ABS;
|
|
|
|
sig = fetch_disp(frame, insn, 1, &ea->ea_absaddr);
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: absolute address (word)\n");
|
|
|
|
#endif
|
|
|
|
break;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
case 1: /* (xxxxxxxx).L */
|
|
|
|
ea->ea_flags = EA_ABS;
|
|
|
|
sig = fetch_disp(frame, insn, 2, &ea->ea_absaddr);
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: absolute address (long)\n");
|
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 2: /* (d16,PC) */
|
|
|
|
ea->ea_flags = EA_PC_REL | EA_OFFSET;
|
|
|
|
sig = fetch_disp(frame, insn, 1, &ea->ea_absaddr);
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: pc relative word displacement\n");
|
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 3: /* (d8,PC,Xn) */
|
|
|
|
ea->ea_flags = EA_PC_REL | EA_INDEXED;
|
|
|
|
sig = decode_ea6(frame, insn, ea, modreg);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 4: /* #data */
|
|
|
|
/* it should have been taken care of earlier */
|
|
|
|
default:
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("decode_ea: invalid addr mode (7,%d)\n", modreg & 7);
|
|
|
|
#endif
|
|
|
|
return SIGILL;
|
|
|
|
} /* switch for mode 7 */
|
|
|
|
break;
|
|
|
|
} /* switch mode */
|
|
|
|
}
|
|
|
|
ea->ea_moffs = 0;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
return sig;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Decode Mode=6 address modes
|
|
|
|
*/
|
|
|
|
static int
|
|
|
|
decode_ea6(frame, insn, ea, modreg)
|
|
|
|
struct frame *frame;
|
|
|
|
struct instruction *insn;
|
|
|
|
struct insn_ea *ea;
|
|
|
|
int modreg;
|
|
|
|
{
|
1996-04-30 15:52:09 +04:00
|
|
|
int extword, idx;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
int basedisp, outerdisp;
|
|
|
|
int bd_size, od_size;
|
|
|
|
int sig;
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
extword = fusword((void *) (insn->is_pc + insn->is_advance));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (extword < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
insn->is_advance += 2;
|
|
|
|
|
|
|
|
/* get register index */
|
|
|
|
ea->ea_idxreg = (extword >> 12) & 0xf;
|
|
|
|
idx = frame->f_regs[ea->ea_idxreg];
|
|
|
|
if ((extword & 0x0800) == 0) {
|
|
|
|
/* if word sized index, sign-extend */
|
|
|
|
idx &= 0xffff;
|
|
|
|
if (idx & 0x8000) {
|
|
|
|
idx |= 0xffff0000;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* scale register index */
|
|
|
|
idx <<= ((extword >>9) & 3);
|
|
|
|
|
|
|
|
if ((extword & 0x100) == 0) {
|
|
|
|
/* brief extention word - sign-extend the displacement */
|
|
|
|
basedisp = (extword & 0xff);
|
|
|
|
if (basedisp & 0x80) {
|
|
|
|
basedisp |= 0xffffff00;
|
|
|
|
}
|
|
|
|
|
|
|
|
ea->ea_basedisp = idx + basedisp;
|
|
|
|
ea->ea_outerdisp = 0;
|
1999-05-31 00:17:48 +04:00
|
|
|
#if DEBUG_FPE
|
|
|
|
printf("decode_ea6: brief ext word idxreg=%d, basedisp=%08x\n",
|
|
|
|
ea->ea_idxreg, ea->ea_basedisp);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
} else {
|
|
|
|
/* full extention word */
|
|
|
|
if (extword & 0x80) {
|
|
|
|
ea->ea_flags |= EA_BASE_SUPPRSS;
|
|
|
|
}
|
|
|
|
bd_size = ((extword >> 4) & 3) - 1;
|
|
|
|
od_size = (extword & 3) - 1;
|
|
|
|
sig = fetch_disp(frame, insn, bd_size, &basedisp);
|
|
|
|
if (sig) {
|
|
|
|
return sig;
|
|
|
|
}
|
|
|
|
if (od_size >= 0) {
|
|
|
|
ea->ea_flags |= EA_MEM_INDIR;
|
|
|
|
}
|
|
|
|
sig = fetch_disp(frame, insn, od_size, &outerdisp);
|
|
|
|
if (sig) {
|
|
|
|
return sig;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (extword & 0x44) {
|
|
|
|
case 0: /* preindexed */
|
|
|
|
ea->ea_basedisp = basedisp + idx;
|
|
|
|
ea->ea_outerdisp = outerdisp;
|
|
|
|
break;
|
|
|
|
case 4: /* postindexed */
|
|
|
|
ea->ea_basedisp = basedisp;
|
|
|
|
ea->ea_outerdisp = outerdisp + idx;
|
|
|
|
break;
|
|
|
|
case 0x40: /* no index */
|
|
|
|
ea->ea_basedisp = basedisp;
|
|
|
|
ea->ea_outerdisp = outerdisp;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
#ifdef DEBUG
|
1999-05-31 00:17:48 +04:00
|
|
|
printf("decode_ea6: invalid indirect mode: ext word %04x\n",
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
extword);
|
|
|
|
#endif
|
|
|
|
return SIGILL;
|
|
|
|
break;
|
|
|
|
}
|
1999-05-31 00:17:48 +04:00
|
|
|
#if DEBUG_FPE
|
|
|
|
printf("decode_ea6: full ext idxreg=%d, basedisp=%x, outerdisp=%x\n",
|
|
|
|
ea->ea_idxreg, ea->ea_basedisp, ea->ea_outerdisp);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
1999-05-31 00:17:48 +04:00
|
|
|
#if DEBUG_FPE
|
|
|
|
printf("decode_ea6: regnum=%d, flags=%x\n",
|
|
|
|
ea->ea_regnum, ea->ea_flags);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Load a value from an effective address.
|
|
|
|
* Returns zero on success, else signal number.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
fpu_load_ea(frame, insn, ea, dst)
|
|
|
|
struct frame *frame;
|
|
|
|
struct instruction *insn;
|
|
|
|
struct insn_ea *ea;
|
|
|
|
char *dst;
|
|
|
|
{
|
|
|
|
int *reg;
|
|
|
|
char *src;
|
|
|
|
int len, step;
|
1996-04-30 15:52:09 +04:00
|
|
|
int sig;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DIAGNOSTIC
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (ea->ea_regnum & ~0xF) {
|
1999-05-31 00:17:48 +04:00
|
|
|
panic("load_ea: bad regnum");
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: frame at %p\n", frame);
|
|
|
|
#endif
|
|
|
|
/* dst is always int or larger. */
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
len = insn->is_datasize;
|
|
|
|
if (len < 4) {
|
|
|
|
dst += (4 - len);
|
|
|
|
}
|
|
|
|
step = (len == 1 && ea->ea_regnum == 15 /* sp */) ? 2 : len;
|
|
|
|
|
2001-03-02 01:01:52 +03:00
|
|
|
#if 0
|
1999-05-31 00:17:48 +04:00
|
|
|
if (ea->ea_flags & EA_FRAME_EA) {
|
|
|
|
/* Using LC040 frame EA */
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
if (ea->ea_flags & (EA_PREDECR|EA_POSTINCR)) {
|
|
|
|
printf("load_ea: frame ea %08x w/r%d\n",
|
|
|
|
ea->ea_fea, ea->ea_regnum);
|
|
|
|
} else {
|
|
|
|
printf("load_ea: frame ea %08x\n", ea->ea_fea);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
src = (char *)ea->ea_fea;
|
|
|
|
copyin(src + ea->ea_moffs, dst, len);
|
|
|
|
if (ea->ea_flags & EA_PREDECR) {
|
|
|
|
frame->f_regs[ea->ea_regnum] = ea->ea_fea;
|
|
|
|
ea->ea_fea -= step;
|
|
|
|
ea->ea_moffs = 0;
|
|
|
|
} else if (ea->ea_flags & EA_POSTINCR) {
|
|
|
|
ea->ea_fea += step;
|
|
|
|
frame->f_regs[ea->ea_regnum] = ea->ea_fea;
|
|
|
|
ea->ea_moffs = 0;
|
|
|
|
} else {
|
|
|
|
ea->ea_moffs += step;
|
|
|
|
}
|
|
|
|
/* That's it, folks */
|
|
|
|
} else if (ea->ea_flags & EA_DIRECT) {
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (len > 4) {
|
|
|
|
#ifdef DEBUG
|
1999-05-31 00:17:48 +04:00
|
|
|
printf("load_ea: operand doesn't fit cpu reg\n");
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#endif
|
|
|
|
return SIGILL;
|
|
|
|
}
|
1999-05-31 00:17:48 +04:00
|
|
|
if (ea->ea_moffs > 0) {
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#ifdef DEBUG
|
1999-05-31 00:17:48 +04:00
|
|
|
printf("load_ea: more than one move from cpu reg\n");
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#endif
|
|
|
|
return SIGILL;
|
|
|
|
}
|
|
|
|
src = (char *)&frame->f_regs[ea->ea_regnum];
|
|
|
|
/* The source is an int. */
|
|
|
|
if (len < 4) {
|
|
|
|
src += (4 - len);
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: short/byte opr - addr adjusted\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: src %p\n", src);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
bcopy(src, dst, len);
|
2001-03-02 01:01:52 +03:00
|
|
|
} else
|
|
|
|
#endif
|
|
|
|
if (ea->ea_flags & EA_IMMED) {
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: immed %08x%08x%08x size %d\n",
|
|
|
|
ea->ea_immed[0], ea->ea_immed[1], ea->ea_immed[2], len);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
src = (char *)&ea->ea_immed[0];
|
|
|
|
if (len < 4) {
|
|
|
|
src += (4 - len);
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: short/byte immed opr - addr adjusted\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
|
|
|
bcopy(src, dst, len);
|
|
|
|
} else if (ea->ea_flags & EA_ABS) {
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: abs addr %08x\n", ea->ea_absaddr);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
src = (char *)ea->ea_absaddr;
|
|
|
|
copyin(src, dst, len);
|
|
|
|
} else /* register indirect */ {
|
|
|
|
if (ea->ea_flags & EA_PC_REL) {
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: using PC\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
reg = NULL;
|
|
|
|
/* Grab the register contents. 4 is offset to the first
|
|
|
|
extention word from the opcode */
|
1999-05-31 00:17:48 +04:00
|
|
|
src = (char *)insn->is_pc + 4;
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: pc relative pc+4 = %p\n", src);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
} else /* not PC relative */ {
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: using register %c%d\n",
|
|
|
|
(ea->ea_regnum >= 8) ? 'a' : 'd', ea->ea_regnum & 7);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
/* point to the register */
|
|
|
|
reg = &frame->f_regs[ea->ea_regnum];
|
|
|
|
|
|
|
|
if (ea->ea_flags & EA_PREDECR) {
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: predecr mode - reg decremented\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
*reg -= step;
|
1999-05-31 00:17:48 +04:00
|
|
|
ea->ea_moffs = 0;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Grab the register contents. */
|
|
|
|
src = (char *)*reg;
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: reg indirect reg = %p\n", src);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
sig = calc_ea(ea, src, &src);
|
|
|
|
if (sig)
|
|
|
|
return sig;
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
copyin(src + ea->ea_moffs, dst, len);
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
/* do post-increment */
|
|
|
|
if (ea->ea_flags & EA_POSTINCR) {
|
|
|
|
if (ea->ea_flags & EA_PC_REL) {
|
|
|
|
#ifdef DEBUG
|
1999-05-31 00:17:48 +04:00
|
|
|
printf("load_ea: tried to postincrement PC\n");
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#endif
|
|
|
|
return SIGILL;
|
|
|
|
}
|
|
|
|
*reg += step;
|
1999-05-31 00:17:48 +04:00
|
|
|
ea->ea_moffs = 0;
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("load_ea: postinc mode - reg incremented\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
} else {
|
1999-05-31 00:17:48 +04:00
|
|
|
ea->ea_moffs += len;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Store a value at the effective address.
|
|
|
|
* Returns zero on success, else signal number.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
fpu_store_ea(frame, insn, ea, src)
|
|
|
|
struct frame *frame;
|
|
|
|
struct instruction *insn;
|
|
|
|
struct insn_ea *ea;
|
|
|
|
char *src;
|
|
|
|
{
|
|
|
|
int *reg;
|
|
|
|
char *dst;
|
|
|
|
int len, step;
|
1996-04-30 15:52:09 +04:00
|
|
|
int sig;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
#ifdef DIAGNOSTIC
|
1999-05-31 00:17:48 +04:00
|
|
|
if (ea->ea_regnum & ~0xf) {
|
|
|
|
panic("store_ea: bad regnum");
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (ea->ea_flags & (EA_IMMED|EA_PC_REL)) {
|
|
|
|
/* not alterable address mode */
|
|
|
|
#ifdef DEBUG
|
1999-05-31 00:17:48 +04:00
|
|
|
printf("store_ea: not alterable address mode\n");
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#endif
|
|
|
|
return SIGILL;
|
|
|
|
}
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
/* src is always int or larger. */
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
len = insn->is_datasize;
|
|
|
|
if (len < 4) {
|
|
|
|
src += (4 - len);
|
|
|
|
}
|
|
|
|
step = (len == 1 && ea->ea_regnum == 15 /* sp */) ? 2 : len;
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
if (ea->ea_flags & EA_FRAME_EA) {
|
|
|
|
/* Using LC040 frame EA */
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
if (ea->ea_flags & (EA_PREDECR|EA_POSTINCR)) {
|
|
|
|
printf("store_ea: frame ea %08x w/r%d\n",
|
|
|
|
ea->ea_fea, ea->ea_regnum);
|
|
|
|
} else {
|
|
|
|
printf("store_ea: frame ea %08x\n", ea->ea_fea);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
dst = (char *)ea->ea_fea;
|
|
|
|
copyout(src, dst + ea->ea_moffs, len);
|
|
|
|
if (ea->ea_flags & EA_PREDECR) {
|
|
|
|
frame->f_regs[ea->ea_regnum] = ea->ea_fea;
|
|
|
|
ea->ea_fea -= step;
|
|
|
|
ea->ea_moffs = 0;
|
|
|
|
} else if (ea->ea_flags & EA_POSTINCR) {
|
|
|
|
ea->ea_fea += step;
|
|
|
|
frame->f_regs[ea->ea_regnum] = ea->ea_fea;
|
|
|
|
ea->ea_moffs = 0;
|
|
|
|
} else {
|
|
|
|
ea->ea_moffs += step;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
1999-05-31 00:17:48 +04:00
|
|
|
/* That's it, folks */
|
|
|
|
} else if (ea->ea_flags & EA_ABS) {
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("store_ea: abs addr %08x\n", ea->ea_absaddr);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
dst = (char *)ea->ea_absaddr;
|
1999-05-31 00:17:48 +04:00
|
|
|
copyout(src, dst + ea->ea_moffs, len);
|
|
|
|
ea->ea_moffs += len;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
} else if (ea->ea_flags & EA_DIRECT) {
|
|
|
|
if (len > 4) {
|
|
|
|
#ifdef DEBUG
|
1999-05-31 00:17:48 +04:00
|
|
|
printf("store_ea: operand doesn't fit cpu reg\n");
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#endif
|
|
|
|
return SIGILL;
|
|
|
|
}
|
1999-05-31 00:17:48 +04:00
|
|
|
if (ea->ea_moffs > 0) {
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#ifdef DEBUG
|
1999-05-31 00:17:48 +04:00
|
|
|
printf("store_ea: more than one move to cpu reg\n");
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
#endif
|
|
|
|
return SIGILL;
|
|
|
|
}
|
|
|
|
dst = (char*)&frame->f_regs[ea->ea_regnum];
|
|
|
|
/* The destination is an int. */
|
|
|
|
if (len < 4) {
|
|
|
|
dst += (4 - len);
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("store_ea: short/byte opr - dst addr adjusted\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("store_ea: dst %p\n", dst);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
bcopy(src, dst, len);
|
|
|
|
} else /* One of MANY indirect forms... */ {
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("store_ea: using register %c%d\n",
|
|
|
|
(ea->ea_regnum >= 8) ? 'a' : 'd', ea->ea_regnum & 7);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
/* point to the register */
|
|
|
|
reg = &(frame->f_regs[ea->ea_regnum]);
|
|
|
|
|
|
|
|
/* do pre-decrement */
|
|
|
|
if (ea->ea_flags & EA_PREDECR) {
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("store_ea: predecr mode - reg decremented\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
*reg -= step;
|
1999-05-31 00:17:48 +04:00
|
|
|
ea->ea_moffs = 0;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* calculate the effective address */
|
|
|
|
sig = calc_ea(ea, (char *)*reg, &dst);
|
|
|
|
if (sig)
|
|
|
|
return sig;
|
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("store_ea: dst addr=%p+%d\n", dst, ea->ea_moffs);
|
|
|
|
#endif
|
|
|
|
copyout(src, dst + ea->ea_moffs, len);
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
/* do post-increment */
|
|
|
|
if (ea->ea_flags & EA_POSTINCR) {
|
|
|
|
*reg += step;
|
1999-05-31 00:17:48 +04:00
|
|
|
ea->ea_moffs = 0;
|
|
|
|
#ifdef DEBUG_FPE
|
|
|
|
printf("store_ea: postinc mode - reg incremented\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
} else {
|
1999-05-31 00:17:48 +04:00
|
|
|
ea->ea_moffs += len;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* fetch_immed: fetch immediate operand
|
|
|
|
*/
|
|
|
|
static int
|
|
|
|
fetch_immed(frame, insn, dst)
|
|
|
|
struct frame *frame;
|
|
|
|
struct instruction *insn;
|
|
|
|
int *dst;
|
|
|
|
{
|
|
|
|
int data, ext_bytes;
|
|
|
|
|
|
|
|
ext_bytes = insn->is_datasize;
|
|
|
|
|
|
|
|
if (0 < ext_bytes) {
|
1999-05-31 00:17:48 +04:00
|
|
|
data = fusword((void *) (insn->is_pc + insn->is_advance));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (data < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
if (ext_bytes == 1) {
|
|
|
|
/* sign-extend byte to long */
|
|
|
|
data &= 0xff;
|
|
|
|
if (data & 0x80) {
|
|
|
|
data |= 0xffffff00;
|
|
|
|
}
|
|
|
|
} else if (ext_bytes == 2) {
|
|
|
|
/* sign-extend word to long */
|
|
|
|
data &= 0xffff;
|
|
|
|
if (data & 0x8000) {
|
|
|
|
data |= 0xffff0000;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
insn->is_advance += 2;
|
|
|
|
dst[0] = data;
|
|
|
|
}
|
|
|
|
if (2 < ext_bytes) {
|
1999-05-31 00:17:48 +04:00
|
|
|
data = fusword((void *) (insn->is_pc + insn->is_advance));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (data < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
insn->is_advance += 2;
|
|
|
|
dst[0] <<= 16;
|
|
|
|
dst[0] |= data;
|
|
|
|
}
|
|
|
|
if (4 < ext_bytes) {
|
1999-05-31 00:17:48 +04:00
|
|
|
data = fusword((void *) (insn->is_pc + insn->is_advance));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (data < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
dst[1] = data << 16;
|
1999-05-31 00:17:48 +04:00
|
|
|
data = fusword((void *) (insn->is_pc + insn->is_advance + 2));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (data < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
insn->is_advance += 4;
|
|
|
|
dst[1] |= data;
|
|
|
|
}
|
|
|
|
if (8 < ext_bytes) {
|
1999-05-31 00:17:48 +04:00
|
|
|
data = fusword((void *) (insn->is_pc + insn->is_advance));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (data < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
dst[2] = data << 16;
|
1999-05-31 00:17:48 +04:00
|
|
|
data = fusword((void *) (insn->is_pc + insn->is_advance + 2));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (data < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
insn->is_advance += 4;
|
|
|
|
dst[2] |= data;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* fetch_disp: fetch displacement in full extention words
|
|
|
|
*/
|
|
|
|
static int
|
|
|
|
fetch_disp(frame, insn, size, res)
|
|
|
|
struct frame *frame;
|
|
|
|
struct instruction *insn;
|
|
|
|
int size, *res;
|
|
|
|
{
|
|
|
|
int disp, word;
|
|
|
|
|
|
|
|
if (size == 1) {
|
1999-05-31 00:17:48 +04:00
|
|
|
word = fusword((void *) (insn->is_pc + insn->is_advance));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (word < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
disp = word & 0xffff;
|
|
|
|
if (disp & 0x8000) {
|
|
|
|
/* sign-extend */
|
|
|
|
disp |= 0xffff0000;
|
|
|
|
}
|
|
|
|
insn->is_advance += 2;
|
|
|
|
} else if (size == 2) {
|
1999-05-31 00:17:48 +04:00
|
|
|
word = fusword((void *) (insn->is_pc + insn->is_advance));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (word < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
disp = word << 16;
|
1999-05-31 00:17:48 +04:00
|
|
|
word = fusword((void *) (insn->is_pc + insn->is_advance + 2));
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
if (word < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
disp |= (word & 0xffff);
|
|
|
|
insn->is_advance += 4;
|
|
|
|
} else {
|
|
|
|
disp = 0;
|
|
|
|
}
|
|
|
|
*res = disp;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Calculates an effective address for all address modes except for
|
|
|
|
* register direct, absolute, and immediate modes. However, it does
|
|
|
|
* not take care of predecrement/postincrement of register content.
|
|
|
|
* Returns a signal value (0 == no error).
|
|
|
|
*/
|
|
|
|
static int
|
|
|
|
calc_ea(ea, ptr, eaddr)
|
|
|
|
struct insn_ea *ea;
|
|
|
|
char *ptr; /* base address (usually a register content) */
|
|
|
|
char **eaddr; /* pointer to result pointer */
|
|
|
|
{
|
1996-04-30 15:52:09 +04:00
|
|
|
int data, word;
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
1999-05-31 00:17:48 +04:00
|
|
|
#if DEBUG_FPE
|
|
|
|
printf("calc_ea: reg indirect (reg) = %p\n", ptr);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
if (ea->ea_flags & EA_OFFSET) {
|
|
|
|
/* apply the signed offset */
|
1999-05-31 00:17:48 +04:00
|
|
|
#if DEBUG_FPE
|
|
|
|
printf("calc_ea: offset %d\n", ea->ea_offset);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
ptr += ea->ea_offset;
|
|
|
|
} else if (ea->ea_flags & EA_INDEXED) {
|
1999-05-31 00:17:48 +04:00
|
|
|
#if DEBUG_FPE
|
|
|
|
printf("calc_ea: indexed mode\n");
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
|
|
|
|
if (ea->ea_flags & EA_BASE_SUPPRSS) {
|
|
|
|
/* base register is suppressed */
|
|
|
|
ptr = (char *)ea->ea_basedisp;
|
|
|
|
} else {
|
|
|
|
ptr += ea->ea_basedisp;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ea->ea_flags & EA_MEM_INDIR) {
|
1999-05-31 00:17:48 +04:00
|
|
|
#if DEBUG_FPE
|
|
|
|
printf("calc_ea: mem indir mode: basedisp=%08x, outerdisp=%08x\n",
|
|
|
|
ea->ea_basedisp, ea->ea_outerdisp);
|
|
|
|
printf("calc_ea: addr fetched from %p\n", ptr);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
/* memory indirect modes */
|
|
|
|
word = fusword(ptr);
|
|
|
|
if (word < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
word <<= 16;
|
|
|
|
data = fusword(ptr + 2);
|
|
|
|
if (data < 0) {
|
|
|
|
return SIGSEGV;
|
|
|
|
}
|
|
|
|
word |= data;
|
1999-05-31 00:17:48 +04:00
|
|
|
#if DEBUG_FPE
|
|
|
|
printf("calc_ea: fetched ptr 0x%08x\n", word);
|
|
|
|
#endif
|
Still incomplete, but much more complete FPE from Ken Nakata
<kenn@remus.rutgers.edu>. This emulator does not yet emulate
the following functions:
FSINH, FETOXM1, FTANH, FATAN, FASIN, FATANH, FSIN, FTAN,
FETOX, FTWOTOX, FTENTOX, FCOSH, FACOS, FCOS, FSINCOS
It is sufficient, however, to allow programs like df, w, and newfs,
to run to completion with correct results.
Portions of this code were based on the sparc fpe and on initial
work by gwr.
1995-11-03 07:46:55 +03:00
|
|
|
ptr = (char *)word + ea->ea_outerdisp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
*eaddr = ptr;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|