Extended ISA for 68020+ addressing modes (without adding 68020+ instructions).
This commit is contained in:
parent
a92630e5c7
commit
653f8dc9fc
@ -10,7 +10,7 @@ class M68kFileElementType private constructor() : ILightStubFileElementType<PsiF
|
||||
@JvmField
|
||||
val INSTANCE = M68kFileElementType()
|
||||
|
||||
const val STUB_VERSION = 6
|
||||
const val STUB_VERSION = 7
|
||||
const val STUB_EXTERNAL_ID_PREFIX = "MC68000."
|
||||
const val EXTERNAL_ID = STUB_EXTERNAL_ID_PREFIX + "FILE"
|
||||
}
|
||||
|
@ -1,5 +1,7 @@
|
||||
package de.platon42.intellij.plugins.m68k.asm
|
||||
|
||||
import java.util.*
|
||||
|
||||
enum class Machine {
|
||||
MC68000,
|
||||
MC68010,
|
||||
@ -9,6 +11,10 @@ enum class Machine {
|
||||
MC68060
|
||||
}
|
||||
|
||||
private val MC68000_ONLY = EnumSet.of(Machine.MC68000)
|
||||
private val MC68020_PLUS = EnumSet.range(Machine.MC68020, Machine.MC68060)
|
||||
private val ALL_MACHINES = EnumSet.allOf(Machine::class.java)
|
||||
|
||||
enum class Register(val regname: String, val num: Int) {
|
||||
D0("d0", 0),
|
||||
D1("d1", 1),
|
||||
@ -138,7 +144,7 @@ data class AllowedAdrMode(
|
||||
data class IsaData(
|
||||
val mnemonic: String,
|
||||
val description: String,
|
||||
val machine: Set<Machine> = setOf(Machine.MC68000),
|
||||
val machine: Set<Machine> = MC68000_ONLY,
|
||||
val altMnemonics: List<String> = emptyList(),
|
||||
val conditionCodes: List<String> = emptyList(),
|
||||
val id: String = mnemonic,
|
||||
@ -166,6 +172,21 @@ object M68kIsa {
|
||||
AddressMode.PROGRAM_COUNTER_INDIRECT_WITH_INDEX,
|
||||
)
|
||||
|
||||
private val ALL_68020_MODES = ALL_68000_MODES.plus(
|
||||
setOf(
|
||||
AddressMode.ADDRESS_REGISTER_INDIRECT_WITH_SCALED_INDEX,
|
||||
AddressMode.ADDRESS_REGISTER_INDIRECT_WITH_BASE_DISPLACEMENT,
|
||||
AddressMode.PROGRAM_COUNTER_INDIRECT_WITH_SCALED_INDEX,
|
||||
AddressMode.PROGRAM_COUNTER_INDIRECT_WITH_BASE_DISPLACEMENT,
|
||||
AddressMode.MEMORY_INDIRECT,
|
||||
AddressMode.MEMORY_INDIRECT_POSTINDEXED,
|
||||
AddressMode.MEMORY_INDIRECT_PREINDEXED,
|
||||
AddressMode.PROGRAM_COUNTER_MEMORY_INDIRECT,
|
||||
AddressMode.PROGRAM_COUNTER_MEMORY_INDIRECT_POSTINDEXED,
|
||||
AddressMode.PROGRAM_COUNTER_MEMORY_INDIRECT_PREINDEXED
|
||||
)
|
||||
)
|
||||
|
||||
private val ALL_EXCEPT_IMMEDIATE_AND_PC_REL = setOf(
|
||||
AddressMode.DATA_REGISTER_DIRECT,
|
||||
AddressMode.ADDRESS_REGISTER_DIRECT,
|
||||
@ -177,6 +198,16 @@ object M68kIsa {
|
||||
AddressMode.ABSOLUTE_ADDRESS
|
||||
)
|
||||
|
||||
private val ALL_68020_MODES_EXCEPT_IMMEDIATE_AND_PC_REL = ALL_EXCEPT_IMMEDIATE_AND_PC_REL.plus(
|
||||
setOf(
|
||||
AddressMode.ADDRESS_REGISTER_INDIRECT_WITH_SCALED_INDEX,
|
||||
AddressMode.ADDRESS_REGISTER_INDIRECT_WITH_BASE_DISPLACEMENT,
|
||||
AddressMode.MEMORY_INDIRECT,
|
||||
AddressMode.MEMORY_INDIRECT_POSTINDEXED,
|
||||
AddressMode.MEMORY_INDIRECT_PREINDEXED,
|
||||
)
|
||||
)
|
||||
|
||||
private val ALL_EXCEPT_AREG_IMMEDIATE_AND_PC_REL = setOf(
|
||||
AddressMode.DATA_REGISTER_DIRECT,
|
||||
AddressMode.ADDRESS_REGISTER_INDIRECT,
|
||||
@ -321,6 +352,9 @@ object M68kIsa {
|
||||
private val isaData = listOf(
|
||||
|
||||
// Data Movement Instructions
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
|
||||
IsaData(
|
||||
"move", "Move",
|
||||
modes = listOf(
|
||||
@ -330,12 +364,16 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"movea", "Move Address", altMnemonics = listOf("move"),
|
||||
modes = listOf(AllowedAdrMode(ALL_68000_MODES, AREG_ONLY, OP_SIZE_WL, modInfo = RWM_READ_OP1_OPSIZE or RWM_SET_OP2_L))
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"movem", "Move Multiple Registers",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.REGISTER_LIST, AddressMode.ADDRESS_REGISTER_DIRECT, AddressMode.DATA_REGISTER_DIRECT),
|
||||
@ -392,8 +430,10 @@ object M68kIsa {
|
||||
),
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"movep", "Move Peripheral",
|
||||
machine = EnumSet.range(Machine.MC68000, Machine.MC68040),
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
DREG_ONLY,
|
||||
@ -412,11 +452,13 @@ object M68kIsa {
|
||||
|
||||
IsaData(
|
||||
"moveq", "Move Quick",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(AllowedAdrMode(setOf(AddressMode.IMMEDIATE_DATA), DREG_ONLY, OP_SIZE_L, modInfo = RWM_SET_OP2_L, affectedCc = cc("-**00")))
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"exg", "Exchange Registers",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.DATA_REGISTER_DIRECT, AddressMode.ADDRESS_REGISTER_DIRECT),
|
||||
@ -426,6 +468,10 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
|
||||
IsaData(
|
||||
"lea", "Load Effective Address",
|
||||
modes = listOf(
|
||||
@ -444,6 +490,7 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"pea", "Push Effective Address",
|
||||
modes = listOf(
|
||||
@ -461,22 +508,32 @@ object M68kIsa {
|
||||
modInfo = RWM_MODIFY_STACK
|
||||
)
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"link", "Link and Allocate",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(AllowedAdrMode(AREG_ONLY, setOf(AddressMode.IMMEDIATE_DATA), OP_SIZE_W, modInfo = RWM_SET_OP1_L or RWM_MODIFY_STACK))
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"unlk", "Unlink",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(AllowedAdrMode(AREG_ONLY, null, OP_UNSIZED, modInfo = RWM_SET_OP1_L or RWM_MODIFY_STACK))
|
||||
),
|
||||
|
||||
// Integer Arithmetic Instructions
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
|
||||
IsaData("add", "Add", modes = ADD_SUB_MODES),
|
||||
|
||||
IsaData(
|
||||
"adda", "Add Address", altMnemonics = listOf("add"),
|
||||
modes = listOf(AllowedAdrMode(ALL_68000_MODES, AREG_ONLY, OP_SIZE_WL, modInfo = RWM_READ_OP1_OPSIZE or RWM_MODIFY_OP2_L))
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"addi", "Add Immediate", altMnemonics = listOf("add"),
|
||||
modes = listOf(
|
||||
@ -485,14 +542,22 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
IsaData("addq", "Add Quick", modes = ADDQ_SUBQ_MODES),
|
||||
IsaData("addx", "Add with Extend", modes = ADDX_SUBX_MODES),
|
||||
|
||||
IsaData("addq", "Add Quick", modes = ADDQ_SUBQ_MODES)
|
||||
),
|
||||
|
||||
IsaData("addx", "Add with Extend", machine = ALL_MACHINES, modes = ADDX_SUBX_MODES),
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
|
||||
IsaData("sub", "Subtract", modes = ADD_SUB_MODES),
|
||||
|
||||
IsaData(
|
||||
"suba", "Subtract Address", altMnemonics = listOf("sub"),
|
||||
modes = listOf(AllowedAdrMode(ALL_68000_MODES, AREG_ONLY, OP_SIZE_WL, modInfo = RWM_READ_OP1_OPSIZE or RWM_MODIFY_OP2_L))
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"subi", "Subtract Immediate", altMnemonics = listOf("sub"),
|
||||
modes = listOf(
|
||||
@ -501,8 +566,14 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
IsaData("subq", "Subtract Quick", modes = ADDQ_SUBQ_MODES),
|
||||
IsaData("subx", "Subtract with Extend", modes = ADDX_SUBX_MODES),
|
||||
|
||||
IsaData("subq", "Subtract Quick", modes = ADDQ_SUBQ_MODES)
|
||||
),
|
||||
|
||||
IsaData("subx", "Subtract with Extend", machine = ALL_MACHINES, modes = ADDX_SUBX_MODES),
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
|
||||
IsaData(
|
||||
"neg", "Negate", modes = listOf(
|
||||
@ -512,6 +583,7 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"negx", "Negate with Extend", modes = listOf(
|
||||
AllowedAdrMode(
|
||||
@ -544,10 +616,20 @@ object M68kIsa {
|
||||
),
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"cmpa", "Compare Address", altMnemonics = listOf("cmp"),
|
||||
modes = listOf(AllowedAdrMode(ALL_68000_MODES, AREG_ONLY, OP_SIZE_WL, modInfo = RWM_READ_OP1_OPSIZE or RWM_READ_OP2_L, affectedCc = cc("-****")))
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
ALL_68000_MODES,
|
||||
AREG_ONLY,
|
||||
OP_SIZE_WL,
|
||||
modInfo = RWM_READ_OP1_OPSIZE or RWM_READ_OP2_L,
|
||||
affectedCc = cc("-****")
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"cmpi", "Compare Immediate", altMnemonics = listOf("cmp"),
|
||||
modes = listOf(
|
||||
@ -556,9 +638,12 @@ object M68kIsa {
|
||||
affectedCc = cc("-****")
|
||||
)
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"cmpm", "Compare Memory to Memory", altMnemonics = listOf("cmp"),
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.ADDRESS_REGISTER_INDIRECT_POST_INC),
|
||||
@ -569,26 +654,41 @@ object M68kIsa {
|
||||
)
|
||||
),
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
|
||||
IsaData(
|
||||
"muls", "Signed Multiply",
|
||||
modes = listOf(AllowedAdrMode(ALL_EXCEPT_AREG, DREG_ONLY, OP_SIZE_W, modInfo = RWM_READ_OP1_W or RWM_MODIFY_OP2_L, affectedCc = cc("-**00")))
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"mulu", "Unsigned Multiply",
|
||||
modes = listOf(AllowedAdrMode(ALL_EXCEPT_AREG, DREG_ONLY, OP_SIZE_W, modInfo = RWM_READ_OP1_W or RWM_MODIFY_OP2_L, affectedCc = cc("-**00")))
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"divs", "Signed Divide",
|
||||
modes = listOf(AllowedAdrMode(ALL_EXCEPT_AREG, DREG_ONLY, OP_SIZE_W, modInfo = RWM_READ_OP1_L or RWM_MODIFY_OP2_L, affectedCc = cc("-***0")))
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"divu", "Unsigned Divide",
|
||||
modes = listOf(AllowedAdrMode(ALL_EXCEPT_AREG, DREG_ONLY, OP_SIZE_W, modInfo = RWM_READ_OP1_L or RWM_MODIFY_OP2_L, affectedCc = cc("-***0")))
|
||||
),
|
||||
),
|
||||
|
||||
IsaData("ext", "Sign Extend", modes = listOf(AllowedAdrMode(DREG_ONLY, null, OP_SIZE_WL, modInfo = RWM_MODIFY_OP1_OPSIZE, affectedCc = cc("-**00")))),
|
||||
IsaData(
|
||||
"ext",
|
||||
"Sign Extend",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(AllowedAdrMode(DREG_ONLY, null, OP_SIZE_WL, modInfo = RWM_MODIFY_OP1_OPSIZE, affectedCc = cc("-**00")))
|
||||
),
|
||||
|
||||
// Logical Instructions
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
IsaData(
|
||||
"and", "Logical AND",
|
||||
modes = listOf(
|
||||
@ -596,6 +696,7 @@ object M68kIsa {
|
||||
AllowedAdrMode(DREG_ONLY, INDIRECT_MODES, modInfo = RWM_READ_OP1_OPSIZE or RWM_MODIFY_OP2_OPSIZE, affectedCc = cc("-**00"))
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"andi", "Logical AND Immediate",
|
||||
altMnemonics = listOf("and"),
|
||||
@ -608,6 +709,7 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"eor", "Logical Exclusive-OR",
|
||||
modes = listOf(
|
||||
@ -619,6 +721,7 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"eori", "Logical Exclusive-OR Immediate", altMnemonics = listOf("eor"),
|
||||
modes = listOf(
|
||||
@ -630,6 +733,7 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"or", "Logical Inclusive-OR",
|
||||
modes = listOf(
|
||||
@ -637,6 +741,7 @@ object M68kIsa {
|
||||
AllowedAdrMode(DREG_ONLY, INDIRECT_MODES, modInfo = RWM_READ_OP1_OPSIZE or RWM_MODIFY_OP2_OPSIZE, affectedCc = cc("-**00"))
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"ori", "Logical Inclusive-OR Immediate", altMnemonics = listOf("or"),
|
||||
modes = listOf(
|
||||
@ -648,6 +753,7 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"not", "Logical Complement",
|
||||
modes = listOf(AllowedAdrMode(ALL_EXCEPT_AREG_IMMEDIATE_AND_PC_REL, null, modInfo = RWM_MODIFY_OP1_OPSIZE, affectedCc = cc("-**00")))
|
||||
@ -662,6 +768,8 @@ object M68kIsa {
|
||||
IsaData("ror", "Rotate Right", modes = ROD_MODES),
|
||||
IsaData("roxl", "Rotate with Extend Left", modes = ROXD_MODES),
|
||||
IsaData("roxr", "Rotate with Extend Right", modes = ROXD_MODES),
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"swap",
|
||||
"Swap Register Words",
|
||||
@ -669,14 +777,19 @@ object M68kIsa {
|
||||
),
|
||||
|
||||
// Bit Manipulation Instructions
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
IsaData("bchg", "Test Bit and Change", modes = BCHG_BCLR_BSET_MODES),
|
||||
IsaData("bclr", "Test Bit and Clear", modes = BCHG_BCLR_BSET_MODES),
|
||||
IsaData("bset", "Test Bit and Set", modes = BCHG_BCLR_BSET_MODES),
|
||||
IsaData("btst", "Test Bit", modes = BTST_MODES),
|
||||
),
|
||||
|
||||
// Binary-Coded Decimal Instructions
|
||||
IsaData(
|
||||
"abcd", "Add Decimal with Extend",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
DREG_ONLY, DREG_ONLY, OP_SIZE_B, modInfo = RWM_READ_OP1_OPSIZE or RWM_MODIFY_OP2_OPSIZE,
|
||||
@ -693,6 +806,7 @@ object M68kIsa {
|
||||
),
|
||||
IsaData(
|
||||
"sbcd", "Subtract Decimal with Extend",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
DREG_ONLY, DREG_ONLY, OP_SIZE_B, modInfo = RWM_READ_OP1_OPSIZE or RWM_MODIFY_OP2_OPSIZE,
|
||||
@ -707,6 +821,9 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
IsaData(
|
||||
"nbcd", "Negate Decimal with Extend",
|
||||
modes = listOf(
|
||||
@ -715,6 +832,7 @@ object M68kIsa {
|
||||
affectedCc = cc("CUAU*"), testedCc = cc("?-?--")
|
||||
)
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
// Program Control Instructions
|
||||
@ -743,6 +861,10 @@ object M68kIsa {
|
||||
modes = listOf(AllowedAdrMode(DREG_ONLY, setOf(AddressMode.ABSOLUTE_ADDRESS), OP_SIZE_W, modInfo = RWM_MODIFY_OP1_W, testedCc = cc("-????"))),
|
||||
changesControlFlow = true
|
||||
),
|
||||
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
IsaData(
|
||||
"sCC", "Set Conditionally", conditionCodes = conditionCodes,
|
||||
modes = listOf(AllowedAdrMode(ALL_EXCEPT_AREG_IMMEDIATE_AND_PC_REL, null, OP_SIZE_B, modInfo = RWM_SET_OP2_B, testedCc = cc("-????")))
|
||||
@ -779,24 +901,30 @@ object M68kIsa {
|
||||
)
|
||||
),
|
||||
changesControlFlow = true
|
||||
)
|
||||
),
|
||||
IsaData("nop", "No Operation", hasOps = false, modes = NO_OPS_UNSIZED),
|
||||
|
||||
IsaData("nop", "No Operation", machine = ALL_MACHINES, hasOps = false, modes = NO_OPS_UNSIZED),
|
||||
|
||||
IsaData(
|
||||
"rtr",
|
||||
"Return and Restore",
|
||||
machine = ALL_MACHINES,
|
||||
hasOps = false,
|
||||
modes = listOf(AllowedAdrMode(size = OP_UNSIZED, modInfo = RWM_MODIFY_STACK, affectedCc = cc("*****"))),
|
||||
changesControlFlow = true
|
||||
),
|
||||
IsaData(
|
||||
"rts", "Return from Subroutine", hasOps = false,
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(AllowedAdrMode(size = OP_UNSIZED, modInfo = RWM_MODIFY_STACK)),
|
||||
changesControlFlow = true
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"tst", "Test Operand", modes = listOf(
|
||||
"tst", "Test Operand",
|
||||
machine = MC68000_ONLY,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
ALL_EXCEPT_AREG_IMMEDIATE_AND_PC_REL, null, modInfo = RWM_READ_OP1_OPSIZE,
|
||||
affectedCc = cc("-**00")
|
||||
@ -804,9 +932,25 @@ object M68kIsa {
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"tst", "Test Operand",
|
||||
machine = MC68020_PLUS,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
ALL_68020_MODES.minus(AddressMode.ADDRESS_REGISTER_DIRECT), null, modInfo = RWM_READ_OP1_OPSIZE,
|
||||
affectedCc = cc("-**00")
|
||||
),
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.ADDRESS_REGISTER_DIRECT), null, OP_SIZE_WL, modInfo = RWM_READ_OP1_OPSIZE,
|
||||
affectedCc = cc("-**00")
|
||||
),
|
||||
)
|
||||
),
|
||||
|
||||
// System Control Instructions
|
||||
IsaData(
|
||||
"andi", "AND Immediate to Status Register", id = "andi to SR", altMnemonics = listOf("and"), isPrivileged = true,
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.IMMEDIATE_DATA), setOf(AddressMode.SPECIAL_REGISTER_DIRECT), OP_SIZE_W, "sr",
|
||||
@ -816,6 +960,7 @@ object M68kIsa {
|
||||
),
|
||||
IsaData(
|
||||
"eori", "Exclusive-OR Immediate to Status Register", id = "eori to SR", altMnemonics = listOf("eor"), isPrivileged = true,
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.IMMEDIATE_DATA), setOf(AddressMode.SPECIAL_REGISTER_DIRECT), OP_SIZE_W, "sr",
|
||||
@ -825,6 +970,7 @@ object M68kIsa {
|
||||
),
|
||||
IsaData(
|
||||
"ori", "Inclusive-OR Immediate to Status Register", id = "ori to SR", altMnemonics = listOf("or"), isPrivileged = true,
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.IMMEDIATE_DATA), setOf(AddressMode.SPECIAL_REGISTER_DIRECT), OP_SIZE_W, "sr",
|
||||
@ -832,8 +978,10 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"move", "Move from Status Register", id = "move from SR",
|
||||
machine = MC68000_ONLY,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.SPECIAL_REGISTER_DIRECT),
|
||||
@ -845,6 +993,10 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
|
||||
IsaData(
|
||||
"move", "Move to Status Register", id = "move to SR", isPrivileged = true,
|
||||
modes = listOf(
|
||||
@ -853,34 +1005,50 @@ object M68kIsa {
|
||||
affectedCc = cc("*****")
|
||||
)
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"move", "Move User Stack Pointer", id = "move USP", isPrivileged = true,
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(
|
||||
AllowedAdrMode(setOf(AddressMode.SPECIAL_REGISTER_DIRECT), AREG_ONLY, OP_SIZE_L, "usp", modInfo = RWM_SET_OP2_L),
|
||||
AllowedAdrMode(AREG_ONLY, setOf(AddressMode.SPECIAL_REGISTER_DIRECT), OP_SIZE_L, "usp", modInfo = RWM_READ_OP1_L),
|
||||
)
|
||||
),
|
||||
|
||||
IsaData("reset", "Reset External Devices", isPrivileged = true, hasOps = false, modes = NO_OPS_UNSIZED),
|
||||
IsaData("reset", "Reset External Devices", machine = ALL_MACHINES, isPrivileged = true, hasOps = false, modes = NO_OPS_UNSIZED),
|
||||
IsaData(
|
||||
"rte", "Return from Exception", isPrivileged = true, hasOps = false,
|
||||
"rte", "Return from Exception",
|
||||
machine = ALL_MACHINES, isPrivileged = true, hasOps = false,
|
||||
modes = listOf(AllowedAdrMode(size = OP_UNSIZED, modInfo = RWM_MODIFY_STACK)),
|
||||
changesControlFlow = true
|
||||
),
|
||||
IsaData(
|
||||
"stop", "Stop", isPrivileged = true,
|
||||
"stop", "Stop",
|
||||
machine = ALL_MACHINES, isPrivileged = true,
|
||||
modes = listOf(AllowedAdrMode(setOf(AddressMode.IMMEDIATE_DATA), null, OP_UNSIZED))
|
||||
),
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
IsaData(
|
||||
"chk", "Check Register Against Bound",
|
||||
modes = listOf(AllowedAdrMode(ALL_EXCEPT_AREG, DREG_ONLY, OP_SIZE_W, modInfo = RWM_READ_OP1_W or RWM_READ_OP2_W, affectedCc = cc("-*UUU")))
|
||||
)
|
||||
),
|
||||
IsaData("illegal", "Take Illegal Instruction Trap", hasOps = false, modes = NO_OPS_UNSIZED, changesControlFlow = true),
|
||||
IsaData("trap", "Trap", modes = listOf(AllowedAdrMode(setOf(AddressMode.IMMEDIATE_DATA), null, OP_UNSIZED)), changesControlFlow = true),
|
||||
|
||||
IsaData("illegal", "Take Illegal Instruction Trap", machine = ALL_MACHINES, hasOps = false, modes = NO_OPS_UNSIZED, changesControlFlow = true),
|
||||
IsaData(
|
||||
"trapv", "Trap on Overflow", hasOps = false,
|
||||
"trap",
|
||||
"Trap",
|
||||
machine = ALL_MACHINES,
|
||||
modes = listOf(AllowedAdrMode(setOf(AddressMode.IMMEDIATE_DATA), null, OP_UNSIZED)),
|
||||
changesControlFlow = true
|
||||
),
|
||||
IsaData(
|
||||
"trapv", "Trap on Overflow",
|
||||
machine = ALL_MACHINES, hasOps = false,
|
||||
modes = listOf(AllowedAdrMode(size = OP_UNSIZED, testedCc = cc("---?-"))),
|
||||
changesControlFlow = true
|
||||
),
|
||||
@ -912,21 +1080,78 @@ object M68kIsa {
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
|
||||
IsaData(
|
||||
"move", "Move from Condition Code Register", id = "move from CCR",
|
||||
machine = EnumSet.of(Machine.MC68010),
|
||||
modes = listOf(
|
||||
AllowedAdrMode(
|
||||
setOf(AddressMode.SPECIAL_REGISTER_DIRECT),
|
||||
ALL_EXCEPT_AREG_IMMEDIATE_AND_PC_REL,
|
||||
OP_SIZE_W,
|
||||
"ccr",
|
||||
modInfo = RWM_SET_OP2_W,
|
||||
testedCc = cc("?????")
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
IsaData(
|
||||
"move", "Move to Condition Code Register", id = "move to CCR",
|
||||
modes = listOf(
|
||||
AllowedAdrMode(ALL_EXCEPT_AREG, setOf(AddressMode.SPECIAL_REGISTER_DIRECT), OP_SIZE_W, "ccr", affectedCc = cc("*****")),
|
||||
)
|
||||
)
|
||||
),
|
||||
|
||||
// Multiprocessor Instructions
|
||||
*autoExpandForOtherCpus(
|
||||
MC68020_PLUS,
|
||||
IsaData(
|
||||
"tas", "Test Operand and Set",
|
||||
modes = listOf(AllowedAdrMode(ALL_EXCEPT_IMMEDIATE_AND_PC_REL, null, OP_SIZE_B, modInfo = RWM_MODIFY_OP1_B, affectedCc = cc("-**00")))
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
private val mnemonicLookupMap = isaData.asSequence()
|
||||
private fun autoExpandForOtherCpus(machines: Set<Machine>, vararg isaDatas: IsaData): Array<out IsaData> {
|
||||
val allIsaData = ArrayList<IsaData>()
|
||||
for (isaData in isaDatas) {
|
||||
val newModes = ArrayList<AllowedAdrMode>()
|
||||
for (mode in isaData.modes) {
|
||||
newModes.add(mode.copy(op1 = add68020Modes(mode.op1), op2 = add68020Modes(mode.op2)))
|
||||
}
|
||||
allIsaData.add(isaData.copy(machine = machines, modes = newModes))
|
||||
}
|
||||
return allIsaData.toTypedArray()
|
||||
}
|
||||
|
||||
private fun add68020Modes(oldModes: Set<AddressMode>?) = if (oldModes != null) {
|
||||
val newModes = oldModes.toMutableSet()
|
||||
if (oldModes.contains(AddressMode.ADDRESS_REGISTER_INDIRECT_WITH_INDEX)) {
|
||||
newModes.add(AddressMode.ADDRESS_REGISTER_INDIRECT_WITH_SCALED_INDEX)
|
||||
newModes.add(AddressMode.ADDRESS_REGISTER_INDIRECT_WITH_BASE_DISPLACEMENT)
|
||||
newModes.add(AddressMode.MEMORY_INDIRECT)
|
||||
newModes.add(AddressMode.MEMORY_INDIRECT_POSTINDEXED)
|
||||
newModes.add(AddressMode.MEMORY_INDIRECT_PREINDEXED)
|
||||
}
|
||||
if (oldModes.contains(AddressMode.PROGRAM_COUNTER_INDIRECT_WITH_INDEX)) {
|
||||
newModes.add(AddressMode.PROGRAM_COUNTER_INDIRECT_WITH_SCALED_INDEX)
|
||||
newModes.add(AddressMode.PROGRAM_COUNTER_INDIRECT_WITH_BASE_DISPLACEMENT)
|
||||
newModes.add(AddressMode.PROGRAM_COUNTER_MEMORY_INDIRECT)
|
||||
newModes.add(AddressMode.PROGRAM_COUNTER_MEMORY_INDIRECT_POSTINDEXED)
|
||||
newModes.add(AddressMode.PROGRAM_COUNTER_MEMORY_INDIRECT_PREINDEXED)
|
||||
}
|
||||
newModes
|
||||
} else {
|
||||
null
|
||||
}
|
||||
|
||||
private
|
||||
val mnemonicLookupMap = isaData.asSequence()
|
||||
.flatMap {
|
||||
(if (it.conditionCodes.isEmpty()) it.altMnemonics.plus(it.mnemonic) else it.altMnemonics.plus(it.conditionCodes
|
||||
.map { cc ->
|
||||
|
@ -100,7 +100,6 @@ nextlabel
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
internal fun check_documentation_for_a_written_register_in_code_flow(@MyFixture myFixture: CodeInsightTestFixture) {
|
||||
myFixture.configureByText(
|
||||
@ -177,6 +176,42 @@ nextlabel
|
||||
<td valign="top"> ; <font color="#00ff00">sets d1.l</font></td>
|
||||
</tr>
|
||||
</table>
|
||||
"""
|
||||
)
|
||||
}
|
||||
|
||||
@Test
|
||||
internal fun check_documentation_for_68020_address_modes(@MyFixture myFixture: CodeInsightTestFixture) {
|
||||
myFixture.configureByText(
|
||||
"documentme.asm", """
|
||||
moveq.l #0,d0
|
||||
lea foobar(pc),a0
|
||||
move.l ([100.w,a0,a0.w*4],124.w),($42.w,a0,d0.l*4)
|
||||
move.l a<caret>0,a1
|
||||
"""
|
||||
)
|
||||
assertThat(generateDocumentation(myFixture))
|
||||
.isEqualToIgnoringWhitespace(
|
||||
"""
|
||||
<div class="definition">movea instruction uses a0.l</div>
|
||||
<table class="sections" style="padding-left: 8pt; padding-right: 8pt">
|
||||
<tr>
|
||||
<td valign="top"> </td>
|
||||
<td valign="top"><code>lea foobar(pc),<font color="#ffc800">a0</font></code></td>
|
||||
<td valign="top"> ; <font color="#00ff00">sets a0.l</font></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td valign="top"> </td>
|
||||
<td valign="top"><code>move.l ([100.w,<font color="#ffc800">a0</font>,<font color="#ffc800">a0</font>.w*4],124.w),(${'$'}42.w,<font color="#ffc800">a0</font>,d0.l*4)</code>
|
||||
</td>
|
||||
<td valign="top"> ; uses a0.l, uses a0.w</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td valign="top">--></td>
|
||||
<td valign="top"><b><code>move.l <font color="#ffc800">a0</font>,a1</code></b></td>
|
||||
<td valign="top"> ; <--</td>
|
||||
</tr>
|
||||
</table>
|
||||
"""
|
||||
)
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user