mirror of
https://github.com/projectacrn/acrn-hypervisor.git
synced 2025-07-03 02:26:24 +00:00
misc: modify the logic of generate HV_RAM_START
The current code assume that there must be an HV_RAM_START element in the scenario and we will generate it if user have not set, the default value of HV_RAM_START is 0x00400000 which cause an overlap issue. This patch remove the requires of HV_RAM_START element, calculate HV_RAM_SIZE and find a region of e820 to run the ACRN which start address will be HV_RAM_START. It is still valid if the user set HV_RAM_START by XMLs. Tracked-On: #6690 Signed-off-by: Chenli Wei <chenli.wei@intel.com>
This commit is contained in:
parent
6024822c01
commit
6d56816e79
@ -13,8 +13,6 @@ import common
|
||||
DESC = """# Board defconfig generated by acrn-config tool
|
||||
"""
|
||||
|
||||
HV_RAM_SIZE_MAX = 0x40000000
|
||||
|
||||
MEM_ALIGN = 2 * common.SIZE_M
|
||||
|
||||
|
||||
@ -54,60 +52,14 @@ def get_serial_type():
|
||||
|
||||
def get_memory(hv_info, config):
|
||||
|
||||
# this dictonary mapped with 'address start':'mem range'
|
||||
ram_range = {}
|
||||
|
||||
post_launched_vm_num = 0
|
||||
for id in common.VM_TYPES:
|
||||
if common.VM_TYPES[id] in scenario_cfg_lib.VM_DB and \
|
||||
scenario_cfg_lib.VM_DB[common.VM_TYPES[id]]["load_type"] == "POST_LAUNCHED_VM":
|
||||
post_launched_vm_num += 1
|
||||
hv_ram_size = common.HV_BASE_RAM_SIZE + common.POST_LAUNCHED_VM_RAM_SIZE * post_launched_vm_num
|
||||
|
||||
ivshmem_enabled = common.get_hv_item_tag(common.SCENARIO_INFO_FILE, "FEATURES", "IVSHMEM", "IVSHMEM_ENABLED")
|
||||
total_shm_size = 0
|
||||
if ivshmem_enabled == 'y':
|
||||
raw_shmem_regions = common.get_hv_item_tag(common.SCENARIO_INFO_FILE, "FEATURES", "IVSHMEM", "IVSHMEM_REGION")
|
||||
for raw_shm in raw_shmem_regions:
|
||||
if raw_shm is None or raw_shm.strip() == '':
|
||||
continue
|
||||
raw_shm_splited = raw_shm.split(',')
|
||||
if len(raw_shm_splited) == 3 and raw_shm_splited[0].strip() != '' \
|
||||
and raw_shm_splited[1].strip() != '' and len(raw_shm_splited[2].strip().split(':')) >= 1:
|
||||
try:
|
||||
size = raw_shm_splited[1].strip()
|
||||
int_size = int(size) * 0x100000
|
||||
total_shm_size += int_size
|
||||
except Exception as e:
|
||||
print(e)
|
||||
|
||||
hv_ram_size += 2 * max(total_shm_size, 0x200000)
|
||||
if hv_ram_size > HV_RAM_SIZE_MAX:
|
||||
common.print_red("requested RAM size should be smaller then {}".format(HV_RAM_SIZE_MAX), err=True)
|
||||
err_dic["board config: total vm number error"] = \
|
||||
"requested RAM size should be smaller then {}".format(HV_RAM_SIZE_MAX)
|
||||
return err_dic
|
||||
|
||||
# reseve 16M memory for hv sbuf, ramoops, etc.
|
||||
reserved_ram = 0x1000000
|
||||
# We recommend to put hv ram start address high than 0x10000000 to
|
||||
# reduce memory conflict with GRUB/Service VM Kernel.
|
||||
hv_start_offset = 0x10000000
|
||||
total_size = reserved_ram + hv_ram_size
|
||||
for start_addr in list(board_cfg_lib.USED_RAM_RANGE):
|
||||
if hv_start_offset <= start_addr < 0x80000000:
|
||||
del board_cfg_lib.USED_RAM_RANGE[start_addr]
|
||||
ram_range = board_cfg_lib.get_ram_range()
|
||||
avl_start_addr = board_cfg_lib.find_avl_memory(ram_range, str(total_size), hv_start_offset)
|
||||
hv_start_addr = int(avl_start_addr, 16) + int(hex(reserved_ram), 16)
|
||||
hv_start_addr = common.round_up(hv_start_addr, MEM_ALIGN)
|
||||
board_cfg_lib.USED_RAM_RANGE[hv_start_addr] = total_size
|
||||
|
||||
if not hv_info.mem.hv_ram_start:
|
||||
print("CONFIG_HV_RAM_START={}".format(hex(hv_start_addr)), file=config)
|
||||
else:
|
||||
print("CONFIG_HV_RAM_START={}".format(hv_info.mem.hv_ram_start), file=config)
|
||||
|
||||
print("CONFIG_HV_RAM_START={}".format(hv_info.mem.hv_ram_start), file=config)
|
||||
print("CONFIG_STACK_SIZE={}".format(hv_info.mem.stack_size), file=config)
|
||||
print("CONFIG_IVSHMEM_ENABLED={}".format(hv_info.mem.ivshmem_enable), file=config)
|
||||
|
||||
|
@ -45,7 +45,7 @@ MAX_VM_NUM = 16
|
||||
MAX_VUART_NUM = 8
|
||||
|
||||
HV_BASE_RAM_SIZE = 0x1400000
|
||||
POST_LAUNCHED_VM_RAM_SIZE = 0x1000000
|
||||
VM_RAM_SIZE = 0x2800000
|
||||
|
||||
class MultiItem():
|
||||
|
||||
|
@ -129,7 +129,7 @@
|
||||
<xs:documentation>Specify the size of the memory stack in bytes for each physical CPU. For example, if you specify 8 kilobytes, each CPU will get its own 8-kilobyte stack.</xs:documentation>
|
||||
</xs:annotation>
|
||||
</xs:element>
|
||||
<xs:element name="HV_RAM_START" type="HexFormat" default="0x00400000">
|
||||
<xs:element name="HV_RAM_START" type="HexFormat" minOccurs="0">
|
||||
<xs:annotation acrn:views="">
|
||||
<xs:documentation>The 2MB-aligned starting physical address of the RAM region used by the hypervisor.</xs:documentation>
|
||||
</xs:annotation>
|
||||
|
50
misc/config_tools/static_allocators/hv_ram.py
Normal file
50
misc/config_tools/static_allocators/hv_ram.py
Normal file
@ -0,0 +1,50 @@
|
||||
#!/usr/bin/env python3
|
||||
#
|
||||
# Copyright (C) 2022 Intel Corporation. All rights reserved.
|
||||
#
|
||||
# SPDX-License-Identifier: BSD-3-Clause
|
||||
#
|
||||
|
||||
import sys, os
|
||||
sys.path.append(os.path.join(os.path.dirname(os.path.abspath(__file__)), '..', 'library'))
|
||||
import common, board_cfg_lib, scenario_cfg_lib
|
||||
|
||||
HV_RAM_SIZE_MAX = 0x40000000
|
||||
|
||||
MEM_ALIGN = 2 * common.SIZE_M
|
||||
|
||||
def fn(board_etree, scenario_etree, allocation_etree):
|
||||
# this dictonary mapped with 'address start':'mem range'
|
||||
ram_range = {}
|
||||
|
||||
vm_num = 0
|
||||
vm_list = scenario_etree.xpath("//vm")
|
||||
if vm_list is not None:
|
||||
vm_num = len(vm_list)
|
||||
hv_ram_size = common.HV_BASE_RAM_SIZE + common.VM_RAM_SIZE * vm_num
|
||||
ivshmem_list = scenario_etree.xpath("//IVSHMEM_SIZE/text()")
|
||||
total_shm_size = 0
|
||||
for ram_size in ivshmem_list:
|
||||
try:
|
||||
total_shm_size += int(ram_size) * 0x100000
|
||||
except Exception as e:
|
||||
print(e)
|
||||
hv_ram_size += 2 * max(total_shm_size, 0x200000)
|
||||
assert(hv_ram_size <= HV_RAM_SIZE_MAX)
|
||||
# reseve 16M memory for hv sbuf, ramoops, etc.
|
||||
reserved_ram = 0x1000000
|
||||
# We recommend to put hv ram start address high than 0x2000000 to
|
||||
# reduce memory conflict with GRUB/SOS Kernel.
|
||||
hv_start_offset = 0x2000000
|
||||
total_size = reserved_ram + hv_ram_size
|
||||
for start_addr in list(board_cfg_lib.USED_RAM_RANGE):
|
||||
if hv_start_offset <= start_addr < 0x80000000:
|
||||
del board_cfg_lib.USED_RAM_RANGE[start_addr]
|
||||
ram_range = board_cfg_lib.get_ram_range()
|
||||
|
||||
avl_start_addr = board_cfg_lib.find_avl_memory(ram_range, str(total_size), hv_start_offset)
|
||||
hv_start_addr = int(avl_start_addr, 16) + int(hex(reserved_ram), 16)
|
||||
hv_start_addr = common.round_up(hv_start_addr, MEM_ALIGN)
|
||||
board_cfg_lib.USED_RAM_RANGE[hv_start_addr] = total_size
|
||||
common.append_node("/acrn-config/hv/MEMORY/HV_RAM_START", hex(hv_start_addr), allocation_etree)
|
||||
common.append_node("/acrn-config/hv/MEMORY/HV_RAM_SIZE", hex(hv_ram_size), allocation_etree)
|
@ -155,6 +155,11 @@
|
||||
<xsl:with-param name="default" select="//allocation-data/acrn-config/hv/MEMORY/HV_RAM_START" />
|
||||
</xsl:call-template>
|
||||
|
||||
<xsl:call-template name="integer-by-key">
|
||||
<xsl:with-param name="key" select="'HV_RAM_SIZE'" />
|
||||
<xsl:with-param name="default" select="//allocation-data/acrn-config/hv/MEMORY/HV_RAM_SIZE" />
|
||||
</xsl:call-template>
|
||||
|
||||
<xsl:call-template name="integer-by-key">
|
||||
<xsl:with-param name="key" select="'STACK_SIZE'" />
|
||||
</xsl:call-template>
|
||||
|
Loading…
Reference in New Issue
Block a user