158 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
static char *sccsid =
 | 
						||
   "@(#) disfp.c, Ver. 2.1 created 00:00:00 87/09/01";
 | 
						||
 | 
						||
 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 | 
						||
  *                                                         *
 | 
						||
  *  Copyright (C) 1987 G. M. Harding, all rights reserved  *
 | 
						||
  *                                                         *
 | 
						||
  * Permission to copy and  redistribute is hereby granted, *
 | 
						||
  * provided full source code,  with all copyright notices, *
 | 
						||
  * accompanies any redistribution.                         *
 | 
						||
  *                                                         *
 | 
						||
  * This file contains handler routines for the numeric op- *
 | 
						||
  * codes of the 8087 co-processor,  as well as a few other *
 | 
						||
  * opcodes which are related to 8087 emulation.            *
 | 
						||
  *                                                         *
 | 
						||
  * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
 | 
						||
 | 
						||
#include "dis.h"              /* Disassembler declarations  */
 | 
						||
 | 
						||
#define FPINT0 0xd8           /* Floating-point interrupts  */
 | 
						||
#define FPINT1 0xd9
 | 
						||
#define FPINT2 0xda
 | 
						||
#define FPINT3 0xdb
 | 
						||
#define FPINT4 0xdc
 | 
						||
#define FPINT5 0xdd
 | 
						||
#define FPINT6 0xde
 | 
						||
#define FPINT7 0xdf
 | 
						||
 | 
						||
                              /* Test for floating opcodes  */
 | 
						||
#define ISFLOP(x) \
 | 
						||
   (((x) >= FPINT0) && ((x) <= FPINT7))
 | 
						||
 | 
						||
 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 | 
						||
  *                                                         *
 | 
						||
  * This is the  handler for the escape  family of opcodes. *
 | 
						||
  * These opcodes place the contents of a specified  memory *
 | 
						||
  * location on the system bus,  for access by a peripheral *
 | 
						||
  * or by a co-processor such as the 8087. (The 8087 NDP is *
 | 
						||
  * accessed  only  via bus  escapes.)  Due to a bug in the *
 | 
						||
  * PC/IX assembler,  the "esc" mnemonic is not recognized; *
 | 
						||
  * consequently,  escape opcodes are disassembled as .byte *
 | 
						||
  * directives,  with the appropriate  mnemonic and operand *
 | 
						||
  * included as a comment.  FOR NOW, those escape sequences *
 | 
						||
  * corresponding  to 8087  opcodes  are  treated as simple *
 | 
						||
  * escapes.                                                *
 | 
						||
  *                                                         *
 | 
						||
  * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
 | 
						||
 | 
						||
void
 | 
						||
eshand(j)
 | 
						||
 | 
						||
   register int j;            /* Pointer to optab[] entry   */
 | 
						||
 | 
						||
{/* * * * * * * * * *  START OF eshand()  * * * * * * * * * */
 | 
						||
 | 
						||
   register char *a;
 | 
						||
   register int k;
 | 
						||
 | 
						||
   objini(j);
 | 
						||
 | 
						||
   FETCH(k);
 | 
						||
 | 
						||
   a = mtrans((j & 0xfd),(k & 0xc7),TR_STD);
 | 
						||
 | 
						||
   mtrunc(a);
 | 
						||
 | 
						||
   printf("\t.byte\t0x%02.2x\t\t| esc\t%s\n",j,a);
 | 
						||
 | 
						||
   for (k = 1; k < objptr; ++k)
 | 
						||
      printf("\t.byte\t0x%02.2x\n",objbuf[k]);
 | 
						||
 | 
						||
}/* * * * * * * * * * * END OF eshand() * * * * * * * * * * */
 | 
						||
 | 
						||
 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 | 
						||
  *                                                         *
 | 
						||
  * This is the handler routine for floating-point opcodes. *
 | 
						||
  * Since PC/IX must  accommodate  systems with and without *
 | 
						||
  * 8087 co-processors, it allows floating-point operations *
 | 
						||
  * to be  initiated  in either of two ways:  by a software *
 | 
						||
  * interrput whose type is in the range 0xd8 through 0xdf, *
 | 
						||
  * or by a CPU escape sequence, which is invoked by an op- *
 | 
						||
  * code in the same range.  In either case, the subsequent *
 | 
						||
  * byte determines the actual numeric operation to be per- *
 | 
						||
  * formed.  However,  depending  on the  method of access, *
 | 
						||
  * either  one or two code bytes will  precede  that byte, *
 | 
						||
  * and the fphand()  routine has no way of knowing whether *
 | 
						||
  * it was invoked by  interrupt or by an escape  sequence. *
 | 
						||
  * Therefore, unlike all of the other handler routines ex- *
 | 
						||
  * cept dfhand(),  fphand() does not initialize the object *
 | 
						||
  * buffer, leaving that chore to the caller.               *
 | 
						||
  *                                                         *
 | 
						||
  * FOR NOW,  fphand()  does not disassemble floating-point *
 | 
						||
  * opcodes to floating  mnemonics,  but simply outputs the *
 | 
						||
  * object code as .byte directives.                        *
 | 
						||
  *                                                         *
 | 
						||
  * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
 | 
						||
 | 
						||
void
 | 
						||
fphand(j)
 | 
						||
 | 
						||
   register int j;            /* Pointer to optab[] entry   */
 | 
						||
 | 
						||
{/* * * * * * * * * *  START OF fphand()  * * * * * * * * * */
 | 
						||
 | 
						||
   register int k;
 | 
						||
 | 
						||
   segflg = 0;
 | 
						||
 | 
						||
   FETCH(k);
 | 
						||
 | 
						||
   printf("\t.byte\t0x%02.2x\t\t| 8087 code sequence\n",
 | 
						||
    objbuf[0]);
 | 
						||
 | 
						||
   for (k = 1; k < objptr; ++k)
 | 
						||
      printf("\t.byte\t0x%02.2x\n",objbuf[k]);
 | 
						||
 | 
						||
/* objout();                                       FOR NOW  */
 | 
						||
 | 
						||
}/* * * * * * * * * * * END OF fphand() * * * * * * * * * * */
 | 
						||
 | 
						||
 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 | 
						||
  *                                                         *
 | 
						||
  * This is the  handler for  variable  software  interrupt *
 | 
						||
  * opcodes.  It is included in this file because PC/IX im- *
 | 
						||
  * plements its software floating-point emulation by means *
 | 
						||
  * of interrupts.  Any interrupt in the range 0xd8 through *
 | 
						||
  * 0xdf is an  NDP-emulation  interrupt,  and is specially *
 | 
						||
  * handled by the assembler.                               *
 | 
						||
  *                                                         *
 | 
						||
  * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
 | 
						||
 | 
						||
void
 | 
						||
inhand(j)
 | 
						||
 | 
						||
   register int j;            /* Pointer to optab[] entry   */
 | 
						||
 | 
						||
{/* * * * * * * * * *  START OF inhand()  * * * * * * * * * */
 | 
						||
 | 
						||
   register int k;
 | 
						||
 | 
						||
   objini(j);
 | 
						||
 | 
						||
   FETCH(k);
 | 
						||
 | 
						||
   if (ISFLOP(k))
 | 
						||
      {
 | 
						||
      fphand(k);
 | 
						||
      return;
 | 
						||
      }
 | 
						||
 | 
						||
   printf("%s\t%d\n",optab[j].text,k);
 | 
						||
 | 
						||
   objout();
 | 
						||
 | 
						||
}/* * * * * * * * * * * END OF inhand() * * * * * * * * * * */
 | 
						||
 | 
						||
 |