mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-12 17:19:10 +01:00
7cecb28bdf
This fixes a problem I was having where using frame advance with the debugger open would frequently cause panic alerts about invalid addresses due to the CPU thread changing MSR.DR while the host thread was trying to access memory. To aid in tracking down all the places where we weren't properly locking the CPU, I've created a new type (in Core.h) that you have to pass as a reference or pointer to functions that require running as the CPU thread.
111 lines
2.2 KiB
C++
111 lines
2.2 KiB
C++
// Copyright 2018 Dolphin Emulator Project
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#pragma once
|
|
|
|
#include <vector>
|
|
|
|
#include <QByteArray>
|
|
#include <QDockWidget>
|
|
|
|
#include "Common/CommonTypes.h"
|
|
|
|
class MemoryViewWidget;
|
|
class QCheckBox;
|
|
class QComboBox;
|
|
class QLabel;
|
|
class QLineEdit;
|
|
class QPushButton;
|
|
class QRadioButton;
|
|
class QShowEvent;
|
|
class QSplitter;
|
|
|
|
namespace Core
|
|
{
|
|
class CPUThreadGuard;
|
|
}
|
|
|
|
class MemoryWidget : public QDockWidget
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
explicit MemoryWidget(QWidget* parent = nullptr);
|
|
~MemoryWidget();
|
|
|
|
void SetAddress(u32 address);
|
|
void Update();
|
|
signals:
|
|
void BreakpointsChanged();
|
|
void ShowCode(u32 address);
|
|
void RequestWatch(QString name, u32 address);
|
|
|
|
private:
|
|
struct TargetAddress
|
|
{
|
|
u32 address = 0;
|
|
bool is_good_address = false;
|
|
bool is_good_offset = false;
|
|
};
|
|
|
|
void CreateWidgets();
|
|
void ConnectWidgets();
|
|
|
|
void LoadSettings();
|
|
void SaveSettings();
|
|
|
|
void OnAddressSpaceChanged();
|
|
void OnDisplayChanged();
|
|
void OnBPLogChanged();
|
|
void OnBPTypeChanged();
|
|
|
|
void OnSearchAddress();
|
|
void OnFindNextValue();
|
|
void OnFindPreviousValue();
|
|
|
|
void OnSetValue();
|
|
void OnSetValueFromFile();
|
|
|
|
void OnDumpMRAM();
|
|
void OnDumpExRAM();
|
|
void OnDumpARAM();
|
|
void OnDumpFakeVMEM();
|
|
|
|
void ValidateAndPreviewInputValue();
|
|
QByteArray GetInputData() const;
|
|
TargetAddress GetTargetAddress() const;
|
|
void FindValue(bool next);
|
|
|
|
void closeEvent(QCloseEvent*) override;
|
|
void showEvent(QShowEvent* event) override;
|
|
|
|
MemoryViewWidget* m_memory_view;
|
|
QSplitter* m_splitter;
|
|
QComboBox* m_search_address;
|
|
QLineEdit* m_search_offset;
|
|
QLineEdit* m_data_edit;
|
|
QCheckBox* m_base_check;
|
|
QLabel* m_data_preview;
|
|
QComboBox* m_display_combo;
|
|
QComboBox* m_align_combo;
|
|
QComboBox* m_row_length_combo;
|
|
QCheckBox* m_dual_check;
|
|
QPushButton* m_set_value;
|
|
|
|
// Search
|
|
QPushButton* m_find_next;
|
|
QPushButton* m_find_previous;
|
|
QComboBox* m_input_combo;
|
|
QLabel* m_result_label;
|
|
|
|
// Address Spaces
|
|
QRadioButton* m_address_space_physical;
|
|
QRadioButton* m_address_space_effective;
|
|
QRadioButton* m_address_space_auxiliary;
|
|
|
|
// Breakpoint options
|
|
QRadioButton* m_bp_read_write;
|
|
QRadioButton* m_bp_read_only;
|
|
QRadioButton* m_bp_write_only;
|
|
QCheckBox* m_bp_log_check;
|
|
};
|