Ajout de la compilation assembleur X86

This commit is contained in:
Horde Nicolas 2021-07-04 15:13:35 +02:00
parent 0f81376eec
commit 5e93ab4600
1 changed files with 132 additions and 7 deletions

127
test.cpp
View File

@ -192,6 +192,61 @@ void TextFixedWindow::adjustSize()
fixedtext.setGeometry (FPoint{1, 2}, FSize(getWidth(), getHeight() - 1)); fixedtext.setGeometry (FPoint{1, 2}, FSize(getWidth(), getHeight() - 1));
} }
//----------------------------------------------------------------------
// class TextEditWindow
//----------------------------------------------------------------------
class TextEditWindow final : public finalcut::FDialog
{
public:
// Constructor
explicit TextEditWindow (finalcut::FWidget* = nullptr);
// Disable copy constructor
TextEditWindow (const TextEditWindow&) = delete;
// Destructor
~TextEditWindow() override = default;
// Disable copy assignment operator (=)
TextEditWindow& operator = (const TextEditWindow&) = delete;
// Method
std::string get();
private:
// Method
void initLayout() override;
void adjustSize() override;
// Data members
finalcut::FLabel fixedtext{this};
};
//----------------------------------------------------------------------
TextEditWindow::TextEditWindow (finalcut::FWidget* parent)
: finalcut::FDialog{parent}
{
fixedtext.setText("pour voir");
fixedtext.ignorePadding();
fixedtext.setFocus();
}
//----------------------------------------------------------------------
std::string TextEditWindow::get()
{
return "inc ax\ndec cx\nmov ax,0x33";
}
//----------------------------------------------------------------------
void TextEditWindow::initLayout()
{
fixedtext.setGeometry (FPoint{1, 2}, FSize{getWidth(), getHeight() - 1});
setMinimumSize (FSize{51, 6});
FDialog::initLayout();
}
//----------------------------------------------------------------------
void TextEditWindow::adjustSize()
{
finalcut::FDialog::adjustSize();
fixedtext.setGeometry (FPoint{1, 2}, FSize(getWidth(), getHeight() - 1));
}
//---------------------------------------------------------------------- //----------------------------------------------------------------------
// class TextWindow // class TextWindow
@ -252,6 +307,68 @@ void TextWindow::adjustSize()
scrolltext.setGeometry (FPoint{1, 2}, FSize(getWidth(), getHeight() - 1)); scrolltext.setGeometry (FPoint{1, 2}, FSize(getWidth(), getHeight() - 1));
} }
//----------------------------------------------------------------------
// class Asm
//----------------------------------------------------------------------
class Assembler
{
public:
Assembler(TextEditWindow *edit,TextWindow *log);
unsigned char *Assemble(uint32_t address);
private:
ks_engine *ks;
ks_err err;
int err2;
TextWindow *log;
TextEditWindow *edit;
std::stringstream out;
size_t srcsize;
size_t codesize;
std::string src;
unsigned char *code = new unsigned char[64*1024];
};
Assembler::Assembler(TextEditWindow *edit,TextWindow *log) : edit(edit),log(log)
{
err = ks_open(KS_ARCH_X86, KS_MODE_16, &ks);
if (err != KS_ERR_OK) {
out << "Erreur : Initialisation de l'assembleur X86" << err;
log->append(out.str());
}
else
log->append("Initialisation de l'assembleur X86");
}
unsigned char *Assembler::Assemble(uint32_t address)
{
src=edit->get();
srcsize=src.size();
unsigned char src_char[srcsize+1];
strcpy(reinterpret_cast<char*>(src_char), src.c_str());
err2=ks_asm(ks, reinterpret_cast<const char*>(src_char), address, &code, &codesize, &srcsize);
if (err2 != KS_ERR_OK)
{
out << "Erreur de compilation de l'assembleur: " << err;
log->append(out.str());
}
else
{
out << "Compilation réussie, taille du code :" << codesize;
log->append(out.str());
out.str("");
out.clear();
if (codesize < 30)
{
out << " ";
for (size_t count = 0; count < codesize; count++)
out << std::uppercase << std::setfill('0') << std::setw(2) << std::hex << (int)((uint8_t)code[count]) ;
log->append(out.str());
}
}
return reinterpret_cast<unsigned char*>(&code);
}
//---------------------------------------------------------------------- //----------------------------------------------------------------------
// class VMEngine // class VMEngine
@ -281,6 +398,7 @@ VMEngine::VMEngine(TextWindow *log) : log(log)
log->append("Initialisation de l'ordinateur IA86"); log->append("Initialisation de l'ordinateur IA86");
} }
//IP DI SI BP SP BX DX CX AX //IP DI SI BP SP BX DX CX AX
void VMEngine::Configure(State *init) void VMEngine::Configure(State *init)
@ -566,7 +684,7 @@ int main (int argc, char* argv[])
finalcut::FApplication app {argc, argv}; finalcut::FApplication app {argc, argv};
Menu main_dlg {&app}; Menu main_dlg {&app};
main_dlg.setText ("IA86 - Main window"); main_dlg.setText ("IA86");
main_dlg.setSize ({50, 14}); main_dlg.setSize ({50, 14});
main_dlg.setShadow(); main_dlg.setShadow();
TextWindow log {&main_dlg}; TextWindow log {&main_dlg};
@ -575,9 +693,16 @@ int main (int argc, char* argv[])
log.setResizeable(); log.setResizeable();
log.append("Lancement des journaux"); log.append("Lancement des journaux");
log.show(); log.show();
TextEditWindow edit {&main_dlg};
edit.setText ("Code source");
edit.setGeometry ( FPoint { 30, 10 }, FSize{60, 12} );
edit.setResizeable();
edit.show();
finalcut::FWidget::setMainWidget (&main_dlg); finalcut::FWidget::setMainWidget (&main_dlg);
main_dlg.show(); main_dlg.show();
VMEngine vm {&log}; VMEngine vm {&log};
Assembler asmer {&edit,&log};
asmer.Assemble(0x0000);
main_dlg.loadGoal(&goals[0],&vm); main_dlg.loadGoal(&goals[0],&vm);
return app.exec(); return app.exec();
} }