summaryrefslogtreecommitdiff
path: root/src/citra_qt/debugger/registers.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/citra_qt/debugger/registers.cpp')
-rw-r--r--src/citra_qt/debugger/registers.cpp190
1 files changed, 0 insertions, 190 deletions
diff --git a/src/citra_qt/debugger/registers.cpp b/src/citra_qt/debugger/registers.cpp
deleted file mode 100644
index f9345c9f6..000000000
--- a/src/citra_qt/debugger/registers.cpp
+++ /dev/null
@@ -1,190 +0,0 @@
1// Copyright 2014 Citra Emulator Project
2// Licensed under GPLv2 or any later version
3// Refer to the license.txt file included.
4
5#include <QTreeWidgetItem>
6#include "citra_qt/debugger/registers.h"
7#include "citra_qt/util/util.h"
8#include "core/arm/arm_interface.h"
9#include "core/core.h"
10
11RegistersWidget::RegistersWidget(QWidget* parent) : QDockWidget(parent) {
12 cpu_regs_ui.setupUi(this);
13
14 tree = cpu_regs_ui.treeWidget;
15 tree->addTopLevelItem(core_registers = new QTreeWidgetItem(QStringList(tr("Registers"))));
16 tree->addTopLevelItem(vfp_registers = new QTreeWidgetItem(QStringList(tr("VFP Registers"))));
17 tree->addTopLevelItem(vfp_system_registers =
18 new QTreeWidgetItem(QStringList(tr("VFP System Registers"))));
19 tree->addTopLevelItem(cpsr = new QTreeWidgetItem(QStringList("CPSR")));
20
21 for (int i = 0; i < 16; ++i) {
22 QTreeWidgetItem* child = new QTreeWidgetItem(QStringList(QString("R[%1]").arg(i)));
23 core_registers->addChild(child);
24 }
25
26 for (int i = 0; i < 32; ++i) {
27 QTreeWidgetItem* child = new QTreeWidgetItem(QStringList(QString("S[%1]").arg(i)));
28 vfp_registers->addChild(child);
29 }
30
31 QFont font = GetMonospaceFont();
32
33 CreateCPSRChildren();
34 CreateVFPSystemRegisterChildren();
35
36 // Set Registers to display in monospace font
37 for (int i = 0; i < core_registers->childCount(); ++i)
38 core_registers->child(i)->setFont(1, font);
39
40 for (int i = 0; i < vfp_registers->childCount(); ++i)
41 vfp_registers->child(i)->setFont(1, font);
42
43 for (int i = 0; i < vfp_system_registers->childCount(); ++i) {
44 vfp_system_registers->child(i)->setFont(1, font);
45 for (int x = 0; x < vfp_system_registers->child(i)->childCount(); ++x) {
46 vfp_system_registers->child(i)->child(x)->setFont(1, font);
47 }
48 }
49 // Set CSPR to display in monospace font
50 cpsr->setFont(1, font);
51 for (int i = 0; i < cpsr->childCount(); ++i) {
52 cpsr->child(i)->setFont(1, font);
53 for (int x = 0; x < cpsr->child(i)->childCount(); ++x) {
54 cpsr->child(i)->child(x)->setFont(1, font);
55 }
56 }
57 setEnabled(false);
58}
59
60void RegistersWidget::OnDebugModeEntered() {
61 if (!Core::System::GetInstance().IsPoweredOn())
62 return;
63
64 for (int i = 0; i < core_registers->childCount(); ++i)
65 core_registers->child(i)->setText(
66 1, QString("0x%1").arg(Core::CPU().GetReg(i), 8, 16, QLatin1Char('0')));
67
68 UpdateCPSRValues();
69}
70
71void RegistersWidget::OnDebugModeLeft() {}
72
73void RegistersWidget::OnEmulationStarting(EmuThread* emu_thread) {
74 setEnabled(true);
75}
76
77void RegistersWidget::OnEmulationStopping() {
78 // Reset widget text
79 for (int i = 0; i < core_registers->childCount(); ++i)
80 core_registers->child(i)->setText(1, QString(""));
81
82 for (int i = 0; i < vfp_registers->childCount(); ++i)
83 vfp_registers->child(i)->setText(1, QString(""));
84
85 for (int i = 0; i < cpsr->childCount(); ++i)
86 cpsr->child(i)->setText(1, QString(""));
87
88 cpsr->setText(1, QString(""));
89
90 // FPSCR
91 for (int i = 0; i < vfp_system_registers->child(0)->childCount(); ++i)
92 vfp_system_registers->child(0)->child(i)->setText(1, QString(""));
93
94 // FPEXC
95 for (int i = 0; i < vfp_system_registers->child(1)->childCount(); ++i)
96 vfp_system_registers->child(1)->child(i)->setText(1, QString(""));
97
98 vfp_system_registers->child(0)->setText(1, QString(""));
99 vfp_system_registers->child(1)->setText(1, QString(""));
100 vfp_system_registers->child(2)->setText(1, QString(""));
101 vfp_system_registers->child(3)->setText(1, QString(""));
102
103 setEnabled(false);
104}
105
106void RegistersWidget::CreateCPSRChildren() {
107 cpsr->addChild(new QTreeWidgetItem(QStringList("M")));
108 cpsr->addChild(new QTreeWidgetItem(QStringList("T")));
109 cpsr->addChild(new QTreeWidgetItem(QStringList("F")));
110 cpsr->addChild(new QTreeWidgetItem(QStringList("I")));
111 cpsr->addChild(new QTreeWidgetItem(QStringList("A")));
112 cpsr->addChild(new QTreeWidgetItem(QStringList("E")));
113 cpsr->addChild(new QTreeWidgetItem(QStringList("IT")));
114 cpsr->addChild(new QTreeWidgetItem(QStringList("GE")));
115 cpsr->addChild(new QTreeWidgetItem(QStringList("DNM")));
116 cpsr->addChild(new QTreeWidgetItem(QStringList("J")));
117 cpsr->addChild(new QTreeWidgetItem(QStringList("Q")));
118 cpsr->addChild(new QTreeWidgetItem(QStringList("V")));
119 cpsr->addChild(new QTreeWidgetItem(QStringList("C")));
120 cpsr->addChild(new QTreeWidgetItem(QStringList("Z")));
121 cpsr->addChild(new QTreeWidgetItem(QStringList("N")));
122}
123
124void RegistersWidget::UpdateCPSRValues() {
125 const u32 cpsr_val = Core::CPU().GetCPSR();
126
127 cpsr->setText(1, QString("0x%1").arg(cpsr_val, 8, 16, QLatin1Char('0')));
128 cpsr->child(0)->setText(
129 1, QString("b%1").arg(cpsr_val & 0x1F, 5, 2, QLatin1Char('0'))); // M - Mode
130 cpsr->child(1)->setText(1, QString::number((cpsr_val >> 5) & 1)); // T - State
131 cpsr->child(2)->setText(1, QString::number((cpsr_val >> 6) & 1)); // F - FIQ disable
132 cpsr->child(3)->setText(1, QString::number((cpsr_val >> 7) & 1)); // I - IRQ disable
133 cpsr->child(4)->setText(1, QString::number((cpsr_val >> 8) & 1)); // A - Imprecise abort
134 cpsr->child(5)->setText(1, QString::number((cpsr_val >> 9) & 1)); // E - Data endianness
135 cpsr->child(6)->setText(1,
136 QString::number((cpsr_val >> 10) & 0x3F)); // IT - If-Then state (DNM)
137 cpsr->child(7)->setText(1,
138 QString::number((cpsr_val >> 16) & 0xF)); // GE - Greater-than-or-Equal
139 cpsr->child(8)->setText(1, QString::number((cpsr_val >> 20) & 0xF)); // DNM - Do not modify
140 cpsr->child(9)->setText(1, QString::number((cpsr_val >> 24) & 1)); // J - Jazelle
141 cpsr->child(10)->setText(1, QString::number((cpsr_val >> 27) & 1)); // Q - Saturation
142 cpsr->child(11)->setText(1, QString::number((cpsr_val >> 28) & 1)); // V - Overflow
143 cpsr->child(12)->setText(1, QString::number((cpsr_val >> 29) & 1)); // C - Carry/Borrow/Extend
144 cpsr->child(13)->setText(1, QString::number((cpsr_val >> 30) & 1)); // Z - Zero
145 cpsr->child(14)->setText(1, QString::number((cpsr_val >> 31) & 1)); // N - Negative/Less than
146}
147
148void RegistersWidget::CreateVFPSystemRegisterChildren() {
149 QTreeWidgetItem* const fpscr = new QTreeWidgetItem(QStringList("FPSCR"));
150 fpscr->addChild(new QTreeWidgetItem(QStringList("IOC")));
151 fpscr->addChild(new QTreeWidgetItem(QStringList("DZC")));
152 fpscr->addChild(new QTreeWidgetItem(QStringList("OFC")));
153 fpscr->addChild(new QTreeWidgetItem(QStringList("UFC")));
154 fpscr->addChild(new QTreeWidgetItem(QStringList("IXC")));
155 fpscr->addChild(new QTreeWidgetItem(QStringList("IDC")));
156 fpscr->addChild(new QTreeWidgetItem(QStringList("IOE")));
157 fpscr->addChild(new QTreeWidgetItem(QStringList("DZE")));
158 fpscr->addChild(new QTreeWidgetItem(QStringList("OFE")));
159 fpscr->addChild(new QTreeWidgetItem(QStringList("UFE")));
160 fpscr->addChild(new QTreeWidgetItem(QStringList("IXE")));
161 fpscr->addChild(new QTreeWidgetItem(QStringList("IDE")));
162 fpscr->addChild(new QTreeWidgetItem(QStringList(tr("Vector Length"))));
163 fpscr->addChild(new QTreeWidgetItem(QStringList(tr("Vector Stride"))));
164 fpscr->addChild(new QTreeWidgetItem(QStringList(tr("Rounding Mode"))));
165 fpscr->addChild(new QTreeWidgetItem(QStringList("FZ")));
166 fpscr->addChild(new QTreeWidgetItem(QStringList("DN")));
167 fpscr->addChild(new QTreeWidgetItem(QStringList("V")));
168 fpscr->addChild(new QTreeWidgetItem(QStringList("C")));
169 fpscr->addChild(new QTreeWidgetItem(QStringList("Z")));
170 fpscr->addChild(new QTreeWidgetItem(QStringList("N")));
171
172 QTreeWidgetItem* const fpexc = new QTreeWidgetItem(QStringList("FPEXC"));
173 fpexc->addChild(new QTreeWidgetItem(QStringList("IOC")));
174 fpexc->addChild(new QTreeWidgetItem(QStringList("OFC")));
175 fpexc->addChild(new QTreeWidgetItem(QStringList("UFC")));
176 fpexc->addChild(new QTreeWidgetItem(QStringList("INV")));
177 fpexc->addChild(new QTreeWidgetItem(QStringList(tr("Vector Iteration Count"))));
178 fpexc->addChild(new QTreeWidgetItem(QStringList("FP2V")));
179 fpexc->addChild(new QTreeWidgetItem(QStringList("EN")));
180 fpexc->addChild(new QTreeWidgetItem(QStringList("EX")));
181
182 vfp_system_registers->addChild(fpscr);
183 vfp_system_registers->addChild(fpexc);
184 vfp_system_registers->addChild(new QTreeWidgetItem(QStringList("FPINST")));
185 vfp_system_registers->addChild(new QTreeWidgetItem(QStringList("FPINST2")));
186}
187
188void RegistersWidget::UpdateVFPSystemRegisterValues() {
189 UNIMPLEMENTED();
190}