Due to the use of gperf to generate hash table for kobjects, the addresses of these kobjects cannot change during the last few phases of linking (especially between zephyr_prebuilt.elf and zephyr.elf). Because of this, the gperf generated data needs to be placed at the end of memory to avoid pushing symbols around in memory. This prevents moving these generated blocks to earlier sections, for example, pinned data section needed for demand paging. So create placeholders for use in intermediate linking to reserve space for these generated blocks. Due to uncertainty on the size of these blocks, more space is being reserved which could result in wasted space. Though, this retains the use of hash table for faster lookup. Signed-off-by: Daniel Leung <daniel.leung@intel.com>
76 lines
1.9 KiB
Plaintext
76 lines
1.9 KiB
Plaintext
/*
|
|
* Copyright (c) 2017,2021 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#ifdef CONFIG_USERSPACE
|
|
|
|
z_kobject_data_begin = .;
|
|
SECTION_DATA_PROLOGUE(kobject_data,,)
|
|
{
|
|
|
|
#if !defined(LINKER_ZEPHYR_PREBUILT) && \
|
|
!defined(LINKER_ZEPHYR_FINAL)
|
|
|
|
#ifdef CONFIG_DYNAMIC_OBJECTS
|
|
PROVIDE(_thread_idx_map = .);
|
|
. += CONFIG_MAX_THREAD_BYTES;
|
|
#endif
|
|
|
|
#endif /* !LINKER_ZEPHYR_PREBUILT && !LINKER_ZEPHYR_FINAL */
|
|
|
|
/* During LINKER_KOBJECT_PREBUILT and LINKER_ZEPHYR_PREBUILT,
|
|
* space needs to be reserved for the rodata that will be
|
|
* produced by gperf during the final stages of linking.
|
|
* The alignment and size are produced by
|
|
* scripts/gen_kobject_placeholders.py. These are here
|
|
* so the addresses to kobjects would remain the same
|
|
* during the final stages of linking (LINKER_ZEPHYR_FINAL).
|
|
*/
|
|
|
|
#if defined(LINKER_ZEPHYR_PREBUILT)
|
|
#include <linker-kobject-prebuilt-data.h>
|
|
|
|
#ifdef CONFIG_DYNAMIC_OBJECTS
|
|
/* This is produced by gperf. Put a place holder here
|
|
* to avoid compilation error.
|
|
*/
|
|
PROVIDE(_thread_idx_map = .);
|
|
#endif
|
|
#ifdef KOBJECT_DATA_ALIGN
|
|
. = ALIGN(KOBJECT_DATA_ALIGN);
|
|
. += KOBJECT_DATA_SZ;
|
|
#endif
|
|
#endif /* LINKER_ZEPHYR_PREBUILT */
|
|
|
|
#if defined(LINKER_ZEPHYR_FINAL)
|
|
#include <linker-kobject-prebuilt-data.h>
|
|
#ifdef KOBJECT_DATA_ALIGN
|
|
. = ALIGN(KOBJECT_DATA_ALIGN);
|
|
|
|
_kobject_data_area_start = .;
|
|
#endif
|
|
|
|
*(".kobject_data.data*")
|
|
|
|
#ifdef KOBJECT_DATA_ALIGN
|
|
_kobject_data_area_end = .;
|
|
_kobject_data_area_used = _kobject_data_area_end - _kobject_data_area_start;
|
|
|
|
ASSERT(_kobject_data_area_used <= KOBJECT_DATA_SZ,
|
|
"scripts/gen_kobject_placeholders.py did not reserve enough space \
|
|
for kobject data."
|
|
);
|
|
|
|
/* Padding is needed to preserve kobject addresses
|
|
* if we have reserved more space than needed.
|
|
*/
|
|
. = MAX(., _kobject_data_area_start + KOBJECT_DATA_SZ);
|
|
#endif /* KOBJECT_DATA_ALIGN */
|
|
#endif /* LINKER_ZEPHYR_FINAL */
|
|
|
|
} GROUP_DATA_LINK_IN(RAMABLE_REGION, ROMABLE_REGION)
|
|
|
|
#endif /* CONFIG_USERSPACE */
|