Second attempt at fixing FS#10396. Turns out that gcc for coldfire choose to inline a function with a big appetite for stack. The previous fix improved things a bit, but not nearly enough.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@21580 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
02bbf55d9d
commit
a538b89060
1 changed files with 8 additions and 4 deletions
|
@ -1653,8 +1653,12 @@ static int check_if_empty(char **tag)
|
||||||
entry.tag_offset[tag] = offset; \
|
entry.tag_offset[tag] = offset; \
|
||||||
entry.tag_length[tag] = check_if_empty(data); \
|
entry.tag_length[tag] = check_if_empty(data); \
|
||||||
offset += entry.tag_length[tag]
|
offset += entry.tag_length[tag]
|
||||||
|
/* GCC 3.4.6 for Coldfire can choose to inline this function. Not a good
|
||||||
static void add_tagcache(char *path, unsigned long mtime
|
* idea, as it uses lots of stack and is called from a recursive function
|
||||||
|
* (check_dir).
|
||||||
|
*/
|
||||||
|
static void __attribute__ ((noinline)) add_tagcache(char *path,
|
||||||
|
unsigned long mtime
|
||||||
#if defined(HAVE_TC_RAMCACHE) && defined(HAVE_DIRCACHE)
|
#if defined(HAVE_TC_RAMCACHE) && defined(HAVE_DIRCACHE)
|
||||||
,const struct dirent *dc
|
,const struct dirent *dc
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue