2020-12-06 23:46:37 -05:00
|
|
|
#ifdef HAVE_CONFIG_H
|
2020-12-06 23:42:52 -05:00
|
|
|
#include "config.h"
|
2020-12-06 23:46:37 -05:00
|
|
|
#endif
|
2020-11-30 06:40:33 -05:00
|
|
|
|
2022-05-24 19:01:51 -04:00
|
|
|
#include <kernaux/assert.h>
|
2020-11-27 16:24:12 -05:00
|
|
|
#include <kernaux/multiboot2.h>
|
|
|
|
|
2022-01-13 09:01:51 -05:00
|
|
|
#include <stdbool.h>
|
2020-12-06 05:16:15 -05:00
|
|
|
#include <stddef.h>
|
2022-01-13 09:32:19 -05:00
|
|
|
#include <stdint.h>
|
2020-12-06 05:16:15 -05:00
|
|
|
|
2022-01-12 22:59:52 -05:00
|
|
|
bool KernAux_Multiboot2_Info_is_valid(
|
|
|
|
const struct KernAux_Multiboot2_Info *const multiboot2_info
|
2020-11-27 19:02:44 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(multiboot2_info, false);
|
|
|
|
|
2022-01-13 09:32:19 -05:00
|
|
|
if (multiboot2_info->total_size <
|
|
|
|
sizeof(struct KernAux_Multiboot2_Info) +
|
|
|
|
sizeof(struct KernAux_Multiboot2_ITag_None))
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2020-11-27 19:02:44 -05:00
|
|
|
|
2022-01-13 09:43:57 -05:00
|
|
|
if (multiboot2_info->total_size % KERNAUX_MULTIBOOT2_TAG_ALIGN != 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:03:15 -05:00
|
|
|
const struct KernAux_Multiboot2_ITagBase *tag_base =
|
|
|
|
(struct KernAux_Multiboot2_ITagBase*)
|
2022-01-12 22:59:52 -05:00
|
|
|
KERNAUX_MULTIBOOT2_DATA(multiboot2_info);
|
2020-11-27 19:02:44 -05:00
|
|
|
|
2022-01-12 22:03:15 -05:00
|
|
|
const struct KernAux_Multiboot2_ITagBase *none_tag_base = NULL;
|
2020-11-27 19:02:44 -05:00
|
|
|
|
2021-12-14 14:13:18 -05:00
|
|
|
while (tag_base <
|
2022-01-12 22:03:15 -05:00
|
|
|
(struct KernAux_Multiboot2_ITagBase*)
|
2022-01-13 09:32:19 -05:00
|
|
|
((uint8_t*)multiboot2_info + multiboot2_info->total_size))
|
2021-12-14 14:13:18 -05:00
|
|
|
{
|
2022-01-12 22:03:15 -05:00
|
|
|
if (!KernAux_Multiboot2_ITagBase_is_valid(tag_base)) return false;
|
2020-11-27 19:02:44 -05:00
|
|
|
|
2022-01-12 21:49:25 -05:00
|
|
|
if (tag_base->type == KERNAUX_MULTIBOOT2_ITAG_NONE &&
|
2020-12-06 05:16:15 -05:00
|
|
|
none_tag_base == NULL
|
2020-11-27 19:02:44 -05:00
|
|
|
) {
|
|
|
|
none_tag_base = tag_base;
|
|
|
|
}
|
|
|
|
|
2022-01-13 07:55:59 -05:00
|
|
|
tag_base = KERNAUX_MULTIBOOT2_ITAG_NEXT(tag_base);
|
2020-11-27 19:02:44 -05:00
|
|
|
}
|
|
|
|
|
2021-12-14 14:13:18 -05:00
|
|
|
if (tag_base !=
|
2022-01-12 22:03:15 -05:00
|
|
|
(struct KernAux_Multiboot2_ITagBase*)
|
2022-01-13 09:32:19 -05:00
|
|
|
((uint8_t*)multiboot2_info + multiboot2_info->total_size))
|
2021-12-14 14:13:18 -05:00
|
|
|
{
|
2020-12-06 05:16:15 -05:00
|
|
|
return false;
|
2020-11-27 19:02:44 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if (none_tag_base !=
|
2022-01-12 22:03:15 -05:00
|
|
|
(struct KernAux_Multiboot2_ITagBase*)
|
2022-01-13 09:32:19 -05:00
|
|
|
((uint8_t*)tag_base -
|
2022-01-12 22:38:51 -05:00
|
|
|
sizeof(struct KernAux_Multiboot2_ITag_None)))
|
2021-12-14 14:13:18 -05:00
|
|
|
{
|
2020-12-06 05:16:15 -05:00
|
|
|
return false;
|
2020-11-27 19:02:44 -05:00
|
|
|
}
|
|
|
|
|
2020-12-06 05:16:15 -05:00
|
|
|
return true;
|
2020-11-27 19:02:44 -05:00
|
|
|
}
|
|
|
|
|
2022-01-12 22:03:15 -05:00
|
|
|
bool KernAux_Multiboot2_ITagBase_is_valid(
|
|
|
|
const struct KernAux_Multiboot2_ITagBase *const tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag_base, false);
|
|
|
|
|
2020-11-27 16:24:12 -05:00
|
|
|
switch (tag_base->type) {
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_NONE:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_None_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_None*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_BOOT_CMD_LINE:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_BootCmdLine_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_BootCmdLine*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_BOOT_LOADER_NAME:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_BootLoaderName_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_BootLoaderName*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_MODULE:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_Module_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_Module*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_BASIC_MEMORY_INFO:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_BasicMemoryInfo_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_BasicMemoryInfo*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_BIOS_BOOT_DEVICE:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_BIOSBootDevice_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_BIOSBootDevice*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_MEMORY_MAP:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_MemoryMap_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_MemoryMap*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_VBE_INFO:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_VBEInfo_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_VBEInfo*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_FRAMEBUFFER_INFO:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_FramebufferInfo_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_FramebufferInfo*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_ELF_SYMBOLS:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_ELFSymbols_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_ELFSymbols*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_APM_TABLE:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_APMTable_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_APMTable*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_EFI_32BIT_SYSTEM_TABLE_PTR:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_EFI32bitSystemTablePtr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_EFI32bitSystemTablePtr*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_EFI_64BIT_SYSTEM_TABLE_PTR:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_EFI64bitSystemTablePtr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_EFI64bitSystemTablePtr*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_SMBIOS_TABLES:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_SMBIOSTables_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_SMBIOSTables*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_ACPI_OLD_RSDP:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_ACPIOldRSDP_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_ACPIOldRSDP*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_ACPI_NEW_RSDP:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_ACPINewRSDP_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_ACPINewRSDP*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_NETWORKING_INFO:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_NetworkingInfo_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_NetworkingInfo*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_EFI_MEMORY_MAP:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_EFIMemoryMap_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_EFIMemoryMap*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_EFI_BOOT_SERVICES_NOT_TERMINATED:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_EFIBootServicesNotTerminated_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_EFIBootServicesNotTerminated*)
|
2022-01-12 22:10:33 -05:00
|
|
|
tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_EFI_32BIT_IMAGE_HANDLE_PTR:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_EFI32bitImageHandlePtr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_EFI32bitImageHandlePtr*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_EFI_64BIT_IMAGE_HANDLE_PTR:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_EFI64bitImageHandlePtr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_EFI64bitImageHandlePtr*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
2022-01-12 21:49:25 -05:00
|
|
|
case KERNAUX_MULTIBOOT2_ITAG_IMAGE_LOAD_BASE_PHYS_ADDR:
|
2022-01-12 22:10:33 -05:00
|
|
|
return KernAux_Multiboot2_ITag_ImageLoadBasePhysAddr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
(struct KernAux_Multiboot2_ITag_ImageLoadBasePhysAddr*)tag_base
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
|
|
|
default:
|
2020-12-06 05:16:15 -05:00
|
|
|
return false;
|
2020-11-27 16:24:12 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_None_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_None *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_NONE &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 8
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_BootCmdLine_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_BootCmdLine *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
|
|
|
|
2021-12-16 10:26:16 -05:00
|
|
|
size_t index = 1;
|
2020-11-27 16:24:12 -05:00
|
|
|
|
|
|
|
for (
|
2022-01-11 04:29:56 -05:00
|
|
|
const char *ptr = (char*)KERNAUX_MULTIBOOT2_DATA(tag);
|
2020-11-27 16:24:12 -05:00
|
|
|
*ptr && index < tag->base.size;
|
|
|
|
++ptr
|
|
|
|
) {
|
|
|
|
++index;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_BOOT_CMD_LINE &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 8 + index
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_BootLoaderName_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_BootLoaderName *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
|
|
|
|
2021-12-16 10:26:16 -05:00
|
|
|
size_t index = 1;
|
2020-11-27 16:24:12 -05:00
|
|
|
|
|
|
|
for (
|
2022-01-11 04:29:56 -05:00
|
|
|
const char *ptr = (char*)KERNAUX_MULTIBOOT2_DATA(tag);
|
2020-11-27 16:24:12 -05:00
|
|
|
*ptr && index < tag->base.size;
|
|
|
|
++ptr
|
|
|
|
) {
|
|
|
|
++index;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_BOOT_LOADER_NAME &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 8 + index
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_Module_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_Module *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
|
|
|
|
2021-12-16 10:26:16 -05:00
|
|
|
size_t index = 1;
|
2020-11-27 16:24:12 -05:00
|
|
|
|
|
|
|
for (
|
2022-01-11 04:29:56 -05:00
|
|
|
const char *ptr = (char*)KERNAUX_MULTIBOOT2_DATA(tag);
|
2020-11-27 16:24:12 -05:00
|
|
|
*ptr && index < tag->base.size;
|
|
|
|
++ptr
|
|
|
|
) {
|
|
|
|
++index;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_MODULE &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 16 + index &&
|
|
|
|
tag->mod_start < tag->mod_end
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_BasicMemoryInfo_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_BasicMemoryInfo *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_BASIC_MEMORY_INFO &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 16
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_BIOSBootDevice_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_BIOSBootDevice *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_BIOS_BOOT_DEVICE &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 20
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_MemoryMap_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_MemoryMap *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_MEMORY_MAP &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size >= 16 &&
|
2020-11-28 17:56:20 -05:00
|
|
|
tag->entry_size > 0 &&
|
2020-11-28 17:51:27 -05:00
|
|
|
tag->entry_size % 8 == 0 &&
|
2020-11-27 16:24:12 -05:00
|
|
|
(tag->base.size - 16) % tag->entry_size == 0
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_VBEInfo_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_VBEInfo *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_VBE_INFO &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 784
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_FramebufferInfo_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_FramebufferInfo *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_FRAMEBUFFER_INFO &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size >= 31
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_ELFSymbols_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_ELFSymbols *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_ELF_SYMBOLS &&
|
2022-05-24 11:09:02 -04:00
|
|
|
tag->base.size >= 16 &&
|
|
|
|
(
|
|
|
|
tag->ent_size == 0 ||
|
|
|
|
(tag->base.size - 16) % tag->ent_size == 0
|
|
|
|
)
|
2020-11-27 16:24:12 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_APMTable_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_APMTable *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_APM_TABLE &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 28
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_EFI32bitSystemTablePtr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_EFI32bitSystemTablePtr *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_EFI_32BIT_SYSTEM_TABLE_PTR &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 12
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_EFI64bitSystemTablePtr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_EFI64bitSystemTablePtr *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_EFI_64BIT_SYSTEM_TABLE_PTR &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 16
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_SMBIOSTables_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_SMBIOSTables *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_SMBIOS_TABLES &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size >= 16
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_ACPIOldRSDP_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_ACPIOldRSDP *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_ACPI_OLD_RSDP &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size >= 8
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_ACPINewRSDP_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_ACPINewRSDP *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_ACPI_NEW_RSDP &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size >= 8
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_NetworkingInfo_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_NetworkingInfo *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_NETWORKING_INFO &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size >= 8
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_EFIMemoryMap_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_EFIMemoryMap *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_EFI_MEMORY_MAP &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size >= 16
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_EFIBootServicesNotTerminated_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_EFIBootServicesNotTerminated *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
|
|
|
tag->base.type ==
|
2022-01-12 21:49:25 -05:00
|
|
|
KERNAUX_MULTIBOOT2_ITAG_EFI_BOOT_SERVICES_NOT_TERMINATED &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 8
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_EFI32bitImageHandlePtr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_EFI32bitImageHandlePtr *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_EFI_32BIT_IMAGE_HANDLE_PTR &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 12
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_EFI64bitImageHandlePtr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_EFI64bitImageHandlePtr *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_EFI_64BIT_IMAGE_HANDLE_PTR &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 16
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-01-12 22:10:33 -05:00
|
|
|
bool KernAux_Multiboot2_ITag_ImageLoadBasePhysAddr_is_valid(
|
2022-01-12 22:38:51 -05:00
|
|
|
const struct KernAux_Multiboot2_ITag_ImageLoadBasePhysAddr *const tag
|
2020-11-27 16:24:12 -05:00
|
|
|
) {
|
2022-05-24 19:01:51 -04:00
|
|
|
KERNAUX_NOTNULL_RETVAL(tag, false);
|
2020-11-27 16:24:12 -05:00
|
|
|
return (
|
2022-01-12 21:49:25 -05:00
|
|
|
tag->base.type == KERNAUX_MULTIBOOT2_ITAG_IMAGE_LOAD_BASE_PHYS_ADDR &&
|
2020-11-27 16:24:12 -05:00
|
|
|
tag->base.size == 12
|
|
|
|
);
|
|
|
|
}
|