Files
SystemPaw3/paw/stos/head/ke/bpal.h
T
Chloe M. e9a1de69cf stos: bpal: Add memory map callbacks
Signed-off-by: Chloe M. <chloe@mensia.org>
2026-06-22 03:51:35 +00:00

101 lines
1.8 KiB
C

/*
* Copyright (c) 2026, Chloe M.
* Provided under the BSD-3 clause.
*
* Description: Boot protocol abstraction layer
* Author: Chloe M.
*/
#ifndef _KE_BPAL_H_
#define _KE_BPAL_H_ 1
#include <stapi/status.h>
#include <stdef.h>
/*
* Valid memory types
*/
typedef enum {
MEMORY_USABLE,
MEMORY_RESERVED,
MEMORY_ACPI_RECLAIM,
MEMORY_ACPI_NVS,
MEMORY_BAD,
MEMORY_BOOTLOADER,
MEMORY_KERNEL,
MEMORY_FRAMEBUFFER,
MEMORY_ACPI_TABLES
} MEM_TYPE;
/*
* Memory map entry
*
* @Base: Entry base
* @Length: Entry length
* @Type: Entry type
*/
typedef struct {
UQUAD Base;
UQUAD Length;
UQUAD Type;
} MEMMAP_ENTRY;
/*
* Represents a framebuffer
*/
typedef struct {
VOID *Address;
UQUAD Width;
UQUAD Height;
UQUAD Pitch;
SHORT Bpp;
UCHAR RedMaskSize;
UCHAR RedMaskShift;
UCHAR GreenMaskSize;
UCHAR GreenMaskShift;
UCHAR BlueMaskSize;
UCHAR BlueMaskShift;
} BPAL_FRAMEBUFFER;
/*
* Boot protocol abstraction handle
*
* @KernelBase: Kernel load base
* @Framebuffer: Framebuffer info
* @MemEntryIdx: Callback to get memory map entry by index
*/
typedef struct {
UPTR KernelBase;
BPAL_FRAMEBUFFER Framebuffer;
ST_STATUS(*MemEntryIdx)(USIZE Idx, MEMMAP_ENTRY *Result);
} BPAL_HANDLE;
/*
* Initialize the boot protocol abstraction layer
*/
VOID KeBpalInit(VOID);
/*
* Obtain the boot protocol handle
*
* @Result: Result is written here
*/
VOID KeBpalGetHandle(BPAL_HANDLE *Result);
/*
* Obtain the kernel load virtual memory base
*/
ALWAYS_INLINE static inline UPTR
KeBpalLoadBase(VOID)
{
BPAL_HANDLE Handle;
KeBpalGetHandle(&Handle);
return Handle.KernelBase;
}
/* Backend init functions */
VOID KeBpalLimineInit(BPAL_HANDLE *Handle);
#endif /* !_KE_BPAL_H_ */