summaryrefslogtreecommitdiff
path: root/Kernel
diff options
context:
space:
mode:
authorLiav A <liavalb@gmail.com>2022-05-14 00:29:54 +0300
committerLinus Groh <mail@linusgroh.de>2022-06-06 20:11:05 +0100
commitd84d81fc4eb8a368c1ff13afd26ae75731608728 (patch)
tree47065183b4228a2d8785773cd0f67c35efadc1f3 /Kernel
parent6fca2134d2f677c1e41ecaa0e8fdf643ba743e8c (diff)
downloadserenity-d84d81fc4eb8a368c1ff13afd26ae75731608728.zip
Kernel/Graphics: Flush the entire buffer if using VirtIO console
Keeping the exact details of a dirty rectangle doesn't make any sense when we just flush the entire screen, so just keep a simple boolean value to know if the screen needs to be flushed or not.
Diffstat (limited to 'Kernel')
-rw-r--r--Kernel/Graphics/VirtIOGPU/Console.cpp29
-rw-r--r--Kernel/Graphics/VirtIOGPU/Console.h20
2 files changed, 6 insertions, 43 deletions
diff --git a/Kernel/Graphics/VirtIOGPU/Console.cpp b/Kernel/Graphics/VirtIOGPU/Console.cpp
index 234fd2ba47..5d33a5c403 100644
--- a/Kernel/Graphics/VirtIOGPU/Console.cpp
+++ b/Kernel/Graphics/VirtIOGPU/Console.cpp
@@ -11,24 +11,6 @@ namespace Kernel::Graphics::VirtIOGPU {
constexpr static AK::Time refresh_interval = AK::Time::from_milliseconds(16);
-void DirtyRect::union_rect(size_t x, size_t y, size_t width, size_t height)
-{
- if (width == 0 || height == 0)
- return;
- if (m_is_dirty) {
- m_x0 = min(x, m_x0);
- m_y0 = min(y, m_y0);
- m_x1 = max(x + width, m_x1);
- m_y1 = max(y + height, m_y1);
- } else {
- m_is_dirty = true;
- m_x0 = x;
- m_y0 = y;
- m_x1 = x + width;
- m_y1 = y + height;
- }
-}
-
NonnullRefPtr<Console> Console::initialize(VirtIODisplayConnector& parent_display_connector)
{
auto current_resolution = parent_display_connector.current_mode_setting();
@@ -47,23 +29,22 @@ void Console::set_resolution(size_t, size_t, size_t)
// FIXME: Update some values here?
}
-void Console::flush(size_t x, size_t y, size_t width, size_t height)
+void Console::flush(size_t, size_t, size_t, size_t)
{
- m_dirty_rect.union_rect(x, y, width, height);
+ m_dirty = true;
}
void Console::enqueue_refresh_timer()
{
NonnullRefPtr<Timer> refresh_timer = adopt_ref(*new Timer());
refresh_timer->setup(CLOCK_MONOTONIC, refresh_interval, [this]() {
- auto rect = m_dirty_rect;
- if (m_enabled.load() && rect.is_dirty()) {
+ if (m_enabled.load() && m_dirty) {
MUST(g_io_work->try_queue([this]() {
{
MutexLocker locker(m_parent_display_connector->m_flushing_lock);
MUST(m_parent_display_connector->flush_first_surface());
}
- m_dirty_rect.clear();
+ m_dirty = false;
}));
}
enqueue_refresh_timer();
@@ -78,7 +59,7 @@ void Console::enable()
m_width = current_resolution.horizontal_active;
m_height = current_resolution.vertical_active;
m_pitch = current_resolution.horizontal_stride;
- m_dirty_rect.union_rect(0, 0, m_width, m_height);
+ m_dirty = true;
}
u8* Console::framebuffer_data()
diff --git a/Kernel/Graphics/VirtIOGPU/Console.h b/Kernel/Graphics/VirtIOGPU/Console.h
index ab9d9076b6..a84c354967 100644
--- a/Kernel/Graphics/VirtIOGPU/Console.h
+++ b/Kernel/Graphics/VirtIOGPU/Console.h
@@ -12,24 +12,6 @@
namespace Kernel::Graphics::VirtIOGPU {
-class DirtyRect {
-public:
- void union_rect(size_t x, size_t y, size_t width, size_t height);
- bool is_dirty() const { return m_is_dirty; }
- size_t x() const { return m_x0; }
- size_t y() const { return m_y0; }
- size_t width() const { return m_x1 - m_x0; }
- size_t height() const { return m_y1 - m_y0; }
- void clear() { m_is_dirty = false; }
-
-private:
- bool m_is_dirty { false };
- size_t m_x0 { 0 };
- size_t m_y0 { 0 };
- size_t m_x1 { 0 };
- size_t m_y1 { 0 };
-};
-
class Console final : public GenericFramebufferConsole {
public:
static NonnullRefPtr<Console> initialize(VirtIODisplayConnector& parent_display_connector);
@@ -44,7 +26,7 @@ private:
Console(VirtIODisplayConnector const& parent_display_connector, DisplayConnector::ModeSetting current_resolution);
NonnullRefPtr<VirtIODisplayConnector> m_parent_display_connector;
- DirtyRect m_dirty_rect;
+ bool m_dirty { false };
};
}