i_cmpa.c

来自「skyeye的开源代码」· C语言 代码 · 共 68 行

C
68
字号
/**********************************//*                                *//*  Copyright 2000, David Grant   *//*                                *//*  see LICENSE for more details  *//*                                *//**********************************/#include "coldfire.h"/* Compare address (CMPA) instruction *//* Format     15  14  13  12  11  10   9   8   7   6   5   4   3   2   1   0+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+| 1 | 0 | 1 | 1 | Register  | 1 | 1 | 1 |  EAMode   |EARegister |+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+*/int CMPATime[8]={ 1, 3, 3, 3, 3, 4, 3, 1};INSTRUCTION_5ARGS(CMPA,	unsigned Code2,4,	unsigned Register,3,	unsigned Code1,3,	unsigned EAMode,3,	unsigned EARegister,3);static void execute(void){	struct _Address Source,Destination;	unsigned int Result, SValue, DValue;	CMPA_Instr Instr;	Memory_RetrWordFromPC(&Instr.Code);		if(!EA_GetFromPC(&Source, 32, Instr.Bits.EAMode, Instr.Bits.EARegister)) return;	if(!EA_GetFromPC(&Destination, 32, 1, Instr.Bits.Register)) return;	EA_GetValue(&SValue, &Source);	EA_GetValue(&DValue, &Destination);	Result = DValue - SValue;	/* Set the status register */	SR_Set(I_CMPA, SValue, DValue, Result);	cycle(CMPATime[cycle_EA(Instr.Bits.EARegister,Instr.Bits.EAMode)]);	return;}static int disassemble(char *Instruction, char *Arg1, char *Arg2) {	CMPA_Instr Instr;	Memory_RetrWordFromPC(&Instr.Code);	sprintf(Instruction, "CMPA.L");	Addressing_Print(32, Instr.Bits.EAMode, Instr.Bits.EARegister, Arg1);	Addressing_Print(32, 1, Instr.Bits.Register, Arg2);	return 0;}int cmpa_5206_register(void){	instruction_register(0xB1C0, 0xF1C0, &execute, &disassemble);	return 1;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?