Serenity Operating System
at master 42 lines 1.7 kB view raw
1/* 2 * Copyright (c) 2022, Liav A. <liavalb@hotmail.co.il> 3 * 4 * SPDX-License-Identifier: BSD-2-Clause 5 */ 6 7#pragma once 8 9#include <AK/RefPtr.h> 10#include <AK/Try.h> 11#include <AK/Types.h> 12#include <Kernel/Graphics/Intel/Transcoder/DisplayTranscoder.h> 13 14namespace Kernel { 15 16class IntelDisplayConnectorGroup; 17class IntelAnalogDisplayTranscoder final : public IntelDisplayTranscoder { 18public: 19 static ErrorOr<NonnullOwnPtr<IntelAnalogDisplayTranscoder>> create_with_physical_addresses(PhysicalAddress transcoder_registers_start_address, 20 PhysicalAddress pipe_registers_start_address, PhysicalAddress dpll_registers_start_address, PhysicalAddress dpll_control_registers_start_address); 21 22 virtual ErrorOr<void> set_dpll_settings(Badge<IntelDisplayConnectorGroup>, IntelGraphics::PLLSettings const& settings, size_t dac_multiplier) override; 23 virtual ErrorOr<void> enable_dpll_without_vga(Badge<IntelDisplayConnectorGroup>) override; 24 virtual ErrorOr<void> disable_dpll(Badge<IntelDisplayConnectorGroup>) override; 25 26private: 27 struct [[gnu::packed]] DPLLRegisters { 28 u32 divisor_a0; 29 u32 divisor_a1; 30 }; 31 32 struct [[gnu::packed]] DPLLControlRegisters { 33 u32 control; 34 u32 padding; // On Gen4, this is the control register of DPLL B, don't touch this 35 u32 multiplier; 36 }; 37 38 IntelAnalogDisplayTranscoder(Memory::TypedMapping<TranscoderRegisters volatile>, Memory::TypedMapping<PipeRegisters volatile>, Memory::TypedMapping<DPLLRegisters volatile>, Memory::TypedMapping<DPLLControlRegisters volatile>); 39 Memory::TypedMapping<DPLLRegisters volatile> m_dpll_registers; 40 Memory::TypedMapping<DPLLControlRegisters volatile> m_dpll_control_registers; 41}; 42}