URL
https://opencores.org/ocsvn/sardmips/sardmips/trunk
Subversion Repositories sardmips
[/] [sardmips/] [trunk/] [source/] [top_debug.cpp.BAK] - Rev 18
Compare with Previous | Blame | View Log
#include "top_debug.h"
void decode(sc_lv<32> if_id_inst, unsigned int i, ostream& out)
{
sc_lv<32> inst = if_id_inst;
sc_lv<6> func = inst.range(5,0);
sc_lv<6> op = inst.range(31,26);
char *charinst=0;
sc_lv<5> rs, rt ,rd ,lrs, lrt, lrd, lsa; // lv version of reg #
sc_uint<5> uirs, uirt, uird, uisa; // unsigned integer version of reg #
sc_int<32> is, it, id; // integer version of register contents...
//! The immediate value in an instruction
sc_lv<16> imm;
sc_lv<32> imm_sign, imm_zero;
sc_int<32> iimm_sign, iimm_zero;
sc_uint<32> uiimm_sign, uiimm_zero;
sc_lv<28> instr_index;
sc_uint<28> uiinstr_index;
// register destinations and recipients
rs = inst.range(25,21);
rt = inst.range(20,16);
rd = inst.range(15,11);
uirs = lrs = inst.range(25,21);
uirt = lrt = inst.range(20,16);
uird = lrd = inst.range(15,11);
uisa = lsa = inst.range(10,6);
// Immediate values
imm = inst.range(15,0);
uiimm_zero = iimm_zero = imm_zero = (HALFWORD_ZERO,imm);
if( imm[15] == '1')
uiimm_sign = iimm_sign = imm_sign = (HALFWORD_ONE,imm);
else
uiimm_sign = iimm_sign = imm_sign = (HALFWORD_ZERO,imm);
uiinstr_index = instr_index = (inst.range(25,0), "00");
//switch stage
if(op == OP_RFORMAT)
{
if(func == FUNC_JR)
{
out << " MIPS (ID): jr $"<< dec << (unsigned int)uirs << endl;
}
else if(func == FUNC_JALR)
{
if (uird == 0)
out << " MIPS (ID): jalr $" << dec << (unsigned int)uirs << endl;
else
out << " MIPS (ID): jalr $" << dec << (unsigned int)uird << ", $" << dec << (unsigned int)uirs << endl;
}
/*
*/
else
if(func == FUNC_MTHI ||
func == FUNC_MFLO ||
func == FUNC_MULT ||
func == FUNC_MULTU ||
func == FUNC_DIV ||
func == FUNC_DIVU)
if (func == FUNC_MTHI) {charinst = "mthi"; out << " MIPS (ID): " << charinst << " $" << dec << (unsigned int) uirs << " [Hi]" << endl;}
if (func == FUNC_MFLO) {charinst = "mflo"; out << " MIPS (ID): " << charinst << " $" << dec << (unsigned int) uird << " [Lo]" << endl;}
if (func == FUNC_MULT) {charinst = "mult"; out << " MIPS (ID): " << charinst << " [Hi,Lo]," <<" $" << dec << (unsigned int)uirs << ", $" << dec << (unsigned int)uirt << endl;}
if (func == FUNC_MULTU) {charinst = "multu"; out << " MIPS (ID): " << charinst <<" [Hi,Lo], $" << dec << (unsigned int)uirs << ", $" << dec << (unsigned int)uirt << endl;}
if (func == FUNC_DIV) {charinst = "div"; out << " MIPS (ID): " << charinst << " [Quoz = Hi, Resto = Lo], $" << dec << (unsigned int)uirs << ", $" << dec << (unsigned int)uirt << endl;}
if (func == FUNC_DIVU) {charinst = "divu"; out << " MIPS (ID): " << charinst << " [Quoz = Hi, Rest = Lo], $" << dec << (unsigned int)uirs << ", $" << dec << (unsigned int)uirt << endl;}
else if(func == FUNC_SLL ||
func == FUNC_SRL ||
func == FUNC_SRA)
{
if (func == FUNC_SLL) charinst = "sll";
if (func == FUNC_SRL) charinst = "srl";
if (func == FUNC_SRA) charinst = "sra";
if (func == FUNC_SLL && (unsigned int)uird == 0)
out << " MIPS (ID): nop" << endl;
else
out << " MIPS (ID): " << charinst << " $" << dec << (unsigned int)uird <<", $" << dec << (unsigned int)uirt <<", " << dec << (unsigned int)uisa << endl;
}
else if(func == FUNC_SLLV ||
func == FUNC_SRLV ||
func == FUNC_SRAV ||
func == FUNC_ADD ||
func == FUNC_ADDU ||
func == FUNC_SUB ||
func == FUNC_SUBU ||
func == FUNC_AND ||
func == FUNC_OR ||
func == FUNC_XOR ||
func == FUNC_NOR ||
func == FUNC_SLT ||
func == FUNC_SLTU)
{
// printf("MIPS (ID): R-Format - read next line!\n");
if (func == FUNC_SLLV) charinst = "sllv";
if (func == FUNC_SRLV) charinst = "srlv";
if (func == FUNC_SRAV) charinst = "srav";
if (func == FUNC_ADD) charinst = "add";
if (func == FUNC_ADDU) charinst = "addu";
if (func == FUNC_SUB) charinst = "sub";
if (func == FUNC_SUBU) charinst = "subu";
if (func == FUNC_AND) charinst = "and";
if (func == FUNC_OR) charinst = "or";
if (func == FUNC_XOR) charinst = "xor";
if (func == FUNC_NOR) charinst = "nor";
if (func == FUNC_SLT) charinst = "slt";
if (func == FUNC_SLTU) charinst = "sltu";
out << " MIPS (ID): " << charinst << " $" << dec << (unsigned int)uird << ", $" << dec << (unsigned int)uirs << ", $" << dec << (unsigned int)uirt << endl;
}
else if (func == FUNC_BREAK)
{
out << " MIPS (ID): BREAK" << endl;
}
else if (func == FUNC_SYSCALL)
{
out << " MIPS (ID): SYSCALL" << endl;
}
else if (func == FUNC_BREAK || func == FUNC_SYSCALL)
{
out << " Exception!!" << endl;
}
else
{
out << " * UNKNOWN FUNCTION CODE FOR R-format" << endl;
}
}
else if(op == OP_BRANCH)
{
// PRINTLN("Branch format");
if(lrt.range(1,0) == BRANCH_BLTZ)
{
out << " MIPS (ID): bltz $" << dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(lrt.range(1,0) == BRANCH_BGEZ)
{
out << " MIPS (ID): bgez $" << dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(lrt.range(1,0) == BRANCH_BLTZAL)
{
out << " MIPS (ID): bltzal $"<< dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(lrt.range(1,0) == BRANCH_BGEZAL)
{
out << " MIPS (ID): bgezal $" << dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
}
else if(op == OP_J)
{
out << " MIPS (ID): j "<< dec << (unsigned int) uiinstr_index << endl;
}
else if(op == OP_JAL)
{
out << " MIPS (ID): jal " << dec << (unsigned int) uiinstr_index << endl;
}
else if(op == OP_BEQ)
{
out << " MIPS (ID): beq $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(op == OP_BNE)
{
out << " MIPS (ID): bne $"<< dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(op == OP_BLEZ)
{
out << " MIPS (ID): blez $" << dec << (unsigned int) uirs << ", " << dec << (unsigned int) iimm_sign << endl;
}
else if(op == OP_BGTZ)
{
out << " MIPS (ID): bgtz $" << dec << (unsigned int)uirs << ", " << (unsigned int)iimm_sign << endl;
}
else if(op == OP_ADDI)
{
out << " MIPS (ID): addi $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(op == OP_ADDIU)
{
out << " MIPS (ID): addiu $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", " << dec << (int)uiimm_sign << endl;
}
else if(op == OP_SLTI)
{
out << " MIPS (ID): slti $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(op == OP_SLTIU)
{
out << " MIPS (ID): sltiu $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(op == OP_ANDI)
{
out << " MIPS (ID): andi $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", 0x" << hex << (unsigned int)iimm_sign << endl;
}
else if(op == OP_ORI)
{
out << " MIPS (ID): ori $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", 0x" << hex << (unsigned int)iimm_sign << endl;
}
else if(op == OP_XORI)
{
out << " MIPS (ID): xori $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uirs << ", 0x" << hex << (unsigned int)iimm_sign << endl;
}
else if(op == OP_LUI)
{
out << " MIPS (ID): lui $" << dec << (unsigned int)uirt << ", " << dec << (unsigned int)iimm_sign << endl;
}
else if(op == OP_LB ||
op == OP_LH ||
op == OP_LWL ||
op == OP_LW ||
op == OP_LBU ||
op == OP_LHU ||
op == OP_LWR)
{
if (op == OP_LB) charinst = "lb";
if (op == OP_LH) charinst = "lh";
if (op == OP_LWL) charinst = "lwl";
if (op == OP_LW) charinst = "lw";
if (op == OP_LBU) charinst = "lbu";
if (op == OP_LHU) charinst = "lhu";
if (op == OP_LWR) charinst = "lwr";
out << " MIPS (ID): " << charinst << " $" << dec << (unsigned int)uirt << ", " << dec << (unsigned int)iimm_sign << "($" << dec << (unsigned int)uirs << ") (" << dec << (unsigned int)(is + iimm_sign) << ")" << endl;
}
else if(op == OP_SB ||
op == OP_SH ||
op == OP_SWL ||
op == OP_SW ||
op == OP_SWR)
{
if (op == OP_SB) charinst = "sb";
if (op == OP_SH) charinst = "sh";
if (op == OP_SWL) charinst = "swl";
if (op == OP_SW) charinst = "sw";
if (op == OP_SWR) charinst = "swr";
out << " MIPS (ID): " << charinst <<" $" << dec << (unsigned int)uirt << ", " << dec << (unsigned int)iimm_sign << "($" << dec << (unsigned int)uirs << ") (" << dec << (unsigned int)(is + iimm_sign) << ")" << endl;
}
else if(op == OP_CACHE)
{
out << " MIPS (ID): CACHE $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)iimm_sign.range(15,0) << "(" << dec << (unsigned int) uirs << ")" << endl;
}
else if(op == OP_COPROC0)
{
out << " MIPS (ID): CP0 instruction" << endl;
}
else
{
if(lrs == RS_MFC0)
{
out << " MIPS (ID): mfc0 $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uird << endl;
}
else if(lrs == RS_MTC0)
{
out << " MIPS (ID): mtc0 $" << dec << (unsigned int)uirt << ", $" << dec << (unsigned int)uird << endl;
}
}
}
void top_debug::debug_signals()
{
ofstream out("GIGINO.txt");
out << endl;
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << endl;
//PC_STAGE
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx PC_STAGE xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << " pc_in " << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) top_level->risc->cpu->pc->pc_in) << endl;
out << " pc_out " << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) top_level->risc->cpu->pc->pc_out) << endl;
out << " enable_pc " << top_level->risc->cpu->pc->enable_pc << endl;
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << endl;
//IF_STAGE
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx IF_STAGE xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << " instadataread " << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) top_level->risc->cpu->if_s->instdataread) << endl;
out << " if_id_next_pc " << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) top_level->risc->cpu->if_s->if_id_next_pc) << endl;
out << " enable_if " << top_level->risc->cpu->if_s->enable_fetch << endl;
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << endl;
//ID_STAGE
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ID_STAGE xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
decode(top_level->instdataread,((unsigned int) ((sc_uint<32>)(top_level->instaddr))), out);
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx REGISTERS xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << endl;
for (int n=0; n < 8; n++)
{
out << "$"<< dec << n <<" = 0x" << hex << setw(8) << setfill('0') <<(unsigned int) ((sc_uint<32>)(top_level->risc->cpu->id->localreg->r[n]));
out << " $"<< dec << n+8 <<" = 0x" << hex << setw(8) << setfill('0') <<(unsigned int) ((sc_uint<32>)(top_level->risc->cpu->id->localreg->r[n+8]));
out << " $"<< dec << n+16 <<" = 0x" << hex << setw(8) << setfill('0') <<(unsigned int) ((sc_uint<32>)(top_level->risc->cpu->id->localreg->r[n+16]));
out << " $"<< dec << n+24 <<" = 0x" << hex << setw(8) << setfill('0') <<(unsigned int) ((sc_uint<32>)(top_level->risc->cpu->id->localreg->r[n+24]))<< endl;
}
out << " [HI] = " << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) top_level->risc->cpu->ex->out_hi) << endl;
out << " [LO] = " << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) top_level->risc->cpu->ex->out_lo) << endl;
out << endl;
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx DATA xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << " dataaddr = 0x" << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>)(top_level->dataaddr)) << endl;
out << " dataread = 0x" << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) (top_level->dataread_dec_cpu)) << " ("<< top_level->dataread_dec_cpu <<")"<< endl;
out << " datawrite = 0x" << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) (top_level->datawrite)) << " ("<< top_level->datawrite <<")"<< endl;
out << " datareq = " << top_level->datarw << endl;
out << " datarw = " << top_level->datareq << endl;
out << " databs = " << top_level->databs << endl;
out << endl;
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx INST_MEM xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
out << " PC = 0x" << hex << setw(8) << setfill('0') << ((unsigned int)((sc_uint<32>)(top_level->instaddr))) << endl;
out << " InstDataRead = 0x" << hex << setw(8) << setfill('0') << (unsigned int) ((sc_uint<32>) (top_level->instdataread)) << " " << top_level->instdataread << endl;
out << " instreq = " << top_level->instreq << endl;
out << endl;
out << endl;
out << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx MEMORY xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" << endl;
int temp, temp2, Start, Stop;
Start = Start_pos;
Stop = Finish_pos;
temp = (Start + (Stop - Start)/4);
temp2 = ((Stop - Start)/4);
for(int n= Start; n < temp; n=n+4)
{
out << "[0x"<< hex << n << "] = "<< hex << setw(8) << setfill('0') << top_level->datamem->x[(n >> 2)] << " ";
out << "[0x"<< hex << (n + temp2) << "] = "<< hex << setw(8) << setfill('0') << top_level->datamem->x[((n+temp2) >> 2)] << " ";
out << "[0x"<< hex << (n + 2*temp2) << "] = "<< hex << setw(8) << setfill('0') << top_level->datamem->x[((n+2*temp2) >> 2)] << " ";
out << "[0x"<< hex << (n + 3*temp2) << "] = "<< hex << setw(8) << setfill('0') << top_level->datamem->x[((n+3*temp2) >> 2)] << " " << endl;
/*out << "cella [0x"<< hex << (n+8) << "] = "<< hex << setw(8) << setfill('0') << top_level->datamem->x[((n+8) >> 2)] << " ";
out << "cella [0x"<< hex << (n+12) << "] = "<< hex << setw(8) << setfill('0') << top_level->datamem->x[((n+12) >> 2)] << endl;*/
}
char buffer[256];
ifstream examplefile ("GIGINO.txt");
if (! examplefile.is_open())
{ cout << "Error opening file"; exit (1); }
while (! examplefile.eof() )
{
examplefile.getline (buffer,100);
fprintf (fp ,"%s\n", buffer);
}
}