mirror of
https://github.com/dingusdev/dingusppc.git
synced 2025-01-10 13:29:38 +00:00
FPU Fixing + Preparing for more debugging
This commit is contained in:
parent
add0d5877c
commit
c5ac0a2420
@ -189,6 +189,11 @@ extern uint32_t ppc_effective_address;
|
|||||||
extern uint32_t ppc_real_address;
|
extern uint32_t ppc_real_address;
|
||||||
extern uint32_t ppc_next_instruction_address;
|
extern uint32_t ppc_next_instruction_address;
|
||||||
|
|
||||||
|
//Profiling Stats
|
||||||
|
extern uint32_t mmu_operations_num;
|
||||||
|
extern uint32_t exceptions_performed;
|
||||||
|
extern uint32_t supervisor_inst_num;
|
||||||
|
|
||||||
//Function prototypes
|
//Function prototypes
|
||||||
void reg_init();
|
void reg_init();
|
||||||
uint32_t reg_print();
|
uint32_t reg_print();
|
||||||
@ -233,6 +238,7 @@ extern void ppc_store_dfpresult();
|
|||||||
void ppc_carry(uint32_t a, uint32_t b);
|
void ppc_carry(uint32_t a, uint32_t b);
|
||||||
void ppc_setsoov(uint32_t a, uint32_t b);
|
void ppc_setsoov(uint32_t a, uint32_t b);
|
||||||
void ppc_changecrf0(uint32_t set_result);
|
void ppc_changecrf0(uint32_t set_result);
|
||||||
|
void ppc_fp_changecrf1();
|
||||||
|
|
||||||
void ppc_tbr_update();
|
void ppc_tbr_update();
|
||||||
void ppc_exception_handler(uint32_t exception_type, uint32_t handle_args);
|
void ppc_exception_handler(uint32_t exception_type, uint32_t handle_args);
|
||||||
@ -410,6 +416,8 @@ extern void ppc_mffs();
|
|||||||
extern void ppc_mffsdot();
|
extern void ppc_mffsdot();
|
||||||
extern void ppc_mtfsf();
|
extern void ppc_mtfsf();
|
||||||
extern void ppc_mtfsfdot();
|
extern void ppc_mtfsfdot();
|
||||||
|
extern void ppc_mtfsfi();
|
||||||
|
extern void ppc_mtfsfidot();
|
||||||
|
|
||||||
extern void ppc_addi();
|
extern void ppc_addi();
|
||||||
extern void ppc_addic();
|
extern void ppc_addic();
|
||||||
|
@ -269,8 +269,9 @@ static std::unordered_map<uint16_t, PPCOpcode> SubOpcode63Grabber = {
|
|||||||
{ 239, &ppc_fseldot}, { 242, &ppc_fmult}, { 243, &ppc_fmultdot},
|
{ 239, &ppc_fseldot}, { 242, &ppc_fmult}, { 243, &ppc_fmultdot},
|
||||||
{ 248, &ppc_fmsub}, { 249, &ppc_fmsubdot}, { 250, &ppc_fmadd},
|
{ 248, &ppc_fmsub}, { 249, &ppc_fmsubdot}, { 250, &ppc_fmadd},
|
||||||
{ 251, &ppc_fmadddot}, { 252, &ppc_fnmsub}, { 253, &ppc_fnmsubdot},
|
{ 251, &ppc_fmadddot}, { 252, &ppc_fnmsub}, { 253, &ppc_fnmsubdot},
|
||||||
{ 254, &ppc_fnmadd}, { 255, &ppc_fnmadddot}, { 272, &ppc_fnabs},
|
{ 254, &ppc_fnmadd}, { 255, &ppc_fnmadddot}, { 268, &ppc_mtfsfi},
|
||||||
{ 273, &ppc_fnabsdot}, { 302, &ppc_fsel}, { 303, &ppc_fseldot},
|
{ 272, &ppc_fnabs}, { 273, &ppc_fnabsdot},
|
||||||
|
{ 302, &ppc_fsel}, { 303, &ppc_fseldot},
|
||||||
{ 306, &ppc_fmult}, { 307, &ppc_fmultdot}, { 312, &ppc_fmsub},
|
{ 306, &ppc_fmult}, { 307, &ppc_fmultdot}, { 312, &ppc_fmsub},
|
||||||
{ 313, &ppc_fmsubdot}, { 314, &ppc_fmadd}, { 315, &ppc_fmadddot},
|
{ 313, &ppc_fmsubdot}, { 314, &ppc_fmadd}, { 315, &ppc_fmadddot},
|
||||||
{ 316, &ppc_fnmsub}, { 317, &ppc_fnmsubdot}, { 318, &ppc_fnmadd},
|
{ 316, &ppc_fnmsub}, { 317, &ppc_fnmsubdot}, { 318, &ppc_fnmadd},
|
||||||
@ -287,7 +288,7 @@ static std::unordered_map<uint16_t, PPCOpcode> SubOpcode63Grabber = {
|
|||||||
{ 505, &ppc_fmsubdot}, { 506, &ppc_fmadd}, { 507, &ppc_fmadddot},
|
{ 505, &ppc_fmsubdot}, { 506, &ppc_fmadd}, { 507, &ppc_fmadddot},
|
||||||
{ 508, &ppc_fnmsub}, { 509, &ppc_fnmsubdot}, { 510, &ppc_fnmadd},
|
{ 508, &ppc_fnmsub}, { 509, &ppc_fnmsubdot}, { 510, &ppc_fnmadd},
|
||||||
{ 511, &ppc_fnmadddot}, { 528, &ppc_fabs}, { 529, &ppc_fabsdot},
|
{ 511, &ppc_fnmadddot}, { 528, &ppc_fabs}, { 529, &ppc_fabsdot},
|
||||||
{ 558, &ppc_fsel}, { 559, &ppc_fseldot}, { 562, &ppc_fmult},
|
{ 536, &ppc_mtfsfidot}, { 558, &ppc_fsel}, { 559, &ppc_fseldot}, { 562, &ppc_fmult},
|
||||||
{ 563, &ppc_fmultdot}, { 568, &ppc_fmsub}, { 569, &ppc_fmsubdot},
|
{ 563, &ppc_fmultdot}, { 568, &ppc_fmsub}, { 569, &ppc_fmsubdot},
|
||||||
{ 570, &ppc_fmadd}, { 571, &ppc_fmadddot}, { 572, &ppc_fnmsub},
|
{ 570, &ppc_fmadd}, { 571, &ppc_fmadddot}, { 572, &ppc_fnmsub},
|
||||||
{ 573, &ppc_fnmsubdot}, { 574, &ppc_fnmadd}, { 575, &ppc_fnmadddot},
|
{ 573, &ppc_fnmsubdot}, { 574, &ppc_fnmadd}, { 575, &ppc_fnmadddot},
|
||||||
|
@ -110,6 +110,10 @@ void ppc_grab_regsfpdabc(){
|
|||||||
ppc_result64_c = ppc_state.ppc_fpr[reg_c];
|
ppc_result64_c = ppc_state.ppc_fpr[reg_c];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ppc_fp_changecrf1() {
|
||||||
|
ppc_state.ppc_fpscr |= 0xf0000000;
|
||||||
|
}
|
||||||
|
|
||||||
void ppc_divbyzero(uint64_t input_a, uint64_t input_b, bool is_single){
|
void ppc_divbyzero(uint64_t input_a, uint64_t input_b, bool is_single){
|
||||||
if (input_b == 0){
|
if (input_b == 0){
|
||||||
ppc_state.ppc_fpscr |= 0x84000000;
|
ppc_state.ppc_fpscr |= 0x84000000;
|
||||||
@ -1047,12 +1051,13 @@ void ppc_mffsdot(){
|
|||||||
fpstore1 |= fpstore2;
|
fpstore1 |= fpstore2;
|
||||||
ppc_state.ppc_fpr[reg_d] = fpstore1;
|
ppc_state.ppc_fpr[reg_d] = fpstore1;
|
||||||
ppc_store_sfpresult();
|
ppc_store_sfpresult();
|
||||||
|
ppc_fp_changecrf1();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ppc_mtfsf(){
|
void ppc_mtfsf(){
|
||||||
reg_b = (ppc_cur_instruction >> 11) & 31;
|
reg_b = (ppc_cur_instruction >> 11) & 31;
|
||||||
uint32_t fm_mask = (ppc_cur_instruction >> 17) & 255;
|
uint32_t fm_mask = (ppc_cur_instruction >> 17) & 255;
|
||||||
crm += ((fm_mask & 1) == 1)? 0xF0000000 : 0x00000000;
|
crm = ((fm_mask & 1) == 1)? 0xF0000000 : 0x00000000;
|
||||||
crm += (((fm_mask >> 1) & 1) == 1)? 0x0F000000 : 0x00000000;
|
crm += (((fm_mask >> 1) & 1) == 1)? 0x0F000000 : 0x00000000;
|
||||||
crm += (((fm_mask >> 2) & 1) == 1)? 0x00F00000 : 0x00000000;
|
crm += (((fm_mask >> 2) & 1) == 1)? 0x00F00000 : 0x00000000;
|
||||||
crm += (((fm_mask >> 3) & 1) == 1)? 0x000F0000 : 0x00000000;
|
crm += (((fm_mask >> 3) & 1) == 1)? 0x000F0000 : 0x00000000;
|
||||||
@ -1065,9 +1070,9 @@ void ppc_mtfsf(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ppc_mtfsfdot(){
|
void ppc_mtfsfdot(){
|
||||||
reg_b = (ppc_cur_instruction >> 11) & 31;
|
uint32_t quickfprval = (ppc_cur_instruction >> 12) & 15;
|
||||||
uint32_t fm_mask = (ppc_cur_instruction >> 17) & 255;
|
ppc_result_d = (ppc_cur_instruction >> 23) & 7;
|
||||||
crm += ((fm_mask & 1) == 1)? 0xF0000000 : 0x00000000;
|
crm = ((fm_mask & 1) == 1)? 0xF0000000 : 0x00000000;
|
||||||
crm += (((fm_mask >> 1) & 1) == 1)? 0x0F000000 : 0x00000000;
|
crm += (((fm_mask >> 1) & 1) == 1)? 0x0F000000 : 0x00000000;
|
||||||
crm += (((fm_mask >> 2) & 1) == 1)? 0x00F00000 : 0x00000000;
|
crm += (((fm_mask >> 2) & 1) == 1)? 0x00F00000 : 0x00000000;
|
||||||
crm += (((fm_mask >> 3) & 1) == 1)? 0x000F0000 : 0x00000000;
|
crm += (((fm_mask >> 3) & 1) == 1)? 0x000F0000 : 0x00000000;
|
||||||
@ -1077,6 +1082,22 @@ void ppc_mtfsfdot(){
|
|||||||
crm += (((fm_mask >> 7) & 1) == 1)? 0x0000000F : 0x00000000;
|
crm += (((fm_mask >> 7) & 1) == 1)? 0x0000000F : 0x00000000;
|
||||||
uint32_t quickfprval = (uint32_t)ppc_state.ppc_fpr[reg_b];
|
uint32_t quickfprval = (uint32_t)ppc_state.ppc_fpr[reg_b];
|
||||||
ppc_state.ppc_fpscr = (quickfprval & crm) | (quickfprval & ~(crm));
|
ppc_state.ppc_fpscr = (quickfprval & crm) | (quickfprval & ~(crm));
|
||||||
|
ppc_fp_changecrf1();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ppc_mtfsfi() {
|
||||||
|
ppc_result_b = (ppc_cur_instruction >> 11) & 15;
|
||||||
|
crf_d = (ppc_cur_instruction >> 23) & 7;
|
||||||
|
crf_d = crf_d << 2;
|
||||||
|
ppc_state.ppc_fpscr = (ppc_state.ppc_cr & ~(0xF0000000UL >> crf_d)) | ((ppc_state.ppc_spr[1] & 0xF0000000UL) >> crf_d);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ppc_mtfsfidot() {
|
||||||
|
ppc_result_b = (ppc_cur_instruction >> 11) & 15;
|
||||||
|
crf_d = (ppc_cur_instruction >> 23) & 7;
|
||||||
|
crf_d = crf_d << 2;
|
||||||
|
ppc_state.ppc_fpscr = (ppc_state.ppc_cr & ~(0xF0000000UL >> crf_d)) | ((ppc_state.ppc_spr[1] & 0xF0000000UL) >> crf_d);
|
||||||
|
ppc_fp_changecrf1();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ppc_mtfsb0(){
|
void ppc_mtfsb0(){
|
||||||
@ -1087,11 +1108,11 @@ void ppc_mtfsb0(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ppc_mtfsb0dot(){
|
void ppc_mtfsb0dot(){
|
||||||
//PLACEHOLDER
|
|
||||||
crf_d = (ppc_cur_instruction >> 21) & 0x31;
|
crf_d = (ppc_cur_instruction >> 21) & 0x31;
|
||||||
if ((crf_d == 0) || (crf_d > 2)){
|
if ((crf_d == 0) || (crf_d > 2)){
|
||||||
ppc_state.ppc_fpscr &= ~(1 << crf_d);
|
ppc_state.ppc_fpscr &= ~(1 << crf_d);
|
||||||
}
|
}
|
||||||
|
ppc_fp_changecrf1();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ppc_mtfsb1(){
|
void ppc_mtfsb1(){
|
||||||
@ -1102,12 +1123,11 @@ void ppc_mtfsb1(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ppc_mtfsb1dot(){
|
void ppc_mtfsb1dot(){
|
||||||
//PLACEHOLDER
|
|
||||||
crf_d = ~(ppc_cur_instruction >> 21) & 0x31;
|
crf_d = ~(ppc_cur_instruction >> 21) & 0x31;
|
||||||
if ((crf_d == 0) || (crf_d > 2)){
|
if ((crf_d == 0) || (crf_d > 2)){
|
||||||
ppc_state.ppc_fpscr |= (1 << crf_d);
|
ppc_state.ppc_fpscr |= (1 << crf_d);
|
||||||
}
|
}
|
||||||
|
ppc_fp_changecrf1();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ppc_mcrfs(){
|
void ppc_mcrfs(){
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
#include <fstream>
|
||||||
#include <map>
|
#include <map>
|
||||||
#include "ppcemu.h"
|
#include "ppcemu.h"
|
||||||
#include "../cpu/ppc/ppcmmu.h"
|
#include "../cpu/ppc/ppcmmu.h"
|
||||||
@ -22,6 +23,7 @@ void show_help()
|
|||||||
cout << " step -- execute single instruction" << endl;
|
cout << " step -- execute single instruction" << endl;
|
||||||
cout << " until X -- execute until address X is reached" << endl;
|
cout << " until X -- execute until address X is reached" << endl;
|
||||||
cout << " regs -- dump content of the GRPs" << endl;
|
cout << " regs -- dump content of the GRPs" << endl;
|
||||||
|
cout << " memdump -- dump content of the system memory to memdump.bin" << endl;
|
||||||
cout << " disas X,n -- disassemble N instructions starting at address X" << endl;
|
cout << " disas X,n -- disassemble N instructions starting at address X" << endl;
|
||||||
cout << " quit -- quit the debugger" << endl << endl;
|
cout << " quit -- quit the debugger" << endl << endl;
|
||||||
cout << "Pressing ENTER will repeat last command." << endl;
|
cout << "Pressing ENTER will repeat last command." << endl;
|
||||||
@ -40,6 +42,14 @@ void dump_regs()
|
|||||||
cout << "MSR: " << hex << ppc_state.ppc_msr << endl;
|
cout << "MSR: " << hex << ppc_state.ppc_msr << endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void dump_mem_file()
|
||||||
|
{
|
||||||
|
std::ofstream memdumpfile;
|
||||||
|
memdumpfile.open("memdump.bin", std::ofstream::out | std::ofstream::binary);
|
||||||
|
memdumpfile.write((char *)&machine_sysram_mem, sizeof(char) * 67108864);
|
||||||
|
memdumpfile.close();
|
||||||
|
}
|
||||||
|
|
||||||
void enter_debugger()
|
void enter_debugger()
|
||||||
{
|
{
|
||||||
string inp, cmd, addr_str, last_cmd;
|
string inp, cmd, addr_str, last_cmd;
|
||||||
@ -69,7 +79,11 @@ void enter_debugger()
|
|||||||
show_help();
|
show_help();
|
||||||
} else if (cmd == "quit") {
|
} else if (cmd == "quit") {
|
||||||
break;
|
break;
|
||||||
} else if (cmd == "regs") {
|
}
|
||||||
|
else if (cmd == "memdump") {
|
||||||
|
dump_mem_file();
|
||||||
|
}
|
||||||
|
else if (cmd == "regs") {
|
||||||
dump_regs();
|
dump_regs();
|
||||||
} else if (cmd == "step") {
|
} else if (cmd == "step") {
|
||||||
ppc_exec_single();
|
ppc_exec_single();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user