Skip to content

Commit

Permalink
Moved UI function code to lambdas & Fixed BTB having incorrect number…
Browse files Browse the repository at this point in the history
… of bits
  • Loading branch information
jiristefan authored and jdupak committed Jul 7, 2024
1 parent bae027e commit 6c82d44
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 47 deletions.
62 changes: 21 additions & 41 deletions src/gui/dialogs/new/newdialog.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -130,24 +130,30 @@ NewDialog::NewDialog(QWidget *parent, QSettings *settings) : QDialog(parent) {
connect(ui->osemu_fs_root, &QLineEdit::textChanged, this, &NewDialog::osemu_fs_root_change);

// Branch predictor
connect(
ui->group_branch_predictor, QOverload<bool>::of(&QGroupBox::toggled), this,
&NewDialog::bp_enabled_change);
connect(ui->group_branch_predictor, QOverload<bool>::of(&QGroupBox::toggled), this, [this] {
config->set_bp_enabled(ui->group_branch_predictor->isChecked());
});
connect(
ui->select_bp_type, QOverload<int>::of(&QComboBox::activated), this,
&NewDialog::bp_type_change);
connect(
ui->select_bp_init_state, QOverload<int>::of(&QComboBox::activated), this,
&NewDialog::bp_init_state_change);
connect(
ui->slider_bp_btb_bits, &QAbstractSlider::valueChanged, this,
&NewDialog::bp_btb_bits_change);
connect(
ui->slider_bp_bhr_bits, &QAbstractSlider::valueChanged, this,
&NewDialog::bp_bhr_bits_change);
connect(
ui->slider_bp_bht_addr_bits, &QAbstractSlider::valueChanged, this,
&NewDialog::bp_bht_addr_bits_change);
connect(ui->select_bp_init_state, QOverload<int>::of(&QComboBox::activated), this, [this] {
config->set_bp_init_state(
ui->select_bp_init_state->currentData().value<machine::PredictorState>());
});
connect(ui->slider_bp_btb_bits, &QAbstractSlider::valueChanged, this, [this] {
config->set_bp_btb_bits((uint8_t)ui->slider_bp_btb_bits->value());
ui->text_bp_btb_bits_number->setText(QString::number(config->get_bp_btb_bits()));
});
connect(ui->slider_bp_bhr_bits, &QAbstractSlider::valueChanged, this, [this] {
config->set_bp_bhr_bits((uint8_t)ui->slider_bp_bhr_bits->value());
ui->text_bp_bhr_bits_number->setText(QString::number(config->get_bp_bhr_bits()));
ui->text_bp_bht_bits_number->setText(QString::number(config->get_bp_bht_bits()));
});
connect(ui->slider_bp_bht_addr_bits, &QAbstractSlider::valueChanged, this, [this] {
config->set_bp_bht_addr_bits((uint8_t)ui->slider_bp_bht_addr_bits->value());
ui->text_bp_bht_addr_bits_number->setText(QString::number(config->get_bp_bht_addr_bits()));
ui->text_bp_bht_bits_number->setText(QString::number(config->get_bp_bht_bits()));
});

cache_handler_d = new NewDialogCacheHandler(this, ui_cache_d.data());
cache_handler_p = new NewDialogCacheHandler(this, ui_cache_p.data());
Expand Down Expand Up @@ -385,10 +391,6 @@ void NewDialog::reset_at_compile_change(bool v) {
config->set_reset_at_compile(v);
}

void NewDialog::bp_enabled_change() {
config->set_bp_enabled(ui->group_branch_predictor->isChecked());
}

void NewDialog::bp_type_change() {
// Read branch predictor type from GUI and store it in the config
const machine::PredictorType predictor_type {
Expand Down Expand Up @@ -458,28 +460,6 @@ void NewDialog::bp_type_change() {
}
}

void NewDialog::bp_init_state_change() {
config->set_bp_init_state(
ui->select_bp_init_state->currentData().value<machine::PredictorState>());
}

void NewDialog::bp_btb_bits_change() {
config->set_bp_btb_bits((uint8_t)ui->slider_bp_btb_bits->value());
ui->text_bp_btb_bits_number->setText(QString::number(config->get_bp_btb_bits()));
}

void NewDialog::bp_bhr_bits_change() {
config->set_bp_bhr_bits((uint8_t)ui->slider_bp_bhr_bits->value());
ui->text_bp_bhr_bits_number->setText(QString::number(config->get_bp_bhr_bits()));
ui->text_bp_bht_bits_number->setText(QString::number(config->get_bp_bht_bits()));
}

void NewDialog::bp_bht_addr_bits_change() {
config->set_bp_bht_addr_bits((uint8_t)ui->slider_bp_bht_addr_bits->value());
ui->text_bp_bht_addr_bits_number->setText(QString::number(config->get_bp_bht_addr_bits()));
ui->text_bp_bht_bits_number->setText(QString::number(config->get_bp_bht_bits()));
}

void NewDialog::bp_toggle_history_table_ui(bool enabled) {
ui->select_bp_init_state->setEnabled(enabled);
ui->slider_bp_bhr_bits->setEnabled(enabled);
Expand Down
5 changes: 0 additions & 5 deletions src/gui/dialogs/new/newdialog.h
Original file line number Diff line number Diff line change
Expand Up @@ -55,12 +55,7 @@ private slots:
void reset_at_compile_change(bool);

// Branch Predictor
void bp_enabled_change();
void bp_type_change();
void bp_init_state_change();
void bp_btb_bits_change();
void bp_bhr_bits_change();
void bp_bht_addr_bits_change();
void bp_toggle_history_table_ui(bool enabled);

private:
Expand Down
2 changes: 1 addition & 1 deletion src/machine/predictor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -614,7 +614,7 @@ BranchPredictor::BranchPredictor(
}

bhr = new BranchHistoryRegister(number_of_bhr_bits);
btb = new BranchTargetBuffer(number_of_bht_bits);
btb = new BranchTargetBuffer(number_of_btb_bits);

if (enabled) {
connect(
Expand Down

0 comments on commit 6c82d44

Please sign in to comment.