[En-Nut-Discussion] Can a thread determine its stack space?

Henrik Maier hmnews at proconx.com
Thu Sep 23 01:51:54 CEST 2010


Hi Ulrich,

If you enable just NUTDEBUG_CHECK_STACK during system build,
NutThreadStackAvailable() tells you how much unused stack is available for a
given thread.

This is done using a pattern check for the DEADBEEF pattern. This has no
other performance or code impact to a system than that the stack is filled
with a pattern upon creation in NutThreadCreate().

Refer to context.c and thread.c source code.

Henrik


> -----Original Message-----
> From: en-nut-discussion-bounces at egnite.de [mailto:en-nut-discussion-
> bounces at egnite.de] On Behalf Of Ulrich Prinz
> Sent: Thursday, 23 September 2010 6:13 AM
> To: Ethernut User Chat (English)
> Subject: [En-Nut-Discussion] Can a thread determine its stack space?
> 
> Hi!
> 
> Can a stack determine its own stack space? I.e. I want a thread to
> monitor its own left free stack space. But I cannot find out how to do
> that.
> 
> There are functions that are only available if some debug settings are
> enabled. And some of them are never available as the #defines are never
> set and not available through nutconf.
> 
> But enabling heap debugging doesn't solve the problem if a thread
> silently hangs up while the rest of the system is still running fine.
> And the output of NutHeapAvailable() and NutHeapRootRegionAvailable()
> in the main thread still show plenty of memory.
> 
> Is there a mechanism to find a mutex where a thread is blocked on?
> 
> Enabling debugging has another problem too as it multiplies some stacks
> for init and main and others with a factor what has a general impact on
> the system. So it is difficult to find the problem in a surrounding
> that
> is different from what you target on.
> This might also get difficult if your application needs most of FLASH
> and RAM.
> 
> Best regards
> Ulrich
> _______________________________________________
> http://lists.egnite.de/mailman/listinfo/en-nut-discussion




More information about the En-Nut-Discussion mailing list