Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
ac396128
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
ac396128
编写于
11月 15, 2010
作者:
T
Trond Myklebust
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
NFS: readdir shouldn't read beyond the reply returned by the server
Signed-off-by:
N
Trond Myklebust
<
Trond.Myklebust@netapp.com
>
上级
8cd51a0c
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
11 addition
and
7 deletion
+11
-7
fs/nfs/dir.c
fs/nfs/dir.c
+3
-1
fs/nfs/nfs2xdr.c
fs/nfs/nfs2xdr.c
+2
-2
fs/nfs/nfs3xdr.c
fs/nfs/nfs3xdr.c
+2
-2
fs/nfs/nfs4proc.c
fs/nfs/nfs4proc.c
+3
-1
fs/nfs/nfs4xdr.c
fs/nfs/nfs4xdr.c
+1
-1
未找到文件。
fs/nfs/dir.c
浏览文件 @
ac396128
...
...
@@ -573,11 +573,13 @@ int nfs_readdir_xdr_to_array(nfs_readdir_descriptor_t *desc, struct page *page,
if
(
!
pages_ptr
)
goto
out_release_array
;
do
{
unsigned
int
pglen
;
status
=
nfs_readdir_xdr_filler
(
pages
,
desc
,
&
entry
,
file
,
inode
);
if
(
status
<
0
)
break
;
status
=
nfs_readdir_page_filler
(
desc
,
&
entry
,
pages_ptr
,
page
,
array_size
*
PAGE_SIZE
);
pglen
=
status
;
status
=
nfs_readdir_page_filler
(
desc
,
&
entry
,
pages_ptr
,
page
,
pglen
);
if
(
status
<
0
)
{
if
(
status
==
-
ENOSPC
)
status
=
0
;
...
...
fs/nfs/nfs2xdr.c
浏览文件 @
ac396128
...
...
@@ -423,7 +423,7 @@ nfs_xdr_readdirres(struct rpc_rqst *req, __be32 *p, void *dummy)
struct
page
**
page
;
size_t
hdrlen
;
unsigned
int
pglen
,
recvd
;
int
status
,
nr
=
0
;
int
status
;
if
((
status
=
ntohl
(
*
p
++
)))
return
nfs_stat_to_errno
(
status
);
...
...
@@ -443,7 +443,7 @@ nfs_xdr_readdirres(struct rpc_rqst *req, __be32 *p, void *dummy)
if
(
pglen
>
recvd
)
pglen
=
recvd
;
page
=
rcvbuf
->
pages
;
return
nr
;
return
pglen
;
}
static
void
print_overflow_msg
(
const
char
*
func
,
const
struct
xdr_stream
*
xdr
)
...
...
fs/nfs/nfs3xdr.c
浏览文件 @
ac396128
...
...
@@ -555,7 +555,7 @@ nfs3_xdr_readdirres(struct rpc_rqst *req, __be32 *p, struct nfs3_readdirres *res
struct
page
**
page
;
size_t
hdrlen
;
u32
recvd
,
pglen
;
int
status
,
nr
=
0
;
int
status
;
status
=
ntohl
(
*
p
++
);
/* Decode post_op_attrs */
...
...
@@ -586,7 +586,7 @@ nfs3_xdr_readdirres(struct rpc_rqst *req, __be32 *p, struct nfs3_readdirres *res
pglen
=
recvd
;
page
=
rcvbuf
->
pages
;
return
nr
;
return
pglen
;
}
__be32
*
...
...
fs/nfs/nfs4proc.c
浏览文件 @
ac396128
...
...
@@ -2852,8 +2852,10 @@ static int _nfs4_proc_readdir(struct dentry *dentry, struct rpc_cred *cred,
nfs4_setup_readdir
(
cookie
,
NFS_COOKIEVERF
(
dir
),
dentry
,
&
args
);
res
.
pgbase
=
args
.
pgbase
;
status
=
nfs4_call_sync
(
NFS_SERVER
(
dir
),
&
msg
,
&
args
,
&
res
,
0
);
if
(
status
==
0
)
if
(
status
>=
0
)
{
memcpy
(
NFS_COOKIEVERF
(
dir
),
res
.
verifier
.
data
,
NFS4_VERIFIER_SIZE
);
status
+=
args
.
pgbase
;
}
nfs_invalidate_atime
(
dir
);
...
...
fs/nfs/nfs4xdr.c
浏览文件 @
ac396128
...
...
@@ -4518,7 +4518,7 @@ static int decode_readdir(struct xdr_stream *xdr, struct rpc_rqst *req, struct n
xdr_read_pages
(
xdr
,
pglen
);
return
0
;
return
pglen
;
}
static
int
decode_readlink
(
struct
xdr_stream
*
xdr
,
struct
rpc_rqst
*
req
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录