Integrate assembler

This commit is contained in:
Kingcom 2014-07-31 20:38:26 +02:00
parent e862047142
commit 3e883e4be4
2 changed files with 113 additions and 1 deletions

View File

@ -17,10 +17,12 @@
#include "CtrlDisassemblyView.h" #include "CtrlDisassemblyView.h"
#include "DebugTools/Breakpoints.h" #include "DebugTools/Breakpoints.h"
#include "DebugTools/Debug.h" #include "DebugTools/Debug.h"
#include "DebugTools/MipsAssembler.h"
#include "DebugEvents.h" #include "DebugEvents.h"
#include "BreakpointWindow.h" #include "BreakpointWindow.h"
#include "AppConfig.h" #include "AppConfig.h"
#include "System.h"
#include <wx/mstream.h> #include <wx/mstream.h>
#include <wx/clipbrd.h> #include <wx/clipbrd.h>
@ -66,7 +68,71 @@ enum DisassemblyMenuIdentifiers
ID_DISASM_ADDFUNCTION ID_DISASM_ADDFUNCTION
}; };
class NonAutoSelectTextCtrl: public wxTextCtrl
{
public:
NonAutoSelectTextCtrl(wxWindow *parent, wxWindowID id,
const wxString& value = wxEmptyString,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
long style = 0,
const wxValidator& validator = wxDefaultValidator,
const wxString& name = wxTextCtrlNameStr)
: wxTextCtrl(parent,id,value,pos,size,style,validator,name)
{
}
#ifdef _WIN32
#define WM_GETDLGCODE 0x0087
#define DLGC_HASSETSEL 0x0008
virtual WXLRESULT MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam)
{
WXLRESULT result = wxTextCtrl::MSWWindowProc(nMsg,wParam,lParam);
if (nMsg == WM_GETDLGCODE)
result &= ~DLGC_HASSETSEL;
return result;
}
#endif
};
class TextEntryDialog: public wxDialog
{
public:
TextEntryDialog(wxWindow* parent, wxString title, wxString defaultText)
: wxDialog(parent,wxID_ANY,title)
{
wxBoxSizer* sizer = new wxBoxSizer(wxVERTICAL);
textControl = new NonAutoSelectTextCtrl(this,wxID_ANY,L"",wxDefaultPosition,wxDefaultSize,0);
textControl->SetValue(defaultText);
textControl->SetSelection(textControl->GetLastPosition(),textControl->GetLastPosition());
sizer->Add(textControl,0,wxEXPAND);
wxBoxSizer* buttons = new wxBoxSizer(wxHORIZONTAL);
okButton = new wxButton(this,wxID_OK,L"OK");
okButton->SetDefault();
cancelButton = new wxButton(this,wxID_CANCEL,L"Cancel");
buttons->Add(okButton);
buttons->Add(cancelButton);
sizer->Add(buttons,0,wxEXPAND);
SetSizer(sizer);
sizer->Layout();
sizer->Fit(this);
textControl->SetFocus();
textControl->SetFocusFromKbd();
}
wxString getText() { return textControl->GetLabel(); }
private:
NonAutoSelectTextCtrl* textControl;
wxButton* okButton;
wxButton* cancelButton;
};
inline wxIcon _wxGetIconFromMemory(const unsigned char *data, int length) { inline wxIcon _wxGetIconFromMemory(const unsigned char *data, int length) {
wxMemoryInputStream is(data, length); wxMemoryInputStream is(data, length);
@ -95,7 +161,6 @@ CtrlDisassemblyView::CtrlDisassemblyView(wxWindow* parent, DebugInterface* _cpu)
menu.Append(ID_DISASM_DISASSEMBLETOFILE, L"Disassemble to File"); menu.Append(ID_DISASM_DISASSEMBLETOFILE, L"Disassemble to File");
menu.AppendSeparator(); menu.AppendSeparator();
menu.Append(ID_DISASM_ASSEMBLE, L"Assemble Opcode"); menu.Append(ID_DISASM_ASSEMBLE, L"Assemble Opcode");
menu.Enable(ID_DISASM_ASSEMBLE,false);
menu.AppendSeparator(); menu.AppendSeparator();
menu.Append(ID_DISASM_RUNTOHERE, L"Run to Cursor"); menu.Append(ID_DISASM_RUNTOHERE, L"Run to Cursor");
menu.Append(ID_DISASM_SETPCTOHERE, L"Jump to Cursor"); menu.Append(ID_DISASM_SETPCTOHERE, L"Jump to Cursor");
@ -558,6 +623,40 @@ void CtrlDisassemblyView::followBranch()
} }
} }
void CtrlDisassemblyView::assembleOpcode(u32 address, std::string defaultText)
{
u32 encoded;
if (cpu->isCpuPaused() == false)
{
wxMessageBox( L"Cannot change code while the core is running", L"Error.", wxICON_ERROR);
return;
}
TextEntryDialog entry(this,L"Assemble opcode",wxString(defaultText.c_str(),wxConvUTF8));
entry.Layout();
if (entry.ShowModal() != wxID_OK)
return;
wxString op = entry.getText();
std::string errorText;
bool result = MipsAssembleOpcode(op.To8BitData(),cpu,address,encoded,errorText);
if (result == true)
{
SysClearExecutionCache();
cpu->write32(address,encoded);
if (address == curAddress)
gotoAddress(manager.getNthNextAddress(curAddress,1));
redraw();
} else {
wxMessageBox( wxString(errorText.c_str(),wxConvUTF8), L"Error.", wxICON_ERROR);
}
}
void CtrlDisassemblyView::onPopupClick(wxCommandEvent& evt) void CtrlDisassemblyView::onPopupClick(wxCommandEvent& evt)
{ {
switch (evt.GetId()) switch (evt.GetId())
@ -684,6 +783,9 @@ void CtrlDisassemblyView::onPopupClick(wxCommandEvent& evt)
redraw(); redraw();
break; break;
} }
case ID_DISASM_ASSEMBLE:
assembleOpcode(curAddress,"");
break;
default: default:
wxMessageBox( L"Unimplemented.", L"Unimplemented.", wxICON_INFORMATION); wxMessageBox( L"Unimplemented.", L"Unimplemented.", wxICON_INFORMATION);
break; break;
@ -730,6 +832,15 @@ void CtrlDisassemblyView::keydownEvent(wxKeyEvent& evt)
break; break;
} }
} else { } else {
if (evt.GetEventType() == wxEVT_CHAR && evt.GetKeyCode() >= 0x20 && evt.GetKeyCode() < 0x80)
{
std::string str;
str += (char) evt.GetKeyCode();
assembleOpcode(curAddress,str);
return;
}
switch (evt.GetKeyCode()) switch (evt.GetKeyCode())
{ {
case WXK_LEFT: case WXK_LEFT:

View File

@ -67,6 +67,7 @@ private:
std::set<std::string> getSelectedLineArguments(); std::set<std::string> getSelectedLineArguments();
void drawArguments(wxDC& dc, const DisassemblyLineInfo &line, int x, int y, wxColor& textColor, void drawArguments(wxDC& dc, const DisassemblyLineInfo &line, int x, int y, wxColor& textColor,
const std::set<std::string> &currentArguments); const std::set<std::string> &currentArguments);
void assembleOpcode(u32 address, std::string defaultText);
void postEvent(wxEventType type, wxString text); void postEvent(wxEventType type, wxString text);
void postEvent(wxEventType type, int value); void postEvent(wxEventType type, int value);