diff options
author | Petr Machata <pmachata@redhat.com> | 2013-08-22 16:46:17 +0200 |
---|---|---|
committer | Paul Smith <psmith@gnu.org> | 2013-09-14 20:38:06 -0400 |
commit | ab78cbc71ce16dd39e4b6b9e42c02f75bf1d8a50 (patch) | |
tree | 98acbcad59538b0f2925c64d8c2438c958856117 | |
parent | c5bfa400448a14f4c8d4fc51dd56ea17176e1f84 (diff) | |
download | gunmake-ab78cbc71ce16dd39e4b6b9e42c02f75bf1d8a50.tar.gz |
[SV 39851] Reinstate stack size limit for processes spawned via $(shell)
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | function.c | 9 |
2 files changed, 13 insertions, 1 deletions
@@ -55,6 +55,11 @@ * makefile.vms: Ditto. * po/POTFILES.in: Ditto. +2013-08-22 Petr Machata <pmachata@redhat.com> + + * function.c (func_shell_base): Get rid of any avoidable limit on + stack size for processes spawned via $(shell). + 2013-07-22 Paul Smith <psmith@gnu.org> * implicit.c (pattern_search): Use PARSE_SIMPLE_SEQ() even for @@ -1718,7 +1718,14 @@ func_shell_base (char *o, char **argv, int trim_newlines) if (pid < 0) perror_with_name (error_prefix, "fork"); else if (pid == 0) - child_execute_job (0, pipedes[1], command_argv, envp); + { +#ifdef SET_STACK_SIZE + /* Reset limits, if necessary. */ + if (stack_limit.rlim_cur) + setrlimit (RLIMIT_STACK, &stack_limit); +#endif + child_execute_job (0, pipedes[1], command_argv, envp); + } else # endif #endif |