1.11.4 Legacy support for __user_initial_stackheap()

Defined in rt_misc.h, __user_initial_stackheap() is supported for backwards compatibility with earlier versions of the ARM C and C++ libraries.


ARM recommends that you use __user_setup_stackheap() in preference to __user_initial_stackheap().

The differences between __user_initial_stackheap() and __user_setup_stackheap() are:

  • __user_initial_stackheap() receives the stack pointer (containing the same value it had on entry to __main()) in r1, and is expected to return the new stack base in r1.

    __user_setup_stackheap() receives the stack pointer in sp, and returns the stack base in sp.

  • __user_initial_stackheap() is provided with a small temporary stack to run on. This temporary stack enables __user_initial_stackheap() to be implemented in C, providing that it uses no more than 88 bytes of stack space.

    __user_setup_stackheap() has no temporary stack and cannot usually be implemented in C.

Using __user_setup_stackheap() instead of __user_initial_stackheap() reduces code size, because __user_setup_stackheap() has no requirement for a temporary stack.

In the following circumstances you cannot use the provided __user_setup_stackheap() function, but you can use the __user_initial_stackheap() function:

  • Your implementation is sufficiently complex that it warrants the use of a temporary stack when setting up the initial heap and stack.

  • You have a requirement to implement the heap and stack creation code in C rather than in assembly language.

Non-ConfidentialPDF file icon PDF versionARM DUI0475M
Copyright © 2010-2016 ARM Limited or its affiliates. All rights reserved.