mirror of
https://github.com/portapack-mayhem/mayhem-firmware.git
synced 2025-01-07 23:07:43 +00:00
Extract baseband stats into separate widget
Also removed baseband saturation indication on red (TX) LED. A saturation indicator needs to live somewhere else, and be thought out a bit more...
This commit is contained in:
parent
7c9fc62f5e
commit
154b40d3c9
@ -25,8 +25,43 @@
|
|||||||
|
|
||||||
#include "radio.hpp"
|
#include "radio.hpp"
|
||||||
|
|
||||||
|
#include "hackrf_hal.hpp"
|
||||||
|
using namespace hackrf::one;
|
||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
|
/* BasebandStatsView *****************************************************/
|
||||||
|
|
||||||
|
BasebandStatsView::BasebandStatsView() {
|
||||||
|
add_children({ {
|
||||||
|
&text_used,
|
||||||
|
&text_idle,
|
||||||
|
} });
|
||||||
|
}
|
||||||
|
|
||||||
|
void BasebandStatsView::on_show() {
|
||||||
|
context().message_map[Message::ID::BasebandStatistics] = [this](const Message* const p) {
|
||||||
|
this->on_statistics_update(static_cast<const BasebandStatisticsMessage*>(p)->statistics);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
void BasebandStatsView::on_hide() {
|
||||||
|
context().message_map[Message::ID::BasebandStatistics] = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static std::string ticks_to_percent_string(const uint32_t ticks) {
|
||||||
|
const uint32_t percent_x100 = ticks / (base_m4_clk_f / 10000);
|
||||||
|
return
|
||||||
|
to_string_dec_uint(percent_x100 / 100, 3) + "." +
|
||||||
|
to_string_dec_uint(percent_x100 % 100, 2, '0') + "%";
|
||||||
|
}
|
||||||
|
|
||||||
|
void BasebandStatsView::on_statistics_update(const BasebandStatistics& statistics) {
|
||||||
|
text_used.set(ticks_to_percent_string(statistics.baseband_ticks));
|
||||||
|
text_idle.set(ticks_to_percent_string(statistics.idle_ticks));
|
||||||
|
}
|
||||||
|
|
||||||
DebugMemoryView::DebugMemoryView(NavigationView& nav) {
|
DebugMemoryView::DebugMemoryView(NavigationView& nav) {
|
||||||
add_children({ {
|
add_children({ {
|
||||||
&text_title,
|
&text_title,
|
||||||
|
@ -32,6 +32,27 @@
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
|
class BasebandStatsView : public View {
|
||||||
|
public:
|
||||||
|
BasebandStatsView();
|
||||||
|
|
||||||
|
void on_show() override;
|
||||||
|
void on_hide() override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
Text text_used {
|
||||||
|
{ 0, 0, 7 * 8, 1 * 16 },
|
||||||
|
"",
|
||||||
|
};
|
||||||
|
|
||||||
|
Text text_idle {
|
||||||
|
{ 8 * 8, 0, 7 * 8, 1 * 16 },
|
||||||
|
"",
|
||||||
|
};
|
||||||
|
|
||||||
|
void on_statistics_update(const BasebandStatistics& statistics);
|
||||||
|
};
|
||||||
|
|
||||||
class DebugMemoryView : public View {
|
class DebugMemoryView : public View {
|
||||||
public:
|
public:
|
||||||
DebugMemoryView(NavigationView& nav);
|
DebugMemoryView(NavigationView& nav);
|
||||||
|
@ -27,10 +27,6 @@
|
|||||||
#include "ui_debug.hpp"
|
#include "ui_debug.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
|
||||||
#include "hackrf_hal.hpp"
|
|
||||||
#include "hackrf_gpio.hpp"
|
|
||||||
using namespace hackrf::one;
|
|
||||||
|
|
||||||
extern ReceiverModel receiver_model;
|
extern ReceiverModel receiver_model;
|
||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
@ -42,36 +38,12 @@ SystemStatusView::SystemStatusView() {
|
|||||||
&portapack,
|
&portapack,
|
||||||
//&text_app_fifo_n,
|
//&text_app_fifo_n,
|
||||||
//&text_baseband_fifo_n,
|
//&text_baseband_fifo_n,
|
||||||
&text_ticks,
|
|
||||||
&rssi,
|
&rssi,
|
||||||
&channel,
|
&channel,
|
||||||
&audio,
|
&audio,
|
||||||
} });
|
} });
|
||||||
}
|
}
|
||||||
|
|
||||||
void SystemStatusView::on_show() {
|
|
||||||
context().message_map[Message::ID::BasebandStatistics] = [this](const Message* const p) {
|
|
||||||
this->on_statistics_update(static_cast<const BasebandStatisticsMessage*>(p)->statistics);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
void SystemStatusView::on_hide() {
|
|
||||||
context().message_map[Message::ID::BasebandStatistics] = nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
static std::string ticks_to_percent_string(const uint32_t ticks) {
|
|
||||||
const uint32_t percent_x100 = ticks / (base_m4_clk_f / 10000);
|
|
||||||
return
|
|
||||||
to_string_dec_uint(percent_x100 / 100, 3) + "." +
|
|
||||||
to_string_dec_uint(percent_x100 % 100, 2, '0') + "%";
|
|
||||||
}
|
|
||||||
|
|
||||||
void SystemStatusView::on_statistics_update(const BasebandStatistics& statistics) {
|
|
||||||
led_tx.write(statistics.saturation);
|
|
||||||
portapack.set(ticks_to_percent_string(statistics.baseband_ticks));
|
|
||||||
text_ticks.set(ticks_to_percent_string(statistics.idle_ticks));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Navigation ************************************************************/
|
/* Navigation ************************************************************/
|
||||||
|
|
||||||
NavigationView::NavigationView()
|
NavigationView::NavigationView()
|
||||||
|
@ -39,9 +39,6 @@ class SystemStatusView : public View {
|
|||||||
public:
|
public:
|
||||||
SystemStatusView();
|
SystemStatusView();
|
||||||
|
|
||||||
void on_show() override;
|
|
||||||
void on_hide() override;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Text portapack {
|
Text portapack {
|
||||||
{ 0, 0, 9 * 8, 1 * 16 },
|
{ 0, 0, 9 * 8, 1 * 16 },
|
||||||
@ -58,11 +55,6 @@ private:
|
|||||||
"---",
|
"---",
|
||||||
};
|
};
|
||||||
*/
|
*/
|
||||||
Text text_ticks {
|
|
||||||
{ 9 * 8, 0, 7 * 8, 1 * 16 },
|
|
||||||
"",
|
|
||||||
};
|
|
||||||
|
|
||||||
RSSI rssi {
|
RSSI rssi {
|
||||||
{ 19 * 8, 0, 11 * 8, 4 },
|
{ 19 * 8, 0, 11 * 8, 4 },
|
||||||
};
|
};
|
||||||
@ -74,8 +66,6 @@ private:
|
|||||||
Audio audio {
|
Audio audio {
|
||||||
{ 19 * 8, 10, 11 * 8, 4 },
|
{ 19 * 8, 10, 11 * 8, 4 },
|
||||||
};
|
};
|
||||||
|
|
||||||
void on_statistics_update(const BasebandStatistics& statistics);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class NavigationView : public View {
|
class NavigationView : public View {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user