提交 9a0c8230 编写于 作者: S Steve French

[CIFS] Reduce cifs stack space usage

The two cifs functions that used the most stack according
to "make checkstack" have been changed to use less stack.

Thanks to jra and Shaggy for helpful ideas
Signed-off-by: NSteve French <sfrench@us.ibm.com>
cc: jra@samba.org
cc: shaggy@us.ibm.com
上级 030e9d81
...@@ -1146,7 +1146,7 @@ static int cifs_writepages(struct address_space *mapping, ...@@ -1146,7 +1146,7 @@ static int cifs_writepages(struct address_space *mapping,
pgoff_t end; pgoff_t end;
pgoff_t index; pgoff_t index;
int range_whole = 0; int range_whole = 0;
struct kvec iov[32]; struct kvec * iov;
int len; int len;
int n_iov = 0; int n_iov = 0;
pgoff_t next; pgoff_t next;
...@@ -1174,12 +1174,18 @@ static int cifs_writepages(struct address_space *mapping, ...@@ -1174,12 +1174,18 @@ static int cifs_writepages(struct address_space *mapping,
if(!experimEnabled) if(!experimEnabled)
return generic_writepages(mapping, wbc); return generic_writepages(mapping, wbc);
iov = kmalloc(32 * sizeof(struct kvec), GFP_KERNEL);
if(iov == NULL)
return generic_writepages(mapping, wbc);
/* /*
* BB: Is this meaningful for a non-block-device file system? * BB: Is this meaningful for a non-block-device file system?
* If it is, we should test it again after we do I/O * If it is, we should test it again after we do I/O
*/ */
if (wbc->nonblocking && bdi_write_congested(bdi)) { if (wbc->nonblocking && bdi_write_congested(bdi)) {
wbc->encountered_congestion = 1; wbc->encountered_congestion = 1;
kfree(iov);
return 0; return 0;
} }
...@@ -1345,7 +1351,7 @@ static int cifs_writepages(struct address_space *mapping, ...@@ -1345,7 +1351,7 @@ static int cifs_writepages(struct address_space *mapping,
mapping->writeback_index = index; mapping->writeback_index = index;
FreeXid(xid); FreeXid(xid);
kfree(iov);
return rc; return rc;
} }
......
...@@ -196,7 +196,7 @@ dohash(char *out, char *in, char *key, int forw) ...@@ -196,7 +196,7 @@ dohash(char *out, char *in, char *key, int forw)
char c[28]; char c[28];
char d[28]; char d[28];
char *cd; char *cd;
char ki[16][48]; char (*ki)[48];
char *pd1; char *pd1;
char l[32], r[32]; char l[32], r[32];
char *rl; char *rl;
...@@ -206,6 +206,10 @@ dohash(char *out, char *in, char *key, int forw) ...@@ -206,6 +206,10 @@ dohash(char *out, char *in, char *key, int forw)
if(pk1 == NULL) if(pk1 == NULL)
return; return;
ki = kmalloc(16*48, GFP_KERNEL);
if(ki == NULL)
return;
cd = pk1 + 56; cd = pk1 + 56;
pd1= cd + 56; pd1= cd + 56;
rl = pd1 + 64; rl = pd1 + 64;
...@@ -243,6 +247,7 @@ dohash(char *out, char *in, char *key, int forw) ...@@ -243,6 +247,7 @@ dohash(char *out, char *in, char *key, int forw)
er = kmalloc(48+48+32+32+32, GFP_KERNEL); er = kmalloc(48+48+32+32+32, GFP_KERNEL);
if(er == NULL) { if(er == NULL) {
kfree(pk1); kfree(pk1);
kfree(ki);
return; return;
} }
erk = er+48; erk = er+48;
...@@ -290,6 +295,7 @@ dohash(char *out, char *in, char *key, int forw) ...@@ -290,6 +295,7 @@ dohash(char *out, char *in, char *key, int forw)
permute(out, rl, perm6, 64); permute(out, rl, perm6, 64);
kfree(pk1); kfree(pk1);
kfree(ki);
} }
static void static void
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册