/* deco6800.c */
/*****************************************************************************/
/* SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only */
/* */
/* */
/* Dissector 6800/02 */
/* */
/*****************************************************************************/
#include "stdinc.h"
#include <ctype.h>
#include "dasmdef.h"
#include "cpulist.h"
#include "codechunks.h"
#include "invaddress.h"
#include "strutil.h"
#include "deco68.h"
static unsigned nData;
static CPUVar CPU6800, CPU6802;
typedef enum
{
eUnknown,
eImplicit,
eDirect,
eIndexed,
eExtended,
eImmediate,
eRelative
} tAddrType;
typedef struct
{
tAddrType Type;
Byte OpSize, NextAddresses;
const char *Memo;
} tOpcodeList;
static const tOpcodeList OpcodeList[256] =
{
/* 0x00 */ { eUnknown , 0, 0, NULL },
/* 0x01 */ { eImplicit , 0, 1, "nop" },
/* 0x02 */ { eUnknown , 0, 0, NULL },
/* 0x03 */ { eUnknown , 0, 0, NULL },
/* 0x04 */ { eUnknown , 0, 0, NULL },
/* 0x05 */ { eUnknown , 0, 0, NULL },
/* 0x06 */ { eImplicit , 0, 1, "tap" },
/* 0x07 */ { eImplicit , 0, 1, "tpa" },
/* 0x08 */ { eImplicit , 1, 1, "inx" },
/* 0x09 */ { eImplicit , 1, 1, "dex" },
/* 0x0a */ { eImplicit , 0, 0, "clv" },
/* 0x0b */ { eImplicit , 0, 0, "sev" },
/* 0x0c */ { eImplicit , 0, 1, "clc" },
/* 0x0d */ { eImplicit , 0, 1, "sec" },
/* 0x0e */ { eImplicit , 0, 1, "cli" },
/* 0x0f */ { eImplicit , 0, 1, "sei" },
/* 0x10 */ { eImplicit , 0, 1, "sba" },
/* 0x11 */ { eImplicit , 0, 1, "cba" },
/* 0x12 */ { eUnknown , 0, 0, NULL },
/* 0x13 */ { eUnknown , 0, 0, NULL },
/* 0x14 */ { eImplicit , 0, 1, "nba" },
/* 0x15 */ { eUnknown , 0, 0, NULL },
/* 0x16 */ { eImplicit , 0, 1, "tab" },
/* 0x17 */ { eImplicit , 0, 1, "tba" },
/* 0x18 */ { eUnknown , 0, 0, NULL },
/* 0x19 */ { eImplicit , 0, 1, "daa" },
/* 0x1a */ { eUnknown , 0, 0, NULL },
/* 0x1b */ { eImplicit , 0, 1, "aba" },
/* 0x1c */ { eUnknown , 0, 0, NULL },
/* 0x1d */ { eUnknown , 0, 0, NULL },
/* 0x1e */ { eUnknown , 0, 0, NULL },
/* 0x1f */ { eUnknown , 0, 0, NULL },
/* 0x20 */ { eRelative , 0, 2, "bra" },
/* 0x21 */ { eUnknown , 0, 0, NULL },
/* 0x22 */ { eRelative , 0, 3, "bhi" },
/* 0x23 */ { eRelative , 0, 3, "bls" },
/* 0x24 */ { eRelative , 0, 3, "bcc" },
/* 0x25 */ { eRelative , 0, 3, "bcs" },
/* 0x26 */ { eRelative , 0, 3, "bne" },
/* 0x27 */ { eRelative , 0, 3, "beq" },
/* 0x28 */ { eRelative , 0, 3, "bvc" },
/* 0x29 */ { eRelative , 0, 3, "bvs" },
/* 0x2a */ { eRelative , 0, 3, "bpl" },
/* 0x2b */ { eRelative , 0, 3, "bmi" },
/* 0x2c */ { eRelative , 0, 3, "bge" },
/* 0x2d */ { eRelative , 0, 3, "blt" },
/* 0x2e */ { eRelative , 0, 3, "bgt" },
/* 0x2f */ { eRelative , 0, 3, "ble" },
/* 0x30 */ { eImplicit , 1, 1, "tsx" },
/* 0x31 */ { eImplicit , 1, 1, "ins" },
/* 0x32 */ { eImplicit , 0, 1, "pula" },
/* 0x33 */ { eImplicit , 0, 1, "pulb" },
/* 0x34 */ { eImplicit , 0, 0, "dess" },
/* 0x35 */ { eImplicit , 0, 0, "txs" },
/* 0x36 */ { eImplicit , 0, 1, "psha" },
/* 0x37 */ { eImplicit , 0, 1, "pshb" },
/* 0x38 */ { eUnknown , 0, 0, NULL },
/* 0x39 */ { eImplicit , 0, 0, "rts" },
/* 0x3a */ { eUnknown , 0, 0, NULL },
/* 0x3b */ { eImplicit , 0, 0, "rti" },
/* 0x3c */ { eUnknown , 0, 0, NULL },
/* 0x3d */ { eUnknown , 0, 0, NULL },
/* 0x3e */ { eImplicit , 0, 1, "wai" },
/* 0x3f */ { eImplicit , 0, 1, "swi" },
/* 0x40 */ { eImplicit , 0, 1, "nega" },
/* 0x41 */ { eUnknown , 0, 0, NULL },
/* 0x42 */ { eUnknown , 0, 0, NULL },
/* 0x43 */ { eImplicit , 0, 1, "coma" },
/* 0x44 */ { eImplicit , 0, 1, "lsra" },
/* 0x45 */ { eUnknown , 0, 0, NULL },
/* 0x46 */ { eImplicit , 0, 1, "rora" },
/* 0x47 */ { eImplicit , 0, 1, "asra" },
/* 0x48 */ { eImplicit , 0, 1, "asla" },
/* 0x49 */ { eImplicit , 0, 1, "rola" },
/* 0x4a */ { eImplicit , 0, 1, "deca" },
/* 0x4b */ { eUnknown , 0, 0, NULL },
/* 0x4c */ { eImplicit , 0, 1, "inca" },
/* 0x4d */ { eImplicit , 0, 1, "tsta" },
/* 0x4e */ { eUnknown , 0, 0, NULL },
/* 0x4f */ { eImplicit , 0, 1, "clra" },
/* 0x50 */ { eImplicit , 0, 1, "negb" },
/* 0x51 */ { eUnknown , 0, 0, NULL },
/* 0x52 */ { eUnknown , 0, 0, NULL },
/* 0x53 */ { eImplicit , 0, 1, "comb" },
/* 0x54 */ { eImplicit , 0, 1, "lsrb" },
/* 0x55 */ { eUnknown , 0, 0, NULL },
/* 0x56 */ { eImplicit , 0, 1, "rorb" },
/* 0x57 */ { eImplicit , 0, 1, "asrb" },
/* 0x58 */ { eImplicit , 0, 1, "aslb" },
/* 0x59 */ { eImplicit , 0, 1, "rolb" },
/* 0x5a */ { eImplicit , 0, 1, "decb" },
/* 0x5b */ { eUnknown , 0, 0, NULL },
/* 0x5c */ { eImplicit , 0, 1, "incb" },
/* 0x5d */ { eImplicit , 0, 1, "tstb" },
/* 0x5e */ { eUnknown , 0, 0, NULL },
/* 0x5f */ { eImplicit , 0, 1, "clrb" },
/* 0x60 */ { eIndexed , 0, 1, "neg" },
/* 0x61 */ { eUnknown , 0, 0, NULL },
/* 0x62 */ { eUnknown , 0, 0, NULL },
/* 0x63 */ { eIndexed , 0, 1, "com" },
/* 0x64 */ { eIndexed , 0, 1, "lsr" },
/* 0x65 */ { eUnknown , 0, 0, NULL },
/* 0x66 */ { eIndexed , 0, 1, "ror" },
/* 0x67 */ { eIndexed , 0, 1, "asr" },
/* 0x68 */ { eIndexed , 0, 1, "asl" },
/* 0x69 */ { eIndexed , 0, 1, "rol" },
/* 0x6a */ { eIndexed , 0, 1, "dec" },
/* 0x6b */ { eUnknown , 0, 0, NULL },
/* 0x6c */ { eIndexed , 0, 1, "inc" },
/* 0x6d */ { eIndexed , 0, 1, "tst" },
/* 0x6e */ { eIndexed , 0, 0, "jmp" },
/* 0x6f */ { eIndexed , 0, 1, "clr" },
/* 0x70 */ { eExtended , 0, 1, "neg" },
/* 0x71 */ { eUnknown , 0, 0, NULL },
/* 0x72 */ { eUnknown , 0, 0, NULL },
/* 0x73 */ { eExtended , 0, 1, "com" },
/* 0x74 */ { eExtended , 0, 1, "lsr" },
/* 0x75 */ { eUnknown , 0, 0, NULL },
/* 0x76 */ { eExtended , 0, 1, "ror" },
/* 0x77 */ { eExtended , 0, 1, "asr" },
/* 0x78 */ { eExtended , 0, 1, "asl" },
/* 0x79 */ { eExtended , 0, 1, "rol" },
/* 0x7a */ { eExtended , 0, 1, "dec" },
/* 0x7b */ { eUnknown , 0, 0, NULL },
/* 0x7c */ { eExtended , 0, 1, "inc" },
/* 0x7d */ { eExtended , 0, 1, "tst" },
/* 0x7e */ { eExtended , 0, 2, "jmp" },
/* 0x7f */ { eExtended , 0, 1, "clr" },
/* 0x80 */ { eImmediate , 0, 1, "suba" },
/* 0x81 */ { eImmediate , 0, 1, "cmpa" },
/* 0x82 */ { eImmediate , 0, 1, "sbca" },
/* 0x83 */ { eUnknown , 0, 0, NULL },
/* 0x84 */ { eImmediate , 0, 1, "anda" },
/* 0x85 */ { eImmediate , 0, 1, "bita" },
/* 0x86 */ { eImmediate , 0, 1, "ldaa" },
/* 0x87 */ { eUnknown , 0, 0, NULL },
/* 0x88 */ { eImmediate , 0, 1, "eora" },
/* 0x89 */ { eImmediate , 0, 1, "adca" },
/* 0x8a */ { eImmediate , 0, 1, "oraa" },
/* 0x8b */ { eImmediate , 0, 1, "adda" },
/* 0x8c */ { eImmediate , 1, 1, "cpx" },
/* 0x8d */ { eRelative , 0, 3, "bsr" },
/* 0x8e */ { eImmediate , 1, 1, "lds" },
/* 0x8f */ { eUnknown , 0, 0, NULL },
/* 0x90 */ { eDirect , 0, 1, "suba" },
/* 0x91 */ { eDirect , 0, 1, "cmpa" },
/* 0x92 */ { eDirect , 0, 1, "sbca" },
/* 0x93 */ { eUnknown , 0, 0, NULL },
/* 0x94 */ { eDirect , 0, 1, "anda" },
/* 0x95 */ { eDirect , 0, 1, "bita" },
/* 0x96 */ { eDirect , 0, 1, "ldaa" },
/* 0x97 */ { eDirect , 0, 1, "staa" },
/* 0x98 */ { eDirect , 0, 1, "eora" },
/* 0x99 */ { eDirect , 0, 1, "adca" },
/* 0x9a */ { eDirect , 0, 1, "oraa" },
/* 0x9b */ { eDirect , 0, 1, "adda" },
/* 0x9c */ { eDirect , 1, 1, "cpx" },
/* 0x9d */ { eUnknown , 0, 0, NULL },
/* 0x9e */ { eDirect , 1, 1, "lds" },
/* 0x9f */ { eDirect , 1, 1, "sts" },
/* 0xa0 */ { eIndexed , 0, 1, "suba" },
/* 0xa1 */ { eIndexed , 0, 1, "cmpa" },
/* 0xa2 */ { eIndexed , 0, 1, "sbca" },
/* 0xa3 */ { eUnknown , 0, 0, NULL },
/* 0xa4 */ { eIndexed , 0, 1, "anda" },
/* 0xa5 */ { eIndexed , 0, 1, "bita" },
/* 0xa6 */ { eIndexed , 0, 1, "ldaa" },
/* 0xa7 */ { eIndexed , 0, 1, "staa" },
/* 0xa8 */ { eIndexed , 0, 1, "eora" },
/* 0xa9 */ { eIndexed , 0, 1, "adca" },
/* 0xaa */ { eIndexed , 0, 1, "oraa" },
/* 0xab */ { eIndexed , 0, 1, "adda" },
/* 0xac */ { eIndexed , 1, 1, "cpx" },
/* 0xad */ { eIndexed , 0, 1, "jsr" },
/* 0xae */ { eIndexed , 1, 1, "lds" },
/* 0xaf */ { eIndexed , 1, 1, "sts" },
/* 0xb0 */ { eExtended , 0, 1, "suba" },
/* 0xb1 */ { eExtended , 0, 1, "cmpa" },
/* 0xb2 */ { eExtended , 0, 1, "sbca" },
/* 0xb3 */ { eUnknown , 0, 0, NULL },
/* 0xb4 */ { eExtended , 0, 1, "anda" },
/* 0xb5 */ { eExtended , 0, 1, "bita" },
/* 0xb6 */ { eExtended , 0, 1, "ldaa" },
/* 0xb7 */ { eExtended , 0, 1, "staa" },
/* 0xb8 */ { eExtended , 0, 1, "eora" },
/* 0xb9 */ { eExtended , 0, 1, "adca" },
/* 0xba */ { eExtended , 0, 1, "oraa" },
/* 0xbb */ { eExtended , 0, 1, "adda" },
/* 0xbc */ { eExtended , 1, 1, "cpx" },
/* 0xbd */ { eExtended , 0, 3, "jsr" },
/* 0xbe */ { eExtended , 1, 0, "lds" },
/* 0xbf */ { eExtended , 1, 0, "sts" },
/* 0xc0 */ { eImmediate , 0, 1, "subb" },
/* 0xc1 */ { eImmediate , 0, 1, "cmpb" },
/* 0xc2 */ { eImmediate , 0, 1, "sbcb" },
/* 0xc3 */ { eUnknown , 0, 0, NULL },
/* 0xc4 */ { eImmediate , 0, 1, "andb" },
/* 0xc5 */ { eImmediate , 0, 1, "bitb" },
/* 0xc6 */ { eImmediate , 0, 1, "ldab" },
/* 0xc7 */ { eImmediate , 0, 1, "stab" },
/* 0xc8 */ { eImmediate , 0, 1, "eorb" },
/* 0xc9 */ { eImmediate , 0, 1, "adcb" },
/* 0xca */ { eImmediate , 0, 1, "orab" },
/* 0xcb */ { eImmediate , 0, 1, "addb" },
/* 0xcc */ { eUnknown , 0, 0, NULL },
/* 0xcd */ { eUnknown , 0, 0, NULL },
/* 0xce */ { eImmediate , 1, 1, "ldx" },
/* 0xcf */ { eUnknown , 0, 0, NULL },
/* 0xd0 */ { eDirect , 0, 1, "subb" },
/* 0xd1 */ { eDirect , 0, 1, "cmpb" },
/* 0xd2 */ { eDirect , 0, 1, "sbcb" },
/* 0xd3 */ { eUnknown , 0, 0, NULL },
/* 0xd4 */ { eDirect , 0, 1, "andb" },
/* 0xd5 */ { eDirect , 0, 1, "bitb" },
/* 0xd6 */ { eDirect , 0, 1, "ldab" },
/* 0xd7 */ { eDirect , 0, 1, "stab" },
/* 0xd8 */ { eDirect , 0, 1, "eorb" },
/* 0xd9 */ { eDirect , 0, 1, "adcb" },
/* 0xda */ { eDirect , 0, 1, "orab" },
/* 0xdb */ { eDirect , 0, 1, "addb" },
/* 0xdc */ { eUnknown , 0, 0, NULL },
/* 0xdd */ { eUnknown , 0, 0, NULL },
/* 0xde */ { eDirect , 0, 1, "ldx" },
/* 0xdf */ { eDirect , 0, 1, "stx" },
/* 0xe0 */ { eIndexed , 0, 1, "subb" },
/* 0xe1 */ { eIndexed , 0, 1, "cmpb" },
/* 0xe2 */ { eIndexed , 0, 1, "sbcb" },
/* 0xe3 */ { eUnknown , 0, 0, NULL },
/* 0xe4 */ { eIndexed , 0, 1, "andb" },
/* 0xe5 */ { eIndexed , 0, 1, "bitb" },
/* 0xe6 */ { eIndexed , 0, 1, "ldab" },
/* 0xe7 */ { eIndexed , 0, 1, "stab" },
/* 0xe8 */ { eIndexed , 0, 1, "eorb" },
/* 0xe9 */ { eIndexed , 0, 1, "adcb" },
/* 0xea */ { eIndexed , 0, 1, "orab" },
/* 0xeb */ { eIndexed , 0, 1, "addb" },
/* 0xec */ { eUnknown , 0, 0, NULL },
/* 0xed */ { eUnknown , 0, 0, NULL },
/* 0xee */ { eIndexed , 1, 1, "ldx" },
/* 0xef */ { eIndexed , 1, 1, "stx" },
/* 0xf0 */ { eExtended , 0, 1, "subb" },
/* 0xf1 */ { eExtended , 0, 1, "cmpb" },
/* 0xf2 */ { eExtended , 0, 1, "sbcb" },
/* 0xf3 */ { eUnknown , 0, 0, NULL },
/* 0xf4 */ { eExtended , 0, 1, "andb" },
/* 0xf5 */ { eExtended , 0, 1, "bitb" },
/* 0xf6 */ { eExtended , 0, 1, "ldab" },
/* 0xf7 */ { eExtended , 0, 1, "stab" },
/* 0xf8 */ { eExtended , 0, 1, "eorb" },
/* 0xf9 */ { eExtended , 0, 1, "adcb" },
/* 0xfa */ { eExtended , 0, 1, "orab" },
/* 0xfb */ { eExtended , 0, 1, "addb" },
/* 0xfc */ { eUnknown , 0, 0, NULL },
/* 0xfd */ { eUnknown , 0, 0, NULL },
/* 0xfe */ { eExtended , 1, 1, "ldx" },
/* 0xff */ { eExtended , 1, 1, "stx" },
};
static const tOpcodeList DummyOpcode = { eUnknown , 0, 0, NULL };
static Boolean RetrieveData(LargeWord Address, Byte *pBuffer, unsigned Count)
{
LargeWord Trans;
while (Count > 0)
{
Trans = 0x10000 - Address;
if (Count < Trans)
Trans = Count;
if (!RetrieveCodeFromChunkList(&CodeChunks, Address, pBuffer, Trans))
{
char NumString[50];
HexString(NumString, sizeof(NumString), Address, 0);
fprintf(stderr
, "cannot retrieve instruction arg @ 0x%s\n", NumString
);
return FALSE;
}
pBuffer += Trans;
Count -= Trans;
Address = (Address + Trans) & 0xffff;
nData += Trans;
}
return TRUE;
}
static const char *MakeSymbolic(Word Address, int AddrLen, const char *pSymbolPrefix, char *pBuffer, int BufferSize)
{
const char *pResult;
if ((pResult = LookupInvSymbol(Address)))
return pResult;
HexString(pBuffer, BufferSize, Address, AddrLen << 1);
if (!pSymbolPrefix)
{
strmaxprep(pBuffer, "$", BufferSize);
return pBuffer;
}
strmaxprep(pBuffer, pSymbolPrefix, BufferSize);
AddInvSymbol(pBuffer, Address);
return pBuffer;
}
static void Disassemble_68(LargeWord Address, tDisassInfo *pInfo, Boolean AsData, int DataSize)
{
Byte Opcode, Data[10];
LargeInt Dist;
char NumBuf[60], NumBuf2[60];
const char *pOp, *pSymbolPrefix;
Word OpAddr = 0;
const tOpcodeList *pOpcode;
pInfo->CodeLen = 0;
pInfo->NextAddressCount = 0;
pInfo->SrcLine[0] = '\0';
pInfo->pRemark = NULL;
if (!RetrieveData(Address, &Opcode, 1))
return;
nData = 1;
pOpcode = AsData ? &DummyOpcode : OpcodeList + Opcode;
switch (pOpcode->Type)
{
case eImplicit:
pInfo->CodeLen = 1;
as_snprintf(pInfo->SrcLine, sizeof(pInfo->SrcLine), "%s", pOpcode->Memo);
break;
case eDirect:
if (!RetrieveData(Address + 1, Data, 1))
return;
pInfo->CodeLen = 2;
OpAddr = Data[0];
pOp = MakeSymbolic(OpAddr, 1, NULL, NumBuf, sizeof(NumBuf));
as_snprintf(pInfo->SrcLine, sizeof(pInfo->SrcLine), "%s\t%s", pOpcode->Memo, pOp);
break;
case eIndexed:
if (!RetrieveData(Address + 1, Data, 1))
return;
pInfo->CodeLen = 2;
OpAddr = Data[0];
pOp = MakeSymbolic(OpAddr, 1, NULL, NumBuf, sizeof(NumBuf));
as_snprintf(pInfo->SrcLine, sizeof(pInfo->SrcLine), "%s\t%s,x", pOpcode->Memo, pOp);
if (!pOpcode->NextAddresses)
pInfo->pRemark = "indirect jump, investigate here";
if ((pOpcode
->NextAddresses
== 1) && (!strcmp(pOpcode
->Memo
, "jsr")))
pInfo->pRemark = "indirect subroutine call, investigate here";
break;
case eExtended:
if (!RetrieveData(Address + 1, Data, 2))
return;
pInfo->CodeLen = 3;
OpAddr = (((Word)Data[0]) << 8) | Data[1];
if (pOpcode->NextAddresses & 2)
pSymbolPrefix
= strcmp(pOpcode
->Memo
, "jsr") ? "lab_" : "sub_";
else
pSymbolPrefix = NULL;
pOp = MakeSymbolic(OpAddr, 2, pSymbolPrefix, NumBuf, sizeof(NumBuf));
as_snprintf(pInfo->SrcLine, sizeof(pInfo->SrcLine), "%s\t%s", pOpcode->Memo, pOp);
break;
case eImmediate:
if (!RetrieveData(Address + 1, Data, pOpcode->OpSize + 1))
return;
pInfo->CodeLen = 2 + pOpcode->OpSize;
OpAddr = pOpcode->OpSize ? (((Word)Data[0]) << 8) | Data[1] : Data[0];
pOp = MakeSymbolic(OpAddr, pOpcode->OpSize + 1, NULL, NumBuf, sizeof(NumBuf));
as_snprintf(pInfo->SrcLine, sizeof(pInfo->SrcLine), "%s\t#%s", pOpcode->Memo, pOp);
break;
case eRelative:
if (!RetrieveData(Address + 1, Data, 1))
return;
pInfo->CodeLen = 2;
Dist = Data[0];
if (Dist & 0x80)
Dist -= 256;
OpAddr = (Address + 2 + Dist) & 0xffff;
pOp
= MakeSymbolic
(OpAddr
, 2, strcmp(pOpcode
->Memo
, "bsr") ? "lab_" : "sub_", NumBuf
, sizeof(NumBuf
));
as_snprintf(pInfo->SrcLine, sizeof(pInfo->SrcLine), "%s\t%s", pOpcode->Memo, pOp);
break;
default:
if (DataSize < 0)
DataSize = 1;
if (!RetrieveData(Address + 1, Data, DataSize - 1))
return;
HexString(NumBuf, sizeof(NumBuf), Opcode, 2);
HexString(NumBuf2, sizeof(NumBuf2), Address, 0);
if (!AsData)
fprintf(stderr
, "unknown opcode 0x%s @ %s\n", NumBuf
, NumBuf2
);
switch (DataSize)
{
case 2:
OpAddr = (((Word)Opcode) << 8) | Data[0];
pOp = MakeSymbolic(OpAddr, 2, NULL, NumBuf, sizeof(NumBuf));
as_snprintf(pInfo->SrcLine, sizeof(pInfo->SrcLine), "adr\t%s", pOp);
pInfo->CodeLen = 2;
break;
default:
pInfo->CodeLen = 1;
HexString(NumBuf, sizeof(NumBuf), Opcode, 2);
as_snprintf(pInfo->SrcLine, sizeof(pInfo->SrcLine), "byt\t$%s", NumBuf);
}
}
pInfo->NextAddressCount = 0;
if (pOpcode->NextAddresses & 2)
pInfo->NextAddresses[pInfo->NextAddressCount++] = OpAddr;
if (pOpcode->NextAddresses & 1)
pInfo->NextAddresses[pInfo->NextAddressCount++] = (Address + pInfo->CodeLen) % 0xffff;
if (nData != pInfo->CodeLen)
as_snprcatf(pInfo->SrcLine, sizeof(pInfo->SrcLine), " ; ouch %u != %u", nData, pInfo->CodeLen);
}
static void SwitchTo_68(void)
{
Disassemble = Disassemble_68;
}
void deco68_init(void)
{
CPU6800 = AddCPU("6800", SwitchTo_68);
CPU6802 = AddCPU("6802", SwitchTo_68);
}