Files
seL4/tools/hardware/config.py
Ivan-Velickovic 53ed1bef7b tools: fix kernel physBase alignment on AArch64
Signed-off-by: Ivan-Velickovic <i.velickovic@unsw.edu.au>
2025-03-13 19:01:05 +11:00

80 lines
2.7 KiB
Python

#
# Copyright 2020, Data61, CSIRO (ABN 41 687 119 230)
#
# SPDX-License-Identifier: GPL-2.0-only
#
from typing import List, Set
from hardware.memory import Region
class Config:
''' Abstract config class '''
arch = 'unknown'
def __init__(self, sel4arch, addrspace_max):
self.sel4arch = sel4arch
self.addrspace_max = addrspace_max
def get_kernel_phys_align(self) -> int:
''' Used to align the base of physical memory. Returns alignment size in bits. '''
return 0
def get_page_bits(self) -> int:
''' Get page size in bits for this arch '''
return 12 # 4096-byte pages
def get_smallest_kernel_object_alignment(self) -> int:
return 4 # seL4_MinUntypedBits is 4 for all configurations
def get_device_page_bits(self) -> int:
''' Get page size in bits for mapping devices for this arch '''
return self.get_page_bits()
class ARMConfig(Config):
''' Config class for ARM '''
arch = 'arm'
def __init__(self, sel4arch, addrspace_max):
super().__init__(sel4arch, addrspace_max)
# On AArch32 the kernel requires at least super section alignment for physBase.
# Page sizes differ on arm_hyp which is why the alignment changes even though
# both arm_hyp and arm are 32-bit.
if sel4arch == 'arm_hyp':
self.KERNEL_PHYS_ALIGN = 25
elif sel4arch == 'aarch32':
self.KERNEL_PHYS_ALIGN = 24
else:
self.KERNEL_PHYS_ALIGN = 0
def get_kernel_phys_align(self) -> int:
return self.KERNEL_PHYS_ALIGN
class RISCVConfig(Config):
''' Config class for RISCV '''
arch = 'riscv'
MEGAPAGE_BITS_RV32 = 22 # 2^22 = 4 MiByte
MEGAPAGE_BITS_RV64 = 21 # 2^21 = 2 MiByte
MEGA_PAGE_SIZE_RV64 = 2**MEGAPAGE_BITS_RV64
def get_device_page_bits(self) -> int:
''' Get page size in bits for mapping devices for this arch '''
if (self.sel4arch == 'riscv32'):
# 4MiB device pages
return self.MEGAPAGE_BITS_RV32
elif (self.sel4arch == 'riscv64'):
# 2MiB device pages for sv39 and sv48
return self.MEGAPAGE_BITS_RV64
raise ValueError('Unsupported sel4arch "{}" specified.'.format(self.sel4arch))
def get_arch_config(sel4arch: str, addrspace_max: int) -> Config:
''' Return an appropriate Config object for the given architecture '''
if sel4arch in ['aarch32', 'aarch64', 'arm_hyp']:
return ARMConfig(sel4arch, addrspace_max)
elif sel4arch in ['riscv32', 'riscv64']:
return RISCVConfig(sel4arch, addrspace_max)
else:
raise ValueError('Unsupported sel4arch "{}" specified.'.format(sel4arch))