Commit 5387320d authored by Simon Derr's avatar Simon Derr Committed by Eric Van Hensbergen

9pnet: refactor struct p9_fcall alloc code

Signed-off-by: default avatarSimon Derr <simon.derr@bull.net>
Signed-off-by: default avatarEric Van Hensbergen <ericvh@gmail.com>
parent 17b6fd9d
...@@ -204,6 +204,17 @@ static int parse_opts(char *opts, struct p9_client *clnt) ...@@ -204,6 +204,17 @@ static int parse_opts(char *opts, struct p9_client *clnt)
return ret; return ret;
} }
struct p9_fcall *p9_fcall_alloc(int alloc_msize)
{
struct p9_fcall *fc;
fc = kmalloc(sizeof(struct p9_fcall) + alloc_msize, GFP_NOFS);
if (!fc)
return NULL;
fc->capacity = alloc_msize;
fc->sdata = (char *) fc + sizeof(struct p9_fcall);
return fc;
}
/** /**
* p9_tag_alloc - lookup/allocate a request by tag * p9_tag_alloc - lookup/allocate a request by tag
* @c: client session to lookup tag within * @c: client session to lookup tag within
...@@ -256,29 +267,19 @@ p9_tag_alloc(struct p9_client *c, u16 tag, unsigned int max_size) ...@@ -256,29 +267,19 @@ p9_tag_alloc(struct p9_client *c, u16 tag, unsigned int max_size)
col = tag % P9_ROW_MAXTAG; col = tag % P9_ROW_MAXTAG;
req = &c->reqs[row][col]; req = &c->reqs[row][col];
if (!req->tc) { if (!req->wq) {
req->wq = kmalloc(sizeof(wait_queue_head_t), GFP_NOFS); req->wq = kmalloc(sizeof(wait_queue_head_t), GFP_NOFS);
if (!req->wq) if (!req->wq)
goto grow_failed; goto grow_failed;
init_waitqueue_head(req->wq); init_waitqueue_head(req->wq);
req->tc = kmalloc(sizeof(struct p9_fcall) + alloc_msize,
GFP_NOFS);
if (!req->tc)
goto grow_failed;
req->tc->capacity = alloc_msize;
req->tc->sdata = (char *) req->tc + sizeof(struct p9_fcall);
} }
if (!req->rc) {
req->rc = kmalloc(sizeof(struct p9_fcall) + alloc_msize,
GFP_NOFS);
if (!req->rc)
goto grow_failed;
req->rc->capacity = alloc_msize; if (!req->tc)
req->rc->sdata = (char *) req->rc + sizeof(struct p9_fcall); req->tc = p9_fcall_alloc(alloc_msize);
} if (!req->rc)
req->rc = p9_fcall_alloc(alloc_msize);
if (!req->tc || !req->rc)
goto grow_failed;
p9pdu_reset(req->tc); p9pdu_reset(req->tc);
p9pdu_reset(req->rc); p9pdu_reset(req->rc);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment