提交 1f6553f9 编写于 作者: N Nathan Scott

[XFS] Dynamically allocate local kiocb structures in readv/writev routines

to reduce stack footprint.

SGI-PV: 947312
SGI-Modid: xfs-linux-melb:xfs-kern:25358a
Signed-off-by: NNathan Scott <nathans@sgi.com>
上级 0293ce3a
...@@ -145,17 +145,22 @@ __linvfs_readv( ...@@ -145,17 +145,22 @@ __linvfs_readv(
{ {
struct inode *inode = file->f_mapping->host; struct inode *inode = file->f_mapping->host;
vnode_t *vp = LINVFS_GET_VP(inode); vnode_t *vp = LINVFS_GET_VP(inode);
struct kiocb kiocb; struct kiocb *kiocb;
ssize_t rval; ssize_t rval;
init_sync_kiocb(&kiocb, file); kiocb = kmalloc(sizeof(*kiocb), GFP_KERNEL);
kiocb.ki_pos = *ppos; if (unlikely(!kiocb))
return -ENOMEM;
init_sync_kiocb(kiocb, file);
kiocb->ki_pos = *ppos;
if (unlikely(file->f_flags & O_DIRECT)) if (unlikely(file->f_flags & O_DIRECT))
ioflags |= IO_ISDIRECT; ioflags |= IO_ISDIRECT;
VOP_READ(vp, &kiocb, iov, nr_segs, &kiocb.ki_pos, ioflags, NULL, rval); VOP_READ(vp, kiocb, iov, nr_segs, &kiocb->ki_pos, ioflags, NULL, rval);
*ppos = kiocb.ki_pos; *ppos = kiocb->ki_pos;
kfree(kiocb);
return rval; return rval;
} }
...@@ -190,17 +195,22 @@ __linvfs_writev( ...@@ -190,17 +195,22 @@ __linvfs_writev(
{ {
struct inode *inode = file->f_mapping->host; struct inode *inode = file->f_mapping->host;
vnode_t *vp = LINVFS_GET_VP(inode); vnode_t *vp = LINVFS_GET_VP(inode);
struct kiocb kiocb; struct kiocb *kiocb;
ssize_t rval; ssize_t rval;
init_sync_kiocb(&kiocb, file); kiocb = kmalloc(sizeof(*kiocb), GFP_KERNEL);
kiocb.ki_pos = *ppos; if (unlikely(!kiocb))
return -ENOMEM;
init_sync_kiocb(kiocb, file);
kiocb->ki_pos = *ppos;
if (unlikely(file->f_flags & O_DIRECT)) if (unlikely(file->f_flags & O_DIRECT))
ioflags |= IO_ISDIRECT; ioflags |= IO_ISDIRECT;
VOP_WRITE(vp, &kiocb, iov, nr_segs, &kiocb.ki_pos, ioflags, NULL, rval); VOP_WRITE(vp, kiocb, iov, nr_segs, &kiocb->ki_pos, ioflags, NULL, rval);
*ppos = kiocb.ki_pos; *ppos = kiocb->ki_pos;
kfree(kiocb);
return rval; return rval;
} }
...@@ -435,7 +445,7 @@ linvfs_ioctl( ...@@ -435,7 +445,7 @@ linvfs_ioctl(
unsigned long arg) unsigned long arg)
{ {
int error; int error;
struct inode *inode = filp->f_dentry->d_inode; struct inode *inode = filp->f_dentry->d_inode;
vnode_t *vp = LINVFS_GET_VP(inode); vnode_t *vp = LINVFS_GET_VP(inode);
VOP_IOCTL(vp, inode, filp, 0, cmd, (void __user *)arg, error); VOP_IOCTL(vp, inode, filp, 0, cmd, (void __user *)arg, error);
...@@ -457,7 +467,7 @@ linvfs_ioctl_invis( ...@@ -457,7 +467,7 @@ linvfs_ioctl_invis(
unsigned long arg) unsigned long arg)
{ {
int error; int error;
struct inode *inode = filp->f_dentry->d_inode; struct inode *inode = filp->f_dentry->d_inode;
vnode_t *vp = LINVFS_GET_VP(inode); vnode_t *vp = LINVFS_GET_VP(inode);
ASSERT(vp); ASSERT(vp);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册