2022-07-18 08:31:00 +00:00
|
|
|
#pragma once
|
|
|
|
#include "R4300iOpcode.h"
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
class R4300iInstruction
|
|
|
|
{
|
|
|
|
public:
|
2024-06-06 04:39:12 +00:00
|
|
|
R4300iInstruction(uint64_t Address, uint32_t Instruction);
|
2023-12-21 00:04:03 +00:00
|
|
|
R4300iInstruction & operator=(const R4300iInstruction &);
|
2022-07-18 08:31:00 +00:00
|
|
|
|
2024-06-06 04:39:12 +00:00
|
|
|
const uint64_t & Address() const;
|
2024-11-07 06:35:16 +00:00
|
|
|
const uint32_t & Address32() const;
|
2023-12-21 00:04:03 +00:00
|
|
|
const R4300iOpcode & Opcode() const;
|
2022-07-18 08:31:00 +00:00
|
|
|
const char * Name();
|
|
|
|
const char * Param();
|
|
|
|
std::string NameAndParam();
|
|
|
|
|
2022-07-25 04:53:12 +00:00
|
|
|
bool HasDelaySlot(void) const;
|
2022-07-25 07:05:42 +00:00
|
|
|
bool DelaySlotEffectsCompare(uint32_t DelayInstruction) const;
|
2022-12-05 01:53:09 +00:00
|
|
|
void ReadsGPR(uint32_t & Reg1, uint32_t & Reg2) const;
|
2024-11-21 00:40:01 +00:00
|
|
|
int32_t WritesGPR(void) const;
|
2022-12-05 01:53:09 +00:00
|
|
|
bool ReadsHI() const;
|
|
|
|
bool ReadsLO() const;
|
|
|
|
bool WritesHI() const;
|
|
|
|
bool WritesLO() const;
|
2022-07-25 04:53:12 +00:00
|
|
|
|
2022-07-18 08:31:00 +00:00
|
|
|
private:
|
|
|
|
R4300iInstruction(void);
|
2022-10-10 00:22:17 +00:00
|
|
|
R4300iInstruction(const R4300iInstruction &);
|
2022-07-18 08:31:00 +00:00
|
|
|
|
|
|
|
static const char * FPR_Type(uint32_t COP1OpCode);
|
2022-10-10 00:22:17 +00:00
|
|
|
|
2022-07-18 08:31:00 +00:00
|
|
|
void DecodeName(void);
|
|
|
|
void DecodeSpecialName(void);
|
|
|
|
void DecodeRegImmName(void);
|
|
|
|
void DecodeCop1Name(void);
|
2023-05-18 08:34:41 +00:00
|
|
|
void DecodeCop2Name(void);
|
2022-10-10 00:22:17 +00:00
|
|
|
|
2024-11-07 06:35:16 +00:00
|
|
|
union
|
|
|
|
{
|
|
|
|
uint64_t m_Address;
|
|
|
|
uint32_t m_Address32[2];
|
|
|
|
};
|
2022-07-18 08:31:00 +00:00
|
|
|
R4300iOpcode m_Instruction;
|
|
|
|
char m_Name[40];
|
|
|
|
char m_Param[200];
|
|
|
|
};
|