Quality RTOS & Embedded Software

 Real time embedded FreeRTOS RSS feed 
Quick Start Supported MCUs PDF Books Trace Tools Ecosystem


STR750_GCC stack allocation

Posted by Jack Peacock on October 1, 2007
In looking at the ARM7/GCC in FreeRTOS 4.5.0 I'm having some trouble understanding the RAM allocations for the STR750 for stacks.
__SVC_Stack_Size = 400 ;
__IRQ_Stack_Size = 400 ;
are obvious, as are the rest of the processor mode stacks. However, in the ARM7_LPC2368_Eclipse example the sizes of those two stacks are set to 100 instead of 400. Is there a reason for the change in size?

Also, in the STR750_GCC example, in the .ld file there is a
_Minimum_Stack_Size = 0xC00 ;
for the user stack, according to comments, to ensure a minimum size for "all stacks" at the top of RAM. What is this, and why doesn't it appear on the other GCC examples? Does this refer to the task stacks, and are the task stacks allocated from the heap or from this area?
Jack Peacock

RE: STR750_GCC stack allocation

Posted by Richard on October 2, 2007
> Is there a reason for the change in size?

Only that 400 is much more than required so wasteful. You can take a look at your stack usage high water mark and adjust as necessary.

>Also, in the STR750_GCC example, in the .ld file there is a
>_Minimum_Stack_Size = 0xC00 ;

The linker files originate from Raisonance so are different just because they come from a different source. I think they put this line in purely so that a linker error will occur should there not be enough room at the top of RAM for at least this amount of stack space - although it seems not to match the sum of the individual stacks that are being allocated.

In the other linker files this link time guard is not used, so if you run out of RAM you will get stack corruption and probably a crash. Putting this line in will not prevent this happening of course, it just makes you more aware of the possibility prior to running the code.


[ Back to the top ]    [ About FreeRTOS ]    [ Privacy ]    [ Sitemap ]    [ ]

Copyright (C) Amazon Web Services, Inc. or its affiliates. All rights reserved.

Latest News

FreeRTOS v10.2.0 is available for immediate download. MIT licensed, and including RISC-V and ARMv8-M (Cortex-M33) demos.

NXP tweet showing LPC5500 (ARMv8-M Cortex-M33) running FreeRTOS.

View a recording of the "OTA Update Security and Reliability" webinar, presented by TI and AWS.


FreeRTOS and other embedded software careers at AWS.

FreeRTOS Partners

ARM Connected RTOS partner for all ARM microcontroller cores

Cadence Tensilica Cortes

Espressif ESP32

IAR Partner

Microchip Premier RTOS Partner

RTOS partner of NXP for all NXP ARM microcontrollers





STMicro RTOS partner supporting ARM7, ARM Cortex-M3, ARM Cortex-M4 and ARM Cortex-M0

Texas Instruments MCU Developer Network RTOS partner for ARM and MSP430 microcontrollers

OpenRTOS and SafeRTOS

Xilinx Microblaze and Zynq partner