Serenity Operating System
at master 42 lines 1.6 kB view raw
1/* 2 * Copyright (c) 2021, Sahan Fernando <sahan.h.fernando@gmail.com> 3 * 4 * SPDX-License-Identifier: BSD-2-Clause 5 */ 6 7#include <Kernel/Graphics/Console/ContiguousFramebufferConsole.h> 8#include <Kernel/TTY/ConsoleManagement.h> 9 10namespace Kernel::Graphics { 11 12NonnullLockRefPtr<ContiguousFramebufferConsole> ContiguousFramebufferConsole::initialize(PhysicalAddress framebuffer_address, size_t width, size_t height, size_t pitch) 13{ 14 return adopt_lock_ref(*new ContiguousFramebufferConsole(framebuffer_address, width, height, pitch)); 15} 16 17ContiguousFramebufferConsole::ContiguousFramebufferConsole(PhysicalAddress framebuffer_address, size_t width, size_t height, size_t pitch) 18 : GenericFramebufferConsole(width, height, pitch) 19 , m_framebuffer_address(framebuffer_address) 20{ 21 set_resolution(width, height, pitch); 22} 23 24void ContiguousFramebufferConsole::set_resolution(size_t width, size_t height, size_t pitch) 25{ 26 m_width = width; 27 m_height = height; 28 m_pitch = pitch; 29 30 size_t size = Memory::page_round_up(pitch * height).release_value_but_fixme_should_propagate_errors(); 31 dbgln("Framebuffer Console: taking {} bytes", size); 32 auto region_or_error = MM.allocate_kernel_region(m_framebuffer_address, size, "Framebuffer Console"sv, Memory::Region::Access::ReadWrite, Memory::Region::Cacheable::Yes); 33 VERIFY(!region_or_error.is_error()); 34 m_framebuffer_region = region_or_error.release_value(); 35 36 // Just to start cleanly, we clean the entire framebuffer 37 memset(m_framebuffer_region->vaddr().as_ptr(), 0, pitch * height); 38 39 ConsoleManagement::the().resolution_was_changed(); 40} 41 42}