x
This commit is contained in:
parent
9b9df8be6e
commit
10bcaa2caf
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
tests/outputs/*
|
||||||
|
bld
|
||||||
@ -20,7 +20,12 @@ typedef lFunction::iterator ilFunction;
|
|||||||
|
|
||||||
|
|
||||||
/* SYMBOL TABLE */
|
/* SYMBOL TABLE */
|
||||||
struct SYM {
|
struct SYM
|
||||||
|
{
|
||||||
|
SYM() : label(0),size(0),flg(0),type(TYPE_UNKNOWN)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
char name[10]; /* New name for this variable */
|
char name[10]; /* New name for this variable */
|
||||||
dword label; /* physical address (20 bit) */
|
dword label; /* physical address (20 bit) */
|
||||||
Int size; /* maximum size */
|
Int size; /* maximum size */
|
||||||
@ -29,13 +34,7 @@ struct SYM {
|
|||||||
eDuVal duVal; /* DEF, USE, VAL */
|
eDuVal duVal; /* DEF, USE, VAL */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct SYMTAB
|
typedef std::vector<SYM> SYMTAB;
|
||||||
{
|
|
||||||
Int csym; /* No. of symbols in table */
|
|
||||||
Int alloc; /* Allocation */
|
|
||||||
SYM * sym; /* Symbols */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* CALL GRAPH NODE */
|
/* CALL GRAPH NODE */
|
||||||
struct CALL_GRAPH
|
struct CALL_GRAPH
|
||||||
{
|
{
|
||||||
|
|||||||
@ -332,7 +332,7 @@ struct DU1
|
|||||||
bool isLlFlag(dword flg) {return (ic.ll.flg&flg)==flg;}
|
bool isLlFlag(dword flg) {return (ic.ll.flg&flg)==flg;}
|
||||||
llIcode GetLlOpcode() const { return ic.ll.opcode; }
|
llIcode GetLlOpcode() const { return ic.ll.opcode; }
|
||||||
|
|
||||||
void writeIntComment(char *s);
|
void writeIntComment(std::ostringstream &s);
|
||||||
void setRegDU(byte regi, operDu du_in);
|
void setRegDU(byte regi, operDu du_in);
|
||||||
void invalidate();
|
void invalidate();
|
||||||
void newCallHl();
|
void newCallHl();
|
||||||
|
|||||||
@ -12,10 +12,6 @@ struct SYMTABLE
|
|||||||
std::string pSymName; /* Ptr to symbolic name or comment */
|
std::string pSymName; /* Ptr to symbolic name or comment */
|
||||||
dword symOff; /* Symbol image offset */
|
dword symOff; /* Symbol image offset */
|
||||||
Function *symProc; /* Procedure pointer */
|
Function *symProc; /* Procedure pointer */
|
||||||
word preHash; /* Hash value before the modulo */
|
|
||||||
word postHash; /* Hash value after the modulo */
|
|
||||||
word nextOvf; /* Next entry this hash bucket, or -1 */
|
|
||||||
word prevOvf; /* Back link in Ovf chain */
|
|
||||||
SYMTABLE() : symOff(0),symProc(0) {}
|
SYMTABLE() : symOff(0),symProc(0) {}
|
||||||
SYMTABLE(dword _sym,Function *_proc) : symOff(_sym),symProc(_proc)
|
SYMTABLE(dword _sym,Function *_proc) : symOff(_sym),symProc(_proc)
|
||||||
{}
|
{}
|
||||||
@ -36,6 +32,6 @@ enum tableType /* The table types */
|
|||||||
|
|
||||||
void createSymTables(void);
|
void createSymTables(void);
|
||||||
void destroySymTables(void);
|
void destroySymTables(void);
|
||||||
boolT readVal (char *symName, dword symOff, Function *symProc);
|
boolT readVal (std::ostringstream &symName, dword symOff, Function *symProc);
|
||||||
void selectTable(tableType); /* Select a particular table */
|
void selectTable(tableType); /* Select a particular table */
|
||||||
|
|
||||||
|
|||||||
@ -58,6 +58,10 @@ typedef unsigned char boolT; /* 8 bits */
|
|||||||
/* duVal FLAGS */
|
/* duVal FLAGS */
|
||||||
struct eDuVal
|
struct eDuVal
|
||||||
{
|
{
|
||||||
|
eDuVal()
|
||||||
|
{
|
||||||
|
def=use=val=0;
|
||||||
|
}
|
||||||
enum flgs
|
enum flgs
|
||||||
{
|
{
|
||||||
DEF=1,
|
DEF=1,
|
||||||
|
|||||||
@ -14,7 +14,7 @@ def perform_test(exepath,filepath,outname)
|
|||||||
filepath=path_local(filepath)
|
filepath=path_local(filepath)
|
||||||
printf("calling:" + "#{exepath} -a1 -o#{output_path}.a1 #{filepath}\n")
|
printf("calling:" + "#{exepath} -a1 -o#{output_path}.a1 #{filepath}\n")
|
||||||
result = `#{exepath} -a1 -o#{output_path}.a1 #{filepath}`
|
result = `#{exepath} -a1 -o#{output_path}.a1 #{filepath}`
|
||||||
result = `#{exepath} -a2 -o#{output_path}.a2 #{filepath}`
|
result = `#{exepath} -a2msc -o#{output_path}.a2 #{filepath}`
|
||||||
puts result
|
puts result
|
||||||
p $?
|
p $?
|
||||||
end
|
end
|
||||||
|
|||||||
12
src/ast.cpp
12
src/ast.cpp
@ -151,10 +151,10 @@ COND_EXPR *COND_EXPR::idGlob (int16 segValue, int16 off)
|
|||||||
newExp = newCondExp (IDENTIFIER);
|
newExp = newCondExp (IDENTIFIER);
|
||||||
newExp->expr.ident.idType = GLOB_VAR;
|
newExp->expr.ident.idType = GLOB_VAR;
|
||||||
adr = opAdr(segValue, off);
|
adr = opAdr(segValue, off);
|
||||||
for (i = 0; i < symtab.csym; i++)
|
for (i = 0; i < symtab.size(); i++)
|
||||||
if (symtab.sym[i].label == adr)
|
if (symtab[i].label == adr)
|
||||||
break;
|
break;
|
||||||
if (i == symtab.csym)
|
if (i == symtab.size())
|
||||||
printf ("Error, glob var not found in symtab\n");
|
printf ("Error, glob var not found in symtab\n");
|
||||||
newExp->expr.ident.idNode.globIdx = i;
|
newExp->expr.ident.idNode.globIdx = i;
|
||||||
return (newExp);
|
return (newExp);
|
||||||
@ -511,7 +511,7 @@ Int hlTypeSize (const COND_EXPR *expr, Function * pproc)
|
|||||||
switch (expr->expr.ident.idType)
|
switch (expr->expr.ident.idType)
|
||||||
{
|
{
|
||||||
case GLOB_VAR:
|
case GLOB_VAR:
|
||||||
return (symtab.sym[expr->expr.ident.idNode.globIdx].size);
|
return (symtab[expr->expr.ident.idNode.globIdx].size);
|
||||||
case REGISTER:
|
case REGISTER:
|
||||||
if (expr->expr.ident.regiType == BYTE_REG)
|
if (expr->expr.ident.regiType == BYTE_REG)
|
||||||
return (1);
|
return (1);
|
||||||
@ -574,7 +574,7 @@ hlType expType (const COND_EXPR *expr, Function * pproc)
|
|||||||
switch (expr->expr.ident.idType)
|
switch (expr->expr.ident.idType)
|
||||||
{
|
{
|
||||||
case GLOB_VAR:
|
case GLOB_VAR:
|
||||||
return (symtab.sym[expr->expr.ident.idNode.globIdx].type);
|
return (symtab[expr->expr.ident.idNode.globIdx].type);
|
||||||
case REGISTER:
|
case REGISTER:
|
||||||
if (expr->expr.ident.regiType == BYTE_REG)
|
if (expr->expr.ident.regiType == BYTE_REG)
|
||||||
return (TYPE_BYTE_SIGN);
|
return (TYPE_BYTE_SIGN);
|
||||||
@ -734,7 +734,7 @@ string walkCondExpr (const COND_EXPR* expr, Function * pProc, Int* numLoc)
|
|||||||
switch (expr->expr.ident.idType)
|
switch (expr->expr.ident.idType)
|
||||||
{
|
{
|
||||||
case GLOB_VAR:
|
case GLOB_VAR:
|
||||||
o << symtab.sym[expr->expr.ident.idNode.globIdx].name;
|
o << symtab[expr->expr.ident.idNode.globIdx].name;
|
||||||
break;
|
break;
|
||||||
case REGISTER:
|
case REGISTER:
|
||||||
id = &pProc->localId.id_arr[expr->expr.ident.idNode.regiIdx];
|
id = &pProc->localId.id_arr[expr->expr.ident.idNode.regiIdx];
|
||||||
|
|||||||
@ -146,14 +146,14 @@ static void writeGlobSymTable()
|
|||||||
char type[10];
|
char type[10];
|
||||||
SYM * pSym;
|
SYM * pSym;
|
||||||
|
|
||||||
if (symtab.csym)
|
if (not symtab.empty())
|
||||||
{
|
{
|
||||||
cCode.appendDecl( "/* Global variables */\n");
|
cCode.appendDecl( "/* Global variables */\n");
|
||||||
for (idx = 0; idx < symtab.csym; idx++)
|
for (idx = 0; idx < symtab.size(); idx++)
|
||||||
{
|
{
|
||||||
pSym = &symtab.sym[idx];
|
pSym = &symtab[idx];
|
||||||
if (symtab.sym[idx].duVal.isUSE_VAL()) /* first used */
|
if (symtab[idx].duVal.isUSE_VAL()) /* first used */
|
||||||
printGlobVar (&(symtab.sym[idx]));
|
printGlobVar (&symtab[idx]);
|
||||||
else { /* first defined */
|
else { /* first defined */
|
||||||
switch (pSym->size) {
|
switch (pSym->size) {
|
||||||
case 1: strcpy (type, "byte\t"); break;
|
case 1: strcpy (type, "byte\t"); break;
|
||||||
|
|||||||
@ -694,7 +694,7 @@ void STATE::checkStartup()
|
|||||||
but decides the model required. Note: must do the far data models
|
but decides the model required. Note: must do the far data models
|
||||||
(large and compact) before the others, since they are the same pattern
|
(large and compact) before the others, since they are the same pattern
|
||||||
as near data, just more pushes at the start. */
|
as near data, just more pushes at the start. */
|
||||||
if(prog.cbImage>0x180+sizeof(pattMainLarge))
|
if(prog.cbImage>startOff+0x180+sizeof(pattMainLarge))
|
||||||
{
|
{
|
||||||
if (locatePattern(prog.Image, startOff, startOff+0x180, pattMainLarge,sizeof(pattMainLarge), &i))
|
if (locatePattern(prog.Image, startOff, startOff+0x180, pattMainLarge,sizeof(pattMainLarge), &i))
|
||||||
{
|
{
|
||||||
|
|||||||
@ -8,10 +8,13 @@
|
|||||||
|
|
||||||
#include "dcc.h"
|
#include "dcc.h"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <sstream>
|
||||||
|
using namespace std;
|
||||||
#define intSize 40
|
#define intSize 40
|
||||||
|
|
||||||
static const char *int21h[] =
|
static const char *int21h[] =
|
||||||
{"Terminate process",
|
{
|
||||||
|
"Terminate process",
|
||||||
"Character input with echo",
|
"Character input with echo",
|
||||||
"Character output",
|
"Character output",
|
||||||
"Auxiliary input",
|
"Auxiliary input",
|
||||||
@ -144,33 +147,37 @@ static const char *intOthers[] = {
|
|||||||
|
|
||||||
/* Writes the description of the current interrupt. Appends it to the
|
/* Writes the description of the current interrupt. Appends it to the
|
||||||
* string s. */
|
* string s. */
|
||||||
void ICODE::writeIntComment (char *s)
|
void ICODE::writeIntComment (std::ostringstream &s)
|
||||||
{
|
{
|
||||||
char *t;
|
s<<"\t/* ";
|
||||||
|
|
||||||
t = (char *)allocMem(intSize * sizeof(char));
|
|
||||||
if (ic.ll.immed.op == 0x21)
|
if (ic.ll.immed.op == 0x21)
|
||||||
{ sprintf (t, "\t/* %s */\n", int21h[ic.ll.dst.off]);
|
{
|
||||||
strcat (s, t);
|
s <<int21h[ic.ll.dst.off];
|
||||||
}
|
}
|
||||||
else if (ic.ll.immed.op > 0x1F && ic.ll.immed.op < 0x2F)
|
else if (ic.ll.immed.op > 0x1F && ic.ll.immed.op < 0x2F)
|
||||||
{
|
{
|
||||||
sprintf (t, "\t/* %s */\n", intOthers[ic.ll.immed.op - 0x20]);
|
s <<intOthers[ic.ll.immed.op - 0x20];
|
||||||
strcat (s, t);
|
|
||||||
}
|
}
|
||||||
else if (ic.ll.immed.op == 0x2F)
|
else if (ic.ll.immed.op == 0x2F)
|
||||||
|
{
|
||||||
switch (ic.ll.dst.off)
|
switch (ic.ll.dst.off)
|
||||||
{
|
{
|
||||||
case 0x01 : strcat (s, "\t/* Print spooler */\n");
|
case 0x01 :
|
||||||
|
s << "Print spooler";
|
||||||
break;
|
break;
|
||||||
case 0x02: strcat (s, "\t/* Assign */\n");
|
case 0x02:
|
||||||
|
s << "Assign";
|
||||||
break;
|
break;
|
||||||
case 0x10: strcat (s, "\t/* Share */\n");
|
case 0x10:
|
||||||
|
s << "Share";
|
||||||
break;
|
break;
|
||||||
case 0xB7: strcat (s, "\t/* Append */\n");
|
case 0xB7:
|
||||||
|
s << "Append";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
strcat (s, "\n");
|
s<<"Unknown int";
|
||||||
|
s<<" */\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
10
src/dcc.cpp
10
src/dcc.cpp
@ -63,7 +63,7 @@ int main(int argc, char *argv[])
|
|||||||
if (option.Stats)
|
if (option.Stats)
|
||||||
displayTotalStats();
|
displayTotalStats();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
freeDataStructures(pProcList);
|
freeDataStructures(pProcList);
|
||||||
*/
|
*/
|
||||||
return 0;
|
return 0;
|
||||||
@ -77,9 +77,11 @@ static char *initargs(int argc, char *argv[])
|
|||||||
char *pc;
|
char *pc;
|
||||||
progname = *argv; /* Save invocation name for error messages */
|
progname = *argv; /* Save invocation name for error messages */
|
||||||
|
|
||||||
while (--argc > 0 && (*++argv)[0] == '-') {
|
while (--argc > 0 && (*++argv)[0] == '-')
|
||||||
|
{
|
||||||
for (pc = argv[0]+1; *pc; pc++)
|
for (pc = argv[0]+1; *pc; pc++)
|
||||||
switch (*pc) {
|
switch (*pc)
|
||||||
|
{
|
||||||
case 'a': /* Print assembler listing */
|
case 'a': /* Print assembler listing */
|
||||||
if (*(pc+1) == '2')
|
if (*(pc+1) == '2')
|
||||||
option.asm2 = TRUE;
|
option.asm2 = TRUE;
|
||||||
@ -118,7 +120,7 @@ static char *initargs(int argc, char *argv[])
|
|||||||
fatalError(INVALID_ARG, *pc);
|
fatalError(INVALID_ARG, *pc);
|
||||||
return *argv;
|
return *argv;
|
||||||
}
|
}
|
||||||
NextArg:;
|
NextArg:;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argc == 1)
|
if (argc == 1)
|
||||||
|
|||||||
316
src/disassem.cpp
316
src/disassem.cpp
@ -9,6 +9,8 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <malloc.h> /* For free() */
|
#include <malloc.h> /* For free() */
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include <sstream>
|
||||||
|
#include <iomanip>
|
||||||
#ifdef _CONSOLE
|
#ifdef _CONSOLE
|
||||||
#include <windows.h> /* For console mode routines */
|
#include <windows.h> /* For console mode routines */
|
||||||
#endif
|
#endif
|
||||||
@ -122,24 +124,24 @@ static const char *szIndex[8] = {"bx+si", "bx+di", "bp+si", "bp+di", "si", "di",
|
|||||||
static const char *szBreg[8] = { "al", "cl", "dl", "bl", "ah", "ch", "dh", "bh" };
|
static const char *szBreg[8] = { "al", "cl", "dl", "bl", "ah", "ch", "dh", "bh" };
|
||||||
static const char *szWreg[12] = { "ax", "cx", "dx", "bx", "sp", "bp", "si", "di",
|
static const char *szWreg[12] = { "ax", "cx", "dx", "bx", "sp", "bp", "si", "di",
|
||||||
"es", "cs", "ss", "ds" };
|
"es", "cs", "ss", "ds" };
|
||||||
static const char *szPtr[2] = { " word ptr ", " byte ptr " };
|
static const char *szPtr[2] = { "word ptr ", "byte ptr " };
|
||||||
|
|
||||||
|
|
||||||
static void dis1Line (Int i, Int pass);
|
static void dis1Line (Int i, Int pass);
|
||||||
void dis1LineOp(Int i, boolT fWin, char attr, word *len, Function * pProc);
|
void dis1LineOp(Int i, boolT fWin, char attr, word *len, Function * pProc);
|
||||||
static void formatRM(char *p, flags32 flg, ICODEMEM* pm);
|
static void formatRM(ostringstream &p, flags32 flg, ICODEMEM* pm);
|
||||||
static char *strDst(flags32 flg, ICODEMEM *pm);
|
static ostringstream &strDst(ostringstream &os, flags32 flg, ICODEMEM *pm);
|
||||||
static char *strSrc(ICODE * pc);
|
static ostringstream &strSrc(ostringstream &os, ICODE *pc, bool skip_comma=false);
|
||||||
static char *strHex(dword d);
|
static char *strHex(dword d);
|
||||||
static Int checkScanned(dword pcCur);
|
static Int checkScanned(dword pcCur);
|
||||||
static void setProc(Function * proc);
|
static void setProc(Function * proc);
|
||||||
static void dispData(word dataSeg);
|
static void dispData(word dataSeg);
|
||||||
static void flops(ICODE * pi);
|
void flops(ICODE *pIcode,std::ostringstream &out);
|
||||||
boolT callArg(word off, char *temp); /* Check for procedure name */
|
boolT callArg(word off, char *temp); /* Check for procedure name */
|
||||||
|
|
||||||
static FILE *fp;
|
static FILE *fp;
|
||||||
static CIcodeRec pc;
|
static CIcodeRec pc;
|
||||||
static char buf[200], *p;
|
static std::ostringstream buf;
|
||||||
static Int cb, j, numIcode, allocIcode, eop;
|
static Int cb, j, numIcode, allocIcode, eop;
|
||||||
static vector<int> pl;
|
static vector<int> pl;
|
||||||
static dword nextInst;
|
static dword nextInst;
|
||||||
@ -192,7 +194,7 @@ void disassem(Int pass, Function * ppProc)
|
|||||||
/* Open the output file (.a1 or .a2 only) */
|
/* Open the output file (.a1 or .a2 only) */
|
||||||
if (pass != 3)
|
if (pass != 3)
|
||||||
{
|
{
|
||||||
p = (pass == 1)? asm1_name: asm2_name;
|
auto p = (pass == 1)? asm1_name: asm2_name;
|
||||||
fp = fopen(p, "a+");
|
fp = fopen(p, "a+");
|
||||||
if (!fp)
|
if (!fp)
|
||||||
{
|
{
|
||||||
@ -260,8 +262,12 @@ void disassem(Int pass, Function * ppProc)
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
static void dis1Line(Int i, Int pass)
|
static void dis1Line(Int i, Int pass)
|
||||||
{
|
{
|
||||||
|
ostringstream oper_stream;
|
||||||
|
ostringstream hex_bytes;
|
||||||
|
ostringstream result_stream;
|
||||||
ICODE * pIcode = &pc[i];
|
ICODE * pIcode = &pc[i];
|
||||||
|
oper_stream << uppercase;
|
||||||
|
hex_bytes << uppercase;
|
||||||
/* Disassembly stage 1 --
|
/* Disassembly stage 1 --
|
||||||
* Do not try to display NO_CODE entries or synthetic instructions,
|
* Do not try to display NO_CODE entries or synthetic instructions,
|
||||||
* other than JMPs, that have been introduced for def/use analysis. */
|
* other than JMPs, that have been introduced for def/use analysis. */
|
||||||
@ -275,10 +281,6 @@ static void dis1Line(Int i, Int pass)
|
|||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* p points to the current position in buf[] */
|
|
||||||
p = (char*)memset(buf, ' ', sizeof(buf));
|
|
||||||
|
|
||||||
if (pIcode->ic.ll.flg & (TARGET | CASE))
|
if (pIcode->ic.ll.flg & (TARGET | CASE))
|
||||||
{
|
{
|
||||||
if (pass == 3)
|
if (pass == 3)
|
||||||
@ -298,97 +300,91 @@ static void dis1Line(Int i, Int pass)
|
|||||||
/* Output hexa code in program image */
|
/* Output hexa code in program image */
|
||||||
if (pass != 3)
|
if (pass != 3)
|
||||||
{
|
{
|
||||||
for (j = 0; j < cb; j++, p += 2)
|
for (j = 0; j < cb; j++)
|
||||||
sprintf(p, "%02X", prog.Image[pIcode->ic.ll.label + j]);
|
{
|
||||||
*p = ' ';
|
hex_bytes << hex << setw(2) << setfill('0') << uint16_t(prog.Image[pIcode->ic.ll.label + j]);
|
||||||
|
}
|
||||||
|
hex_bytes << ' ';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
oper_stream << setw(POS_LAB) << left<< hex_bytes.str();
|
||||||
/* Check if there is a symbol here */
|
/* Check if there is a symbol here */
|
||||||
selectTable(Label);
|
selectTable(Label);
|
||||||
if (readVal(&buf[POS_LAB], pIcode->ic.ll.label, 0))
|
oper_stream << setw(5)<<left; // align for the labels
|
||||||
{
|
{
|
||||||
buf[strlen(buf)] = ':'; /* Also removes the null */
|
ostringstream lab_contents;
|
||||||
|
if (readVal(lab_contents, pIcode->ic.ll.label, 0))
|
||||||
|
{
|
||||||
|
lab_contents << ':'; /* Also removes the null */
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (pIcode->ic.ll.flg & TARGET) /* Symbols override Lnn labels */
|
else if (pIcode->ic.ll.flg & TARGET) /* Symbols override Lnn labels */
|
||||||
{ /* Print label */
|
{
|
||||||
|
/* Print label */
|
||||||
if (! pl[i])
|
if (! pl[i])
|
||||||
{
|
{
|
||||||
pl[i] = ++lab;
|
pl[i] = ++lab;
|
||||||
}
|
}
|
||||||
if (pass == 3)
|
lab_contents<< "L"<<pl[i]<<':';
|
||||||
sprintf(buf, "L%ld", pl[i]);
|
}
|
||||||
else
|
oper_stream<< lab_contents.str();
|
||||||
sprintf(&buf[15], "L%ld", pl[i]);
|
|
||||||
buf[strlen(buf)] = ':'; /* Also removes the null */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pIcode->ic.ll.opcode == iSIGNEX && (pIcode->ic.ll.flg & B))
|
if (pIcode->ic.ll.opcode == iSIGNEX && (pIcode->ic.ll.flg & B))
|
||||||
{
|
{
|
||||||
pIcode->ic.ll.opcode = iCBW;
|
pIcode->ic.ll.opcode = iCBW;
|
||||||
}
|
}
|
||||||
|
oper_stream << setw(15) << left <<szOps[pIcode->ic.ll.opcode];
|
||||||
if (pass == 3)
|
|
||||||
{
|
|
||||||
strcpy (&buf[8], szOps[pIcode->ic.ll.opcode]);
|
|
||||||
buf[eop = strlen(buf)] = ' ';
|
|
||||||
p = buf + 8 + (POS_OPR - POS_OPC);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
strcpy(&buf[POS_OPC], szOps[pIcode->ic.ll.opcode]);
|
|
||||||
buf[eop = strlen(buf)] = ' ';
|
|
||||||
p = buf + POS_OPR;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (pIcode->ic.ll.opcode)
|
switch (pIcode->ic.ll.opcode)
|
||||||
{
|
{
|
||||||
case iADD: case iADC: case iSUB: case iSBB: case iAND: case iOR:
|
case iADD: case iADC: case iSUB: case iSBB: case iAND: case iOR:
|
||||||
case iXOR: case iTEST: case iCMP: case iMOV: case iLEA: case iXCHG:
|
case iXOR: case iTEST: case iCMP: case iMOV: case iLEA: case iXCHG:
|
||||||
strcpy(p, strDst(pIcode->ic.ll.flg, &pIcode->ic.ll.dst));
|
strDst(oper_stream,pIcode->ic.ll.flg, &pIcode->ic.ll.dst);
|
||||||
strcat(p, strSrc(pIcode));
|
strSrc(oper_stream,pIcode);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iESC:
|
case iESC:
|
||||||
flops(pIcode);
|
flops(pIcode,oper_stream);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iSAR: case iSHL: case iSHR: case iRCL: case iRCR: case iROL:
|
case iSAR: case iSHL: case iSHR: case iRCL: case iRCR: case iROL:
|
||||||
case iROR:
|
case iROR:
|
||||||
strcpy(p, strDst(pIcode->ic.ll.flg | I, &pIcode->ic.ll.dst));
|
strDst(oper_stream,pIcode->ic.ll.flg | I, &pIcode->ic.ll.dst);
|
||||||
strcat(p, (pIcode->ic.ll.flg & I)? strSrc(pIcode): ", cl");
|
if(pIcode->ic.ll.flg & I)
|
||||||
|
strSrc(oper_stream,pIcode);
|
||||||
|
else
|
||||||
|
oper_stream<<", cl";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iINC: case iDEC: case iNEG: case iNOT: case iPOP:
|
case iINC: case iDEC: case iNEG: case iNOT: case iPOP:
|
||||||
strcpy(p, strDst(pIcode->ic.ll.flg | I, &pIcode->ic.ll.dst));
|
strDst(oper_stream,pIcode->ic.ll.flg | I, &pIcode->ic.ll.dst);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iPUSH:
|
case iPUSH:
|
||||||
if (pIcode->ic.ll.flg & I)
|
if (pIcode->ic.ll.flg & I)
|
||||||
{
|
{
|
||||||
strcpy(p + WID_PTR, strHex(pIcode->ic.ll.immed.op));
|
oper_stream<<strHex(pIcode->ic.ll.immed.op);
|
||||||
|
// strcpy(p + WID_PTR, strHex(pIcode->ic.ll.immed.op));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
strcpy(p, strDst(pIcode->ic.ll.flg | I, &pIcode->ic.ll.dst));
|
strDst(oper_stream,pIcode->ic.ll.flg | I, &pIcode->ic.ll.dst);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iDIV: case iIDIV: case iMUL: case iIMUL: case iMOD:
|
case iDIV: case iIDIV: case iMUL: case iIMUL: case iMOD:
|
||||||
if (pIcode->ic.ll.flg & I)
|
if (pIcode->ic.ll.flg & I)
|
||||||
{
|
{
|
||||||
strcat(strcpy(p, strDst(pIcode->ic.ll.flg, &pIcode->ic.ll.dst)),", ");
|
strDst(oper_stream,pIcode->ic.ll.flg, &pIcode->ic.ll.dst) <<", ";
|
||||||
formatRM(p + strlen(p), pIcode->ic.ll.flg, &pIcode->ic.ll.src);
|
formatRM(oper_stream, pIcode->ic.ll.flg, &pIcode->ic.ll.src);
|
||||||
strcat(p, strSrc(pIcode));
|
strSrc(oper_stream,pIcode);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
strcpy(p, strDst(pIcode->ic.ll.flg | I, &pIcode->ic.ll.src));
|
strDst(oper_stream,pIcode->ic.ll.flg | I, &pIcode->ic.ll.src);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iLDS: case iLES: case iBOUND:
|
case iLDS: case iLES: case iBOUND:
|
||||||
strcpy(p, strDst(pIcode->ic.ll.flg, &pIcode->ic.ll.dst));
|
strDst(oper_stream,pIcode->ic.ll.flg, &pIcode->ic.ll.dst)<<", dword ptr";
|
||||||
strcat(strcat(p, ", dword ptr"), strSrc(pIcode)+1);
|
strSrc(oper_stream,pIcode,true);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iJB: case iJBE: case iJAE: case iJA:
|
case iJB: case iJBE: case iJAE: case iJA:
|
||||||
@ -401,14 +397,15 @@ static void dis1Line(Int i, Int pass)
|
|||||||
/* Check if there is a symbol here */
|
/* Check if there is a symbol here */
|
||||||
selectTable(Label);
|
selectTable(Label);
|
||||||
if ((pIcode->ic.ll.immed.op < (dword)numIcode) && /* Ensure in range */
|
if ((pIcode->ic.ll.immed.op < (dword)numIcode) && /* Ensure in range */
|
||||||
readVal(p+WID_PTR, pc[pIcode->ic.ll.immed.op].ic.ll.label, 0))
|
readVal(oper_stream, pc[pIcode->ic.ll.immed.op].ic.ll.label, 0))
|
||||||
{
|
{
|
||||||
break; /* Symbolic label. Done */
|
break; /* Symbolic label. Done */
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pIcode->ic.ll.flg & NO_LABEL)
|
if (pIcode->ic.ll.flg & NO_LABEL)
|
||||||
{
|
{
|
||||||
strcpy(p + WID_PTR, strHex(pIcode->ic.ll.immed.op));
|
//strcpy(p + WID_PTR, strHex(pIcode->ic.ll.immed.op));
|
||||||
|
oper_stream<<strHex(pIcode->ic.ll.immed.op);
|
||||||
}
|
}
|
||||||
else if (pIcode->ic.ll.flg & I)
|
else if (pIcode->ic.ll.flg & I)
|
||||||
{
|
{
|
||||||
@ -419,51 +416,48 @@ static void dis1Line(Int i, Int pass)
|
|||||||
}
|
}
|
||||||
if (pIcode->ic.ll.opcode == iJMPF)
|
if (pIcode->ic.ll.opcode == iJMPF)
|
||||||
{
|
{
|
||||||
sprintf(p, " far ptr L%ld", pl[j]);
|
oper_stream<<" far ptr ";
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
sprintf(p + WID_PTR, "L%ld", pl[j]);
|
|
||||||
}
|
}
|
||||||
|
oper_stream<<"L"<<pl[j];
|
||||||
}
|
}
|
||||||
else if (pIcode->ic.ll.opcode == iJMPF)
|
else if (pIcode->ic.ll.opcode == iJMPF)
|
||||||
{
|
{
|
||||||
strcat(strcpy(p-1, "dword ptr"), strSrc(pIcode)+1);
|
oper_stream<<"dword ptr";
|
||||||
|
strSrc(oper_stream,pIcode,true);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
strcpy(p, strDst(I, &pIcode->ic.ll.src));
|
strDst(oper_stream,I, &pIcode->ic.ll.src);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iCALL: case iCALLF:
|
case iCALL: case iCALLF:
|
||||||
if (pIcode->ic.ll.flg & I)
|
if (pIcode->ic.ll.flg & I)
|
||||||
{
|
{
|
||||||
sprintf(p, "%s ptr %s",(pIcode->ic.ll.opcode == iCALL) ?" near":" far",(pIcode->ic.ll.immed.proc.proc)->name);
|
if((pIcode->ic.ll.opcode == iCALL))
|
||||||
|
oper_stream<< "near";
|
||||||
|
else
|
||||||
|
oper_stream<< " far";
|
||||||
|
oper_stream<<" ptr "<<(pIcode->ic.ll.immed.proc.proc)->name;
|
||||||
}
|
}
|
||||||
else if (pIcode->ic.ll.opcode == iCALLF)
|
else if (pIcode->ic.ll.opcode == iCALLF)
|
||||||
{
|
{
|
||||||
strcat(strcpy(p, "dword ptr"),strSrc(pIcode)+1);
|
oper_stream<<"dword ptr ";
|
||||||
|
strSrc(oper_stream,pIcode,true);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
strDst(oper_stream,I, &pIcode->ic.ll.src);
|
||||||
strcpy(p, strDst(I, &pIcode->ic.ll.src));
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iENTER:
|
case iENTER:
|
||||||
strcat(strcpy(p + WID_PTR, strHex(pIcode->ic.ll.dst.off)), ", ");
|
oper_stream<<strHex(pIcode->ic.ll.dst.off)<<", ";
|
||||||
strcat(p, strHex(pIcode->ic.ll.immed.op));
|
oper_stream<<strHex(pIcode->ic.ll.immed.op);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iRET: case iRETF: case iINT:
|
case iRET: case iRETF: case iINT:
|
||||||
if (pIcode->ic.ll.flg & I)
|
if (pIcode->ic.ll.flg & I)
|
||||||
{
|
{
|
||||||
strcpy(p + WID_PTR, strHex(pIcode->ic.ll.immed.op));
|
oper_stream<<strHex(pIcode->ic.ll.immed.op);
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
buf[eop] = '\0';
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -476,46 +470,47 @@ static void dis1Line(Int i, Int pass)
|
|||||||
case iOUTS: case iREP_OUTS:
|
case iOUTS: case iREP_OUTS:
|
||||||
if (pIcode->ic.ll.src.segOver)
|
if (pIcode->ic.ll.src.segOver)
|
||||||
{
|
{
|
||||||
(pIcode->ic.ll.opcode == iOUTS || pIcode->ic.ll.opcode == iREP_OUTS)
|
bool is_dx_src=(pIcode->ic.ll.opcode == iOUTS || pIcode->ic.ll.opcode == iREP_OUTS);
|
||||||
? strcat(strcpy(p+WID_PTR,"dx, "), szPtr[pIcode->ic.ll.flg & B])
|
if(is_dx_src)
|
||||||
: strcpy(&buf[eop+1], szPtr[pIcode->ic.ll.flg & B]);
|
oper_stream<<"dx, "<<szPtr[pIcode->ic.ll.flg & B];
|
||||||
|
else
|
||||||
|
oper_stream<<szPtr[pIcode->ic.ll.flg & B];
|
||||||
if (pIcode->ic.ll.opcode == iLODS ||
|
if (pIcode->ic.ll.opcode == iLODS ||
|
||||||
pIcode->ic.ll.opcode == iREP_LODS ||
|
pIcode->ic.ll.opcode == iREP_LODS ||
|
||||||
pIcode->ic.ll.opcode == iOUTS ||
|
pIcode->ic.ll.opcode == iOUTS ||
|
||||||
pIcode->ic.ll.opcode == iREP_OUTS)
|
pIcode->ic.ll.opcode == iREP_OUTS)
|
||||||
{
|
{
|
||||||
strcat(p, szWreg[pIcode->ic.ll.src.segOver-rAX]);
|
oper_stream<<szWreg[pIcode->ic.ll.src.segOver-rAX];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
strcat(strcat(p, "es:[di], "),szWreg[pIcode->ic.ll.src.segOver - rAX]);
|
oper_stream<<"es:[di], "<<szWreg[pIcode->ic.ll.src.segOver - rAX];
|
||||||
}
|
}
|
||||||
strcat(p, ":[si]");
|
oper_stream<<":[si]";
|
||||||
}
|
}
|
||||||
else strcpy(&buf[eop], (pIcode->ic.ll.flg & B)? "B": "W");
|
else
|
||||||
|
oper_stream<<(pIcode->ic.ll.flg & B)? "B": "W";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iXLAT:
|
case iXLAT:
|
||||||
if (pIcode->ic.ll.src.segOver)
|
if (pIcode->ic.ll.src.segOver)
|
||||||
{
|
{
|
||||||
strcpy(&buf[eop+1], szPtr[1]);
|
oper_stream<<" "<<szPtr[1];
|
||||||
strcat(strcat(p, szWreg[pIcode->ic.ll.src.segOver-rAX]), ":[bx]");
|
oper_stream<<szWreg[pIcode->ic.ll.src.segOver-rAX]<<":[bx]";
|
||||||
}
|
}
|
||||||
else buf[eop] = '\0';
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iIN:
|
case iIN:
|
||||||
strcpy(p+WID_PTR, (pIcode->ic.ll.flg & B)?"al, ": "ax, ");
|
oper_stream<<(pIcode->ic.ll.flg & B)?"al, ": "ax, ";
|
||||||
strcat(p+WID_PTR, (pIcode->ic.ll.flg & I)? strHex(pIcode->ic.ll.immed.op): "dx");
|
oper_stream<<(pIcode->ic.ll.flg & I)? strHex(pIcode->ic.ll.immed.op): "dx";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case iOUT:
|
case iOUT:
|
||||||
strcpy(p+WID_PTR, (pIcode->ic.ll.flg & I)? strHex(pIcode->ic.ll.immed.op): "dx");
|
oper_stream<<(pIcode->ic.ll.flg & I)? strHex(pIcode->ic.ll.immed.op): "dx";
|
||||||
strcat(p+WID_PTR, (pIcode->ic.ll.flg & B)?", al": ", ax");
|
oper_stream<<(pIcode->ic.ll.flg & B)?", al": ", ax";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
buf[eop] = '\0';
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -526,76 +521,73 @@ static void dis1Line(Int i, Int pass)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (j = pIcode->ic.ll.label, fImpure = 0; j > 0 && j < (Int)nextInst;
|
for (j = pIcode->ic.ll.label, fImpure = 0; j > 0 && j < (Int)nextInst; j++)
|
||||||
j++)
|
|
||||||
{
|
{
|
||||||
fImpure |= BITMAP(j, BM_DATA);
|
fImpure |= BITMAP(j, BM_DATA);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
result_stream << setw(54) << left << oper_stream.str();
|
||||||
/* Check for user supplied comment */
|
/* Check for user supplied comment */
|
||||||
selectTable(Comment);
|
selectTable(Comment);
|
||||||
|
ostringstream cbuf;
|
||||||
if (readVal(cbuf, pIcode->ic.ll.label, 0))
|
if (readVal(cbuf, pIcode->ic.ll.label, 0))
|
||||||
{
|
{
|
||||||
buf[strlen(buf)] = ' '; /* Removes the null */
|
result_stream <<"; "<<cbuf.str();
|
||||||
buf[POS_CMT] = ';';
|
|
||||||
strcpy(buf+POS_CMT+1, cbuf);
|
|
||||||
}
|
}
|
||||||
|
else if (fImpure || (pIcode->ic.ll.flg & (SWITCH | CASE | SEG_IMMED | IMPURE | SYNTHETIC | TERMINATES)))
|
||||||
else if (fImpure || (pIcode->ic.ll.flg & (SWITCH | CASE | SEG_IMMED |
|
|
||||||
IMPURE | SYNTHETIC | TERMINATES)))
|
|
||||||
{
|
{
|
||||||
buf[strlen(buf)] = ' ';
|
|
||||||
buf[POS_CMT] = '\0';
|
|
||||||
if (pIcode->ic.ll.flg & CASE)
|
if (pIcode->ic.ll.flg & CASE)
|
||||||
{
|
{
|
||||||
sprintf(buf+POS_CMT, ";Case l%ld", pIcode->ic.ll.caseTbl.numEntries);
|
result_stream << ";Case l"<< pIcode->ic.ll.caseTbl.numEntries;
|
||||||
}
|
}
|
||||||
if (pIcode->ic.ll.flg & SWITCH)
|
if (pIcode->ic.ll.flg & SWITCH)
|
||||||
{
|
{
|
||||||
strcat(buf, ";Switch ");
|
result_stream << ";Switch ";
|
||||||
}
|
}
|
||||||
if (fImpure)
|
if (fImpure)
|
||||||
{
|
{
|
||||||
strcat(buf, ";Accessed as data ");
|
result_stream << ";Accessed as data ";
|
||||||
}
|
}
|
||||||
if (pIcode->ic.ll.flg & IMPURE)
|
if (pIcode->ic.ll.flg & IMPURE)
|
||||||
{
|
{
|
||||||
strcat(buf, ";Impure operand ");
|
result_stream << ";Impure operand ";
|
||||||
}
|
}
|
||||||
if (pIcode->ic.ll.flg & SEG_IMMED)
|
if (pIcode->ic.ll.flg & SEG_IMMED)
|
||||||
{
|
{
|
||||||
strcat(buf, ";Segment constant");
|
result_stream << ";Segment constant";
|
||||||
}
|
}
|
||||||
if (pIcode->ic.ll.flg & TERMINATES)
|
if (pIcode->ic.ll.flg & TERMINATES)
|
||||||
{
|
{
|
||||||
strcat(buf, ";Exit to DOS");
|
result_stream << ";Exit to DOS";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Comment on iINT icodes */
|
/* Comment on iINT icodes */
|
||||||
if (pIcode->ic.ll.opcode == iINT)
|
if (pIcode->ic.ll.opcode == iINT)
|
||||||
pIcode->writeIntComment (buf);
|
pIcode->writeIntComment (result_stream);
|
||||||
|
|
||||||
/* Display output line */
|
/* Display output line */
|
||||||
|
if(pass==3)
|
||||||
|
{
|
||||||
|
/* output to .b code buffer */
|
||||||
|
if (pIcode->isLlFlag(SYNTHETIC))
|
||||||
|
result_stream<<";Synthetic inst";
|
||||||
|
if (pass == 3) /* output to .b code buffer */
|
||||||
|
cCode.appendCode("%s\n", result_stream.str().c_str());
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
if (! (pIcode->ic.ll.flg & SYNTHETIC))
|
if (! (pIcode->ic.ll.flg & SYNTHETIC))
|
||||||
{
|
{
|
||||||
if (pass == 3) /* output to .b code buffer */
|
/* output to .a1 or .a2 file */
|
||||||
cCode.appendCode("%s\n", buf);
|
fprintf (fp, "%03ld %06lX %s\n", i, pIcode->ic.ll.label, result_stream.str().c_str());
|
||||||
else /* output to .a1 or .a2 file */
|
|
||||||
fprintf (fp, "%03ld %06lX %s\n", i, pIcode->ic.ll.label, buf);
|
|
||||||
}
|
}
|
||||||
else /* SYNTHETIC instruction */
|
else /* SYNTHETIC instruction */
|
||||||
{
|
{
|
||||||
strcat (buf, ";Synthetic inst");
|
result_stream<<";Synthetic inst";
|
||||||
if (pass == 3) /* output to .b code buffer */
|
fprintf (fp, "%03ld %s\n", i, result_stream.str().c_str());
|
||||||
{
|
|
||||||
cCode.appendCode("%s\n", buf);
|
|
||||||
}
|
|
||||||
else /* output to .a1 or .a2 file */
|
|
||||||
{
|
|
||||||
fprintf (fp, "%03ld %s\n", i, buf);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -605,7 +597,7 @@ static void dis1Line(Int i, Int pass)
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* formatRM
|
* formatRM
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
static void formatRM(char *p, flags32 flg, ICODEMEM *pm)
|
static void formatRM(std::ostringstream &p, flags32 flg, ICODEMEM *pm)
|
||||||
{
|
{
|
||||||
char seg[4];
|
char seg[4];
|
||||||
|
|
||||||
@ -617,71 +609,68 @@ static void formatRM(char *p, flags32 flg, ICODEMEM *pm)
|
|||||||
|
|
||||||
if (pm->regi == 0)
|
if (pm->regi == 0)
|
||||||
{
|
{
|
||||||
sprintf(p,"%s[%s]", seg, strHex((dword)pm->off));
|
p<<seg<<"["<<strHex((dword)pm->off)<<"]";
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (pm->regi == (INDEXBASE - 1))
|
else if (pm->regi == (INDEXBASE - 1))
|
||||||
{
|
{
|
||||||
strcpy (p, "tmp");
|
p<<"tmp";
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (pm->regi < INDEXBASE)
|
else if (pm->regi < INDEXBASE)
|
||||||
{
|
{
|
||||||
strcpy(p, (flg & B)? szBreg[pm->regi - rAL]: szWreg[pm->regi - rAX]);
|
if(flg & B)
|
||||||
|
p << szBreg[pm->regi - rAL];
|
||||||
|
else
|
||||||
|
p << szWreg[pm->regi - rAX];
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (pm->off)
|
else if (pm->off)
|
||||||
{
|
{
|
||||||
if (pm->off < 0)
|
if (pm->off < 0)
|
||||||
{
|
{
|
||||||
sprintf(p,"%s[%s-%s]", seg, szIndex[pm->regi - INDEXBASE],strHex((dword)(- pm->off)));
|
p <<seg<<"["<<szIndex[pm->regi - INDEXBASE]<<"-"<<strHex((dword)(- pm->off))<<"]";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sprintf(p,"%s[%s+%s]", seg, szIndex[pm->regi - INDEXBASE],strHex((dword)pm->off));
|
p <<seg<<"["<<szIndex[pm->regi - INDEXBASE]<<"+"<<strHex((dword)(pm->off))<<"]";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else sprintf(p,"%s[%s]", seg, szIndex[pm->regi - INDEXBASE]);
|
else
|
||||||
|
p <<seg<<"["<<szIndex[pm->regi - INDEXBASE]<<"]";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
* strDst
|
* strDst
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
static char *strDst(flags32 flg, ICODEMEM *pm)
|
static ostringstream & strDst(ostringstream &os,flags32 flg, ICODEMEM *pm)
|
||||||
{
|
{
|
||||||
static char buf[30];
|
|
||||||
|
|
||||||
/* Immediates to memory require size descriptor */
|
/* Immediates to memory require size descriptor */
|
||||||
|
//os << setw(WID_PTR);
|
||||||
if ((flg & I) && (pm->regi == 0 || pm->regi >= INDEXBASE))
|
if ((flg & I) && (pm->regi == 0 || pm->regi >= INDEXBASE))
|
||||||
{
|
os << szPtr[flg & B];
|
||||||
memcpy(buf, szPtr[flg & B], WID_PTR);
|
formatRM(os, flg, pm);
|
||||||
}
|
return os;
|
||||||
else
|
|
||||||
{
|
|
||||||
memset(buf, ' ', WID_PTR);
|
|
||||||
}
|
|
||||||
|
|
||||||
formatRM(buf + WID_PTR, flg, pm);
|
|
||||||
return buf;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* strSrc *
|
* strSrc *
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
static char *strSrc(ICODE *pc)
|
static ostringstream &strSrc(ostringstream &os,ICODE *pc,bool skip_comma)
|
||||||
{
|
{
|
||||||
static char buf[30] = {", "};
|
static char buf[30] = {", "};
|
||||||
|
if(false==skip_comma)
|
||||||
|
os<<", ";
|
||||||
if (pc->ic.ll.flg & I)
|
if (pc->ic.ll.flg & I)
|
||||||
strcpy(buf + 2, strHex(pc->ic.ll.immed.op));
|
os<<strHex(pc->ic.ll.immed.op);
|
||||||
else if (pc->ic.ll.flg & IM_SRC) /* level 2 */
|
else if (pc->ic.ll.flg & IM_SRC) /* level 2 */
|
||||||
strcpy (buf + 2, "dx:ax");
|
os<<"dx:ax";
|
||||||
else
|
else
|
||||||
formatRM(buf + 2, pc->ic.ll.flg, &pc->ic.ll.src);
|
formatRM(os, pc->ic.ll.flg, &pc->ic.ll.src);
|
||||||
|
|
||||||
return buf;
|
return os;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -707,7 +696,7 @@ void interactDis(Function * initProc, Int initIC)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Handle the floating point opcodes (icode iESC) */
|
/* Handle the floating point opcodes (icode iESC) */
|
||||||
static void flops(ICODE *pIcode)
|
void flops(ICODE *pIcode,std::ostringstream &out)
|
||||||
{
|
{
|
||||||
char bf[30];
|
char bf[30];
|
||||||
byte op = (byte)pIcode->ic.ll.immed.op;
|
byte op = (byte)pIcode->ic.ll.immed.op;
|
||||||
@ -717,11 +706,9 @@ static void flops(ICODE *pIcode)
|
|||||||
|
|
||||||
if ((pIcode->ic.ll.dst.regi == 0) || (pIcode->ic.ll.dst.regi >= INDEXBASE))
|
if ((pIcode->ic.ll.dst.regi == 0) || (pIcode->ic.ll.dst.regi >= INDEXBASE))
|
||||||
{
|
{
|
||||||
/* The mod/rm mod bits are not set to 11 (i.e. register).
|
/* The mod/rm mod bits are not set to 11 (i.e. register). This is the normal floating point opcode */
|
||||||
This is the normal floating point opcode */
|
out<<szFlops1[op]<<' ';
|
||||||
strcpy(&buf[POS_OPC], szFlops1[op]);
|
out <<setw(10);
|
||||||
buf[strlen(buf)] = ' ';
|
|
||||||
|
|
||||||
if ((op == 0x29) || (op == 0x1F))
|
if ((op == 0x29) || (op == 0x1F))
|
||||||
{
|
{
|
||||||
strcpy(bf, "tbyte ptr ");
|
strcpy(bf, "tbyte ptr ");
|
||||||
@ -753,8 +740,7 @@ static void flops(ICODE *pIcode)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
formatRM(bf + 10, pIcode->ic.ll.flg, &pIcode->ic.ll.dst);
|
formatRM(out, pIcode->ic.ll.flg, &pIcode->ic.ll.dst);
|
||||||
strcpy(p, bf);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -763,44 +749,44 @@ static void flops(ICODE *pIcode)
|
|||||||
normal opcodes. Because the opcodes are slightly different for
|
normal opcodes. Because the opcodes are slightly different for
|
||||||
this case (e.g. op=04 means FSUB if reg != 3, but FSUBR for
|
this case (e.g. op=04 means FSUB if reg != 3, but FSUBR for
|
||||||
reg == 3), a separate table is used (szFlops2). */
|
reg == 3), a separate table is used (szFlops2). */
|
||||||
|
|
||||||
switch (op)
|
switch (op)
|
||||||
{
|
{
|
||||||
case 0x0C:
|
case 0x0C:
|
||||||
strcpy(&buf[POS_OPC], szFlops0C[pIcode->ic.ll.dst.regi - rAX]);
|
out << szFlops0C[pIcode->ic.ll.dst.regi - rAX];
|
||||||
break;
|
break;
|
||||||
case 0x0D:
|
case 0x0D:
|
||||||
strcpy(&buf[POS_OPC], szFlops0D[pIcode->ic.ll.dst.regi - rAX]);
|
out << szFlops0D[pIcode->ic.ll.dst.regi - rAX];
|
||||||
break;
|
break;
|
||||||
case 0x0E:
|
case 0x0E:
|
||||||
strcpy(&buf[POS_OPC], szFlops0E[pIcode->ic.ll.dst.regi - rAX]);
|
out << szFlops0E[pIcode->ic.ll.dst.regi - rAX];
|
||||||
break;
|
break;
|
||||||
case 0x0F:
|
case 0x0F:
|
||||||
strcpy(&buf[POS_OPC], szFlops0F[pIcode->ic.ll.dst.regi - rAX]);
|
out << szFlops0F[pIcode->ic.ll.dst.regi - rAX];
|
||||||
break;
|
break;
|
||||||
case 0x15:
|
case 0x15:
|
||||||
strcpy(&buf[POS_OPC], szFlops15[pIcode->ic.ll.dst.regi - rAX]);
|
out << szFlops15[pIcode->ic.ll.dst.regi - rAX];
|
||||||
break;
|
break;
|
||||||
case 0x1C:
|
case 0x1C:
|
||||||
strcpy(&buf[POS_OPC], szFlops1C[pIcode->ic.ll.dst.regi - rAX]);
|
out << szFlops1C[pIcode->ic.ll.dst.regi - rAX];
|
||||||
break;
|
break;
|
||||||
case 0x33:
|
case 0x33:
|
||||||
strcpy(&buf[POS_OPC], szFlops33[pIcode->ic.ll.dst.regi - rAX]);
|
out << szFlops33[pIcode->ic.ll.dst.regi - rAX];
|
||||||
break;
|
break;
|
||||||
case 0x3C:
|
case 0x3C:
|
||||||
strcpy(&buf[POS_OPC], szFlops3C[pIcode->ic.ll.dst.regi - rAX]);
|
out << szFlops3C[pIcode->ic.ll.dst.regi - rAX];
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
strcpy(&buf[POS_OPC], szFlops2[op]);
|
out << szFlops2[op];
|
||||||
buf[strlen(buf)] = ' ';
|
|
||||||
if ((op >= 0x20) && (op <= 0x27))
|
if ((op >= 0x20) && (op <= 0x27))
|
||||||
{
|
{
|
||||||
/* This is the ST(i), ST form. */
|
/* This is the ST(i), ST form. */
|
||||||
sprintf(&buf[POS_OPR2], "ST(%d),ST", pIcode->ic.ll.dst.regi - rAX);
|
out << "ST("<<pIcode->ic.ll.dst.regi - rAX<<"),ST";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* ST, ST(i) */
|
/* ST, ST(i) */
|
||||||
sprintf(&buf[POS_OPR2], "ST,ST(%d)", pIcode->ic.ll.dst.regi - rAX);
|
out << "ST,ST("<<pIcode->ic.ll.dst.regi - rAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|||||||
@ -164,7 +164,7 @@ void Function::markImpure()
|
|||||||
{
|
{
|
||||||
if (Icode.GetLlFlag(i) & (SYM_USE | SYM_DEF))
|
if (Icode.GetLlFlag(i) & (SYM_USE | SYM_DEF))
|
||||||
{
|
{
|
||||||
psym = &symtab.sym[Icode.GetIcode(i)->ic.ll.caseTbl.numEntries];
|
psym = &symtab[Icode.GetIcode(i)->ic.ll.caseTbl.numEntries];
|
||||||
for (int c = (Int)psym->label; c < (Int)psym->label+psym->size; c++)
|
for (int c = (Int)psym->label; c < (Int)psym->label+psym->size; c++)
|
||||||
{
|
{
|
||||||
if (BITMAP(c, BM_CODE))
|
if (BITMAP(c, BM_CODE))
|
||||||
|
|||||||
@ -90,12 +90,12 @@ void parse (CALL_GRAPH * *pcallGraph)
|
|||||||
static void updateSymType (dword symbol, hlType symType, Int size)
|
static void updateSymType (dword symbol, hlType symType, Int size)
|
||||||
{ Int i;
|
{ Int i;
|
||||||
|
|
||||||
for (i = 0; i < symtab.csym; i++)
|
for (i = 0; i < symtab.size(); i++)
|
||||||
if (symtab.sym[i].label == symbol)
|
if (symtab[i].label == symbol)
|
||||||
{
|
{
|
||||||
symtab.sym[i].type = symType;
|
symtab[i].type = symType;
|
||||||
if (size != 0)
|
if (size != 0)
|
||||||
symtab.sym[i].size = size;
|
symtab[i].size = size;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -691,35 +691,34 @@ static SYM * updateGlobSym (dword operand, Int size, word duFlag)
|
|||||||
Int i;
|
Int i;
|
||||||
|
|
||||||
/* Check for symbol in symbol table */
|
/* Check for symbol in symbol table */
|
||||||
for (i = 0; i < symtab.csym; i++)
|
for (i = 0; i < symtab.size(); i++)
|
||||||
if (symtab.sym[i].label == operand) {
|
if (symtab[i].label == operand)
|
||||||
if (symtab.sym[i].size < size)
|
{
|
||||||
symtab.sym[i].size = size;
|
if (symtab[i].size < size)
|
||||||
|
symtab[i].size = size;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* New symbol, not in symbol table */
|
/* New symbol, not in symbol table */
|
||||||
if (i == symtab.csym) {
|
if (i == symtab.size())
|
||||||
if (++symtab.csym > symtab.alloc) {
|
{
|
||||||
symtab.alloc += 5;
|
SYM v;
|
||||||
symtab.sym = (SYM *)reallocVar(symtab.sym, symtab.alloc * sizeof(SYM));
|
sprintf (v.name, "var%05lX", operand);
|
||||||
memset (&symtab.sym[i], 0, 5 * sizeof(SYM));
|
v.label = operand;
|
||||||
}
|
v.size = size;
|
||||||
sprintf (symtab.sym[i].name, "var%05lX", operand);
|
v.type = cbType[size];
|
||||||
symtab.sym[i].label = operand;
|
|
||||||
symtab.sym[i].size = size;
|
|
||||||
symtab.sym[i].type = cbType[size];
|
|
||||||
if (duFlag == eDuVal::USE) /* must already have init value */
|
if (duFlag == eDuVal::USE) /* must already have init value */
|
||||||
{
|
{
|
||||||
symtab.sym[i].duVal.use =1; // USEVAL;
|
v.duVal.use =1; // USEVAL;
|
||||||
symtab.sym[i].duVal.val =1;
|
v.duVal.val =1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
symtab.sym[i].duVal.setFlags(duFlag);
|
v.duVal.setFlags(duFlag);
|
||||||
}
|
}
|
||||||
|
symtab.push_back(v);
|
||||||
}
|
}
|
||||||
return (&symtab.sym[i]);
|
return (&symtab[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -792,11 +791,12 @@ static SYM * lookupAddr (ICODEMEM *pm, STATE *pstate, Int size, word duFlag)
|
|||||||
else if (pstate->f[pm->seg]) { /* new value */
|
else if (pstate->f[pm->seg]) { /* new value */
|
||||||
pm->segValue = pstate->r[pm->seg];
|
pm->segValue = pstate->r[pm->seg];
|
||||||
operand = opAdr(pm->segValue, pm->off);
|
operand = opAdr(pm->segValue, pm->off);
|
||||||
i = symtab.csym;
|
i = symtab.size();
|
||||||
psym = updateGlobSym (operand, size, duFlag);
|
psym = updateGlobSym (operand, size, duFlag);
|
||||||
|
|
||||||
/* Flag new memory locations that are segment values */
|
/* Flag new memory locations that are segment values */
|
||||||
if (symtab.csym > i) {
|
if (symtab.size() > i)
|
||||||
|
{
|
||||||
if (size == 4)
|
if (size == 4)
|
||||||
operand += 2; /* High word */
|
operand += 2; /* High word */
|
||||||
for (i = 0; i < prog.cReloc; i++)
|
for (i = 0; i < prog.cReloc; i++)
|
||||||
@ -939,7 +939,7 @@ static void use (opLoc d, ICODE * pIcode, Function * pProc, STATE * pstate, Int
|
|||||||
{
|
{
|
||||||
setBits (BM_DATA, psym->label, (dword)size);
|
setBits (BM_DATA, psym->label, (dword)size);
|
||||||
pIcode->ic.ll.flg |= SYM_USE;
|
pIcode->ic.ll.flg |= SYM_USE;
|
||||||
pIcode->ic.ll.caseTbl.numEntries = psym - symtab.sym;
|
pIcode->ic.ll.caseTbl.numEntries = psym - &symtab[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -988,7 +988,7 @@ static void def (opLoc d, ICODE * pIcode, Function * pProc, STATE * pstate, Int
|
|||||||
{
|
{
|
||||||
setBits(BM_DATA, psym->label, (dword)size);
|
setBits(BM_DATA, psym->label, (dword)size);
|
||||||
pIcode->ic.ll.flg |= SYM_DEF;
|
pIcode->ic.ll.flg |= SYM_DEF;
|
||||||
pIcode->ic.ll.caseTbl.numEntries = psym - symtab.sym;
|
pIcode->ic.ll.caseTbl.numEntries = psym - &symtab[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -28,7 +28,7 @@
|
|||||||
#include "symtab.h"
|
#include "symtab.h"
|
||||||
|
|
||||||
#define TABLESIZE 16 /* Number of entries added each expansion */
|
#define TABLESIZE 16 /* Number of entries added each expansion */
|
||||||
/* Probably has to be a power of 2 */
|
/* Probably has to be a power of 2 */
|
||||||
#define STRTABSIZE 256 /* Size string table is inc'd by */
|
#define STRTABSIZE 256 /* Size string table is inc'd by */
|
||||||
#define NIL ((word)-1)
|
#define NIL ((word)-1)
|
||||||
using namespace std;
|
using namespace std;
|
||||||
@ -51,6 +51,10 @@ struct hash<SYMTABLE> : public unary_function<const SYMTABLE &,size_t>
|
|||||||
static tableType curTableType; /* Which table is current */
|
static tableType curTableType; /* Which table is current */
|
||||||
struct TABLEINFO_TYPE
|
struct TABLEINFO_TYPE
|
||||||
{
|
{
|
||||||
|
TABLEINFO_TYPE()
|
||||||
|
{
|
||||||
|
symTab=valTab=0;
|
||||||
|
}
|
||||||
void deleteVal(dword symOff, Function *symProc, boolT bSymToo);
|
void deleteVal(dword symOff, Function *symProc, boolT bSymToo);
|
||||||
void create(tableType type);
|
void create(tableType type);
|
||||||
void destroy();
|
void destroy();
|
||||||
@ -75,21 +79,16 @@ void TABLEINFO_TYPE::create(tableType type)
|
|||||||
case Comment:
|
case Comment:
|
||||||
numEntry = 0;
|
numEntry = 0;
|
||||||
tableSize = TABLESIZE;
|
tableSize = TABLESIZE;
|
||||||
valTab = (SYMTABLE*)allocMem(sizeof(SYMTABLE) * TABLESIZE);
|
valTab = new SYMTABLE [TABLESIZE];
|
||||||
symTab = 0;
|
symTab = 0;
|
||||||
memset(valTab, 0, sizeof(SYMTABLE) * TABLESIZE);
|
|
||||||
break;
|
break;
|
||||||
case Label:
|
case Label:
|
||||||
currentTabInfo.numEntry = 0;
|
currentTabInfo.numEntry = 0;
|
||||||
currentTabInfo.tableSize = TABLESIZE;
|
currentTabInfo.tableSize = TABLESIZE;
|
||||||
currentTabInfo.symTab = (SYMTABLE*)allocMem(sizeof(SYMTABLE) * TABLESIZE);
|
currentTabInfo.symTab = new SYMTABLE [TABLESIZE];
|
||||||
memset(currentTabInfo.symTab, 0, sizeof(SYMTABLE) * TABLESIZE);
|
currentTabInfo.valTab = new SYMTABLE [TABLESIZE];
|
||||||
|
|
||||||
currentTabInfo.valTab = (SYMTABLE*)allocMem(sizeof(SYMTABLE) * TABLESIZE);
|
|
||||||
memset(currentTabInfo.valTab, 0, sizeof(SYMTABLE) * TABLESIZE);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void createSymTables(void)
|
void createSymTables(void)
|
||||||
@ -109,10 +108,6 @@ void createSymTables(void)
|
|||||||
strTabNext = 0;
|
strTabNext = 0;
|
||||||
pStrTab = (char *)allocMem(STRTABSIZE);
|
pStrTab = (char *)allocMem(STRTABSIZE);
|
||||||
|
|
||||||
// tableInfo[Label].symTab = currentTabInfo.symTab;
|
|
||||||
// tableInfo[Label].valTab = currentTabInfo.valTab;
|
|
||||||
// tableInfo[Label].numEntry = currentTabInfo.numEntry;
|
|
||||||
// tableInfo[Label].tableSize = currentTabInfo.tableSize;
|
|
||||||
curTableType = Label;
|
curTableType = Label;
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -126,11 +121,8 @@ void selectTable(tableType tt)
|
|||||||
}
|
}
|
||||||
void TABLEINFO_TYPE::destroy()
|
void TABLEINFO_TYPE::destroy()
|
||||||
{
|
{
|
||||||
if(symTab)
|
delete [] symTab; // The symbol hashed label table
|
||||||
free(symTab); // The symbol hashed label table
|
delete [] valTab; // And the value hashed label table
|
||||||
if(valTab)
|
|
||||||
free(valTab); // And the value hashed label table
|
|
||||||
|
|
||||||
}
|
}
|
||||||
void destroySymTables(void)
|
void destroySymTables(void)
|
||||||
{
|
{
|
||||||
@ -141,7 +133,7 @@ void destroySymTables(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Using the value, read the symbolic name */
|
/* Using the value, read the symbolic name */
|
||||||
boolT readVal(char *symName, dword symOff, Function * symProc)
|
boolT readVal(std::ostringstream &symName, dword symOff, Function * symProc)
|
||||||
{
|
{
|
||||||
return false; // no symbolic names for now
|
return false; // no symbolic names for now
|
||||||
}
|
}
|
||||||
|
|||||||
@ -31,7 +31,7 @@ long LMOD@ (long arg0, int arg2, int arg3)
|
|||||||
OR bx, bx
|
OR bx, bx
|
||||||
JE L2
|
JE L2
|
||||||
|
|
||||||
L1: TEST di, 1
|
L1: TEST di, 1
|
||||||
JNE L3
|
JNE L3
|
||||||
OR dx, dx
|
OR dx, dx
|
||||||
JNS L4
|
JNS L4
|
||||||
@ -40,20 +40,20 @@ L1: TEST di, 1
|
|||||||
SBB dx, 0
|
SBB dx, 0
|
||||||
OR di, 0Ch
|
OR di, 0Ch
|
||||||
|
|
||||||
L4: OR cx, cx
|
L4: OR cx, cx
|
||||||
JNS L3
|
JNS L3
|
||||||
NEG cx
|
NEG cx
|
||||||
NEG bx
|
NEG bx
|
||||||
SBB cx, 0
|
SBB cx, 0
|
||||||
XOR di, 4
|
XOR di, 4
|
||||||
|
|
||||||
L3: MOV bp, cx
|
L3: MOV bp, cx
|
||||||
MOV cx, 20h
|
MOV cx, 20h
|
||||||
PUSH di
|
PUSH di
|
||||||
XOR di, 0
|
XOR di, 0
|
||||||
XOR si, 0
|
XOR si, 0
|
||||||
|
|
||||||
L5: SHL ax, 1
|
L5: SHL ax, 1
|
||||||
RCL dx, 1
|
RCL dx, 1
|
||||||
RCL si, 1
|
RCL si, 1
|
||||||
RCL di, 1
|
RCL di, 1
|
||||||
@ -63,11 +63,11 @@ L5: SHL ax, 1
|
|||||||
CMP si, bx
|
CMP si, bx
|
||||||
JB L6
|
JB L6
|
||||||
|
|
||||||
L7: SUB si, bx
|
L7: SUB si, bx
|
||||||
SBB di, bp
|
SBB di, bp
|
||||||
INC ax
|
INC ax
|
||||||
|
|
||||||
L6: LOOP L5
|
L6: LOOP L5
|
||||||
POP bx
|
POP bx
|
||||||
TEST bx, 2
|
TEST bx, 2
|
||||||
JE L8
|
JE L8
|
||||||
@ -75,25 +75,25 @@ L6: LOOP L5
|
|||||||
MOV dx, di
|
MOV dx, di
|
||||||
SHR bx, 1
|
SHR bx, 1
|
||||||
|
|
||||||
L8: TEST bx, 4
|
L8: TEST bx, 4
|
||||||
JE L9
|
JE L9
|
||||||
NEG dx
|
NEG dx
|
||||||
NEG ax
|
NEG ax
|
||||||
SBB dx, 0
|
SBB dx, 0
|
||||||
|
|
||||||
L9: POP di
|
L9: POP di
|
||||||
POP si
|
POP si
|
||||||
POP bp
|
POP bp
|
||||||
RETF 8
|
RETF 8
|
||||||
|
|
||||||
L2: MOV tmp, dx:ax ;Synthetic inst
|
L2: MOV tmp, dx:ax ;Synthetic inst
|
||||||
DIV bx
|
DIV bx
|
||||||
MOD bx ;Synthetic inst
|
MOD bx ;Synthetic inst
|
||||||
TEST di, 2
|
TEST di, 2
|
||||||
JE L10
|
JE L10
|
||||||
MOV ax, dx
|
MOV ax, dx
|
||||||
|
|
||||||
L10: XOR dx, dx
|
L10: XOR dx, dx
|
||||||
JMP L9
|
JMP L9
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -8,7 +8,7 @@
|
|||||||
006 000111 7735 JA L1
|
006 000111 7735 JA L1
|
||||||
007 000113 8BD8 MOV bx, ax
|
007 000113 8BD8 MOV bx, ax
|
||||||
008 000115 D1E3 SHL bx, 1
|
008 000115 D1E3 SHL bx, 1
|
||||||
009 000117 2EFFA71C00 JMP word ptr cs:[bx+1Ch] ;Switch
|
009 000117 2EFFA71C00 JMP word ptr cs:[bx+1Ch];Switch
|
||||||
|
|
||||||
010 00012A B80200 MOV ax, 2 ;Case l0
|
010 00012A B80200 MOV ax, 2 ;Case l0
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user