summaryrefslogtreecommitdiff
path: root/apps/nshlib/nsh_fscmds.c
diff options
context:
space:
mode:
authorGregory Nutt <gnutt@nuttx.org>2014-04-21 18:12:59 -0600
committerGregory Nutt <gnutt@nuttx.org>2014-04-21 18:12:59 -0600
commit47159ade11ffc2349f7d695b0d7838ab9d5fa7cf (patch)
tree40207f90b53572da4ccffd52e181cd3f8f19d836 /apps/nshlib/nsh_fscmds.c
parentadef15b74515b624c5584458dcfaea6b7619ad2f (diff)
downloadpx4-nuttx-47159ade11ffc2349f7d695b0d7838ab9d5fa7cf.tar.gz
px4-nuttx-47159ade11ffc2349f7d695b0d7838ab9d5fa7cf.tar.bz2
px4-nuttx-47159ade11ffc2349f7d695b0d7838ab9d5fa7cf.zip
NSH library: malloc/free IOBUFFER instead of using stack
Diffstat (limited to 'apps/nshlib/nsh_fscmds.c')
-rw-r--r--apps/nshlib/nsh_fscmds.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/apps/nshlib/nsh_fscmds.c b/apps/nshlib/nsh_fscmds.c
index 860e0b814..14e174243 100644
--- a/apps/nshlib/nsh_fscmds.c
+++ b/apps/nshlib/nsh_fscmds.c
@@ -416,7 +416,7 @@ static int ls_recursive(FAR struct nsh_vtbl_s *vtbl, const char *dirpath,
static int cat_common(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
FAR const char *filename)
{
- char buffer[IOBUFFERSIZE];
+ FAR char *buffer;
int fd;
int ret = OK;
@@ -429,6 +429,13 @@ static int cat_common(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
return ERROR;
}
+ buffer = (FAR char *)malloc(IOBUFFERSIZE);
+ if(buffer == NULL)
+ {
+ nsh_output(vtbl, g_fmtcmdfailed, cmd, "malloc", NSH_ERRNO);
+ return ERROR;
+ }
+
/* And just dump it byte for byte into stdout */
for (;;)
@@ -514,6 +521,7 @@ static int cat_common(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
/* Close the input file and return the result */
(void)close(fd);
+ free(buffer);
return ret;
}
#endif