39 lines
1.3 KiB
Plaintext
39 lines
1.3 KiB
Plaintext
/* SPDX-License-Identifier: Apache-2.0 */
|
|
|
|
#ifdef CONFIG_USERSPACE
|
|
/* We need to reserve room for the gperf generated hash functions.
|
|
* Fortunately, unlike the data tables, the size of the code is
|
|
* reasonably predictable.
|
|
*
|
|
* The linker will error out complaining that the location pointer
|
|
* is moving backwards if the reserved room isn't large enough.
|
|
*/
|
|
_kobject_text_area_start = .;
|
|
*(".kobject_data.text*")
|
|
_kobject_text_area_end = .;
|
|
_kobject_text_area_used = _kobject_text_area_end - _kobject_text_area_start;
|
|
#ifndef LINKER_ZEPHYR_FINAL
|
|
#ifdef CONFIG_DYNAMIC_OBJECTS
|
|
PROVIDE(z_object_gperf_find = .);
|
|
PROVIDE(z_object_gperf_wordlist_foreach = .);
|
|
#else
|
|
PROVIDE(z_object_find = .);
|
|
PROVIDE(z_object_wordlist_foreach = .);
|
|
#endif
|
|
#endif
|
|
|
|
/* In a valid build the MAX function will always evaluate to the
|
|
second argument below, but to give the user a good error message
|
|
when the area overflows we need to temporarily corrupt the
|
|
location counter, and then detect the overflow with an assertion
|
|
later on. */
|
|
|
|
. = MAX(., _kobject_text_area_start + CONFIG_KOBJECT_TEXT_AREA);
|
|
|
|
ASSERT(
|
|
CONFIG_KOBJECT_TEXT_AREA >= _kobject_text_area_used,
|
|
"Reserved space for kobject text area is too small. \
|
|
Please change CONFIG_KOBJECT_TEXT_AREA to a larger number."
|
|
);
|
|
#endif /* CONFIG_USERSPACE */
|