mirror of
https://github.com/RGBCube/serenity
synced 2025-05-18 01:05:07 +00:00

The `[[gnu::packed]]` attribute apparently lowered the required alignment of the structs, which caused the compiler to generate two 1 byte loads/stores on RISC-V. This caused the kernel to read/write incorrect values, as the device only seems to accept 2 byte operations.
71 lines
1.4 KiB
C++
71 lines
1.4 KiB
C++
/*
|
|
* Copyright (c) 2022, Liav A. <liavalb@hotmail.co.il>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Types.h>
|
|
|
|
namespace Kernel {
|
|
|
|
#define VBE_DISPI_IOPORT_INDEX 0x01CE
|
|
#define VBE_DISPI_IOPORT_DATA 0x01CF
|
|
|
|
#define BOCHS_DISPLAY_LITTLE_ENDIAN 0x1e1e1e1e
|
|
#define BOCHS_DISPLAY_BIG_ENDIAN 0xbebebebe
|
|
|
|
#define VBE_DISPI_ID5 0xB0C5
|
|
|
|
enum class BochsFramebufferSettings {
|
|
Enabled = 0x1,
|
|
LinearFramebuffer = 0x40,
|
|
};
|
|
|
|
enum class BochsDISPIRegisters {
|
|
ID = 0x0,
|
|
XRES = 0x1,
|
|
YRES = 0x2,
|
|
BPP = 0x3,
|
|
ENABLE = 0x4,
|
|
BANK = 0x5,
|
|
VIRT_WIDTH = 0x6,
|
|
VIRT_HEIGHT = 0x7,
|
|
X_OFFSET = 0x8,
|
|
Y_OFFSET = 0x9,
|
|
VIDEO_RAM_64K_CHUNKS_COUNT = 0xA,
|
|
};
|
|
|
|
struct DISPIInterface {
|
|
u16 index_id;
|
|
u16 xres;
|
|
u16 yres;
|
|
u16 bpp;
|
|
u16 enable;
|
|
u16 bank;
|
|
u16 virt_width;
|
|
u16 virt_height;
|
|
u16 x_offset;
|
|
u16 y_offset;
|
|
u16 vram_64k_chunks_count;
|
|
};
|
|
static_assert(AssertSize<DISPIInterface, 22>());
|
|
|
|
struct ExtensionRegisters {
|
|
u32 region_size;
|
|
u32 framebuffer_byteorder;
|
|
};
|
|
static_assert(AssertSize<ExtensionRegisters, 8>());
|
|
|
|
struct BochsDisplayMMIORegisters {
|
|
u8 edid_data[0x400];
|
|
u16 vga_ioports[0x10];
|
|
u8 reserved[0xE0];
|
|
DISPIInterface bochs_regs;
|
|
u8 reserved2[0x100 - sizeof(DISPIInterface)];
|
|
ExtensionRegisters extension_regs;
|
|
};
|
|
static_assert(AssertSize<BochsDisplayMMIORegisters, 1544>());
|
|
|
|
}
|