Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
9499b434
K
Kernel
项目概览
openeuler
/
Kernel
大约 1 年 前同步成功
通知
5
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
9499b434
编写于
6月 24, 2007
作者:
T
Trond Myklebust
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
SUNRPC: Give credential cache a local spinlock
Signed-off-by:
N
Trond Myklebust
<
Trond.Myklebust@netapp.com
>
上级
31be5bf1
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
41 addition
and
14 deletion
+41
-14
include/linux/sunrpc/auth.h
include/linux/sunrpc/auth.h
+3
-0
net/sunrpc/auth.c
net/sunrpc/auth.c
+32
-14
net/sunrpc/auth_unix.c
net/sunrpc/auth_unix.c
+5
-0
net/sunrpc/sunrpc_syms.c
net/sunrpc/sunrpc_syms.c
+1
-0
未找到文件。
include/linux/sunrpc/auth.h
浏览文件 @
9499b434
...
...
@@ -63,6 +63,7 @@ struct rpc_cred {
#define RPC_CREDCACHE_MASK (RPC_CREDCACHE_NR - 1)
struct
rpc_cred_cache
{
struct
hlist_head
hashtable
[
RPC_CREDCACHE_NR
];
spinlock_t
lock
;
unsigned
long
nextgc
;
/* next garbage collection */
unsigned
long
expire
;
/* cache expiry interval */
};
...
...
@@ -126,6 +127,8 @@ struct rpc_credops {
extern
const
struct
rpc_authops
authunix_ops
;
extern
const
struct
rpc_authops
authnull_ops
;
void
__init
rpc_init_authunix
(
void
);
int
rpcauth_register
(
const
struct
rpc_authops
*
);
int
rpcauth_unregister
(
const
struct
rpc_authops
*
);
struct
rpc_auth
*
rpcauth_create
(
rpc_authflavor_t
,
struct
rpc_clnt
*
);
...
...
net/sunrpc/auth.c
浏览文件 @
9499b434
...
...
@@ -120,6 +120,18 @@ rpcauth_unhash_cred_locked(struct rpc_cred *cred)
clear_bit
(
RPCAUTH_CRED_HASHED
,
&
cred
->
cr_flags
);
}
static
void
rpcauth_unhash_cred
(
struct
rpc_cred
*
cred
)
{
spinlock_t
*
cache_lock
;
cache_lock
=
&
cred
->
cr_auth
->
au_credcache
->
lock
;
spin_lock
(
cache_lock
);
if
(
atomic_read
(
&
cred
->
cr_count
)
==
0
)
rpcauth_unhash_cred_locked
(
cred
);
spin_unlock
(
cache_lock
);
}
/*
* Initialize RPC credential cache
*/
...
...
@@ -134,6 +146,7 @@ rpcauth_init_credcache(struct rpc_auth *auth, unsigned long expire)
return
-
ENOMEM
;
for
(
i
=
0
;
i
<
RPC_CREDCACHE_NR
;
i
++
)
INIT_HLIST_HEAD
(
&
new
->
hashtable
[
i
]);
spin_lock_init
(
&
new
->
lock
);
new
->
expire
=
expire
;
new
->
nextgc
=
jiffies
+
(
expire
>>
1
);
auth
->
au_credcache
=
new
;
...
...
@@ -168,6 +181,7 @@ rpcauth_clear_credcache(struct rpc_cred_cache *cache)
int
i
;
spin_lock
(
&
rpc_credcache_lock
);
spin_lock
(
&
cache
->
lock
);
for
(
i
=
0
;
i
<
RPC_CREDCACHE_NR
;
i
++
)
{
head
=
&
cache
->
hashtable
[
i
];
while
(
!
hlist_empty
(
head
))
{
...
...
@@ -177,6 +191,7 @@ rpcauth_clear_credcache(struct rpc_cred_cache *cache)
rpcauth_unhash_cred_locked
(
cred
);
}
}
spin_unlock
(
&
cache
->
lock
);
spin_unlock
(
&
rpc_credcache_lock
);
rpcauth_destroy_credlist
(
&
free
);
}
...
...
@@ -202,6 +217,7 @@ rpcauth_destroy_credcache(struct rpc_auth *auth)
static
void
rpcauth_prune_expired
(
struct
list_head
*
free
)
{
spinlock_t
*
cache_lock
;
struct
rpc_cred
*
cred
;
while
(
!
list_empty
(
&
cred_unused
))
{
...
...
@@ -212,9 +228,14 @@ rpcauth_prune_expired(struct list_head *free)
list_del_init
(
&
cred
->
cr_lru
);
if
(
atomic_read
(
&
cred
->
cr_count
)
!=
0
)
continue
;
get_rpccred
(
cred
);
list_add_tail
(
&
cred
->
cr_lru
,
free
);
rpcauth_unhash_cred_locked
(
cred
);
cache_lock
=
&
cred
->
cr_auth
->
au_credcache
->
lock
;
spin_lock
(
cache_lock
);
if
(
atomic_read
(
&
cred
->
cr_count
)
==
0
)
{
get_rpccred
(
cred
);
list_add_tail
(
&
cred
->
cr_lru
,
free
);
rpcauth_unhash_cred_locked
(
cred
);
}
spin_unlock
(
cache_lock
);
}
}
...
...
@@ -253,21 +274,19 @@ rpcauth_lookup_credcache(struct rpc_auth *auth, struct auth_cred * acred,
hlist_for_each_entry_rcu
(
entry
,
pos
,
&
cache
->
hashtable
[
nr
],
cr_hash
)
{
if
(
!
entry
->
cr_ops
->
crmatch
(
acred
,
entry
,
flags
))
continue
;
spin_lock
(
&
rpc_credcache_
lock
);
spin_lock
(
&
cache
->
lock
);
if
(
test_bit
(
RPCAUTH_CRED_HASHED
,
&
entry
->
cr_flags
)
==
0
)
{
spin_unlock
(
&
rpc_credcache_
lock
);
spin_unlock
(
&
cache
->
lock
);
continue
;
}
cred
=
get_rpccred
(
entry
);
spin_unlock
(
&
rpc_credcache_
lock
);
spin_unlock
(
&
cache
->
lock
);
break
;
}
rcu_read_unlock
();
if
(
cred
!=
NULL
)
{
rpcauth_gc_credcache
(
cache
,
&
free
);
if
(
cred
!=
NULL
)
goto
found
;
}
new
=
auth
->
au_ops
->
crcreate
(
auth
,
acred
,
flags
);
if
(
IS_ERR
(
new
))
{
...
...
@@ -275,7 +294,7 @@ rpcauth_lookup_credcache(struct rpc_auth *auth, struct auth_cred * acred,
goto
out
;
}
spin_lock
(
&
rpc_credcache_
lock
);
spin_lock
(
&
cache
->
lock
);
hlist_for_each_entry
(
entry
,
pos
,
&
cache
->
hashtable
[
nr
],
cr_hash
)
{
if
(
!
entry
->
cr_ops
->
crmatch
(
acred
,
entry
,
flags
))
continue
;
...
...
@@ -288,9 +307,7 @@ rpcauth_lookup_credcache(struct rpc_auth *auth, struct auth_cred * acred,
hlist_add_head_rcu
(
&
cred
->
cr_hash
,
&
cache
->
hashtable
[
nr
]);
}
else
list_add_tail
(
&
new
->
cr_lru
,
&
free
);
rpcauth_prune_expired
(
&
free
);
cache
->
nextgc
=
jiffies
+
cache
->
expire
;
spin_unlock
(
&
rpc_credcache_lock
);
spin_unlock
(
&
cache
->
lock
);
found:
if
(
test_bit
(
RPCAUTH_CRED_NEW
,
&
cred
->
cr_flags
)
&&
cred
->
cr_ops
->
cr_init
!=
NULL
...
...
@@ -301,6 +318,7 @@ rpcauth_lookup_credcache(struct rpc_auth *auth, struct auth_cred * acred,
cred
=
ERR_PTR
(
res
);
}
}
rpcauth_gc_credcache
(
cache
,
&
free
);
rpcauth_destroy_credlist
(
&
free
);
out:
return
cred
;
...
...
@@ -393,7 +411,7 @@ put_rpccred(struct rpc_cred *cred)
if
(
!
list_empty
(
&
cred
->
cr_lru
))
list_del_init
(
&
cred
->
cr_lru
);
if
(
test_bit
(
RPCAUTH_CRED_UPTODATE
,
&
cred
->
cr_flags
)
==
0
)
rpcauth_unhash_cred
_locked
(
cred
);
rpcauth_unhash_cred
(
cred
);
else
if
(
test_bit
(
RPCAUTH_CRED_HASHED
,
&
cred
->
cr_flags
)
!=
0
)
{
cred
->
cr_expire
=
jiffies
;
list_add_tail
(
&
cred
->
cr_lru
,
&
cred_unused
);
...
...
net/sunrpc/auth_unix.c
浏览文件 @
9499b434
...
...
@@ -213,6 +213,11 @@ unx_validate(struct rpc_task *task, __be32 *p)
return
p
;
}
void
__init
rpc_init_authunix
(
void
)
{
spin_lock_init
(
&
unix_cred_cache
.
lock
);
}
const
struct
rpc_authops
authunix_ops
=
{
.
owner
=
THIS_MODULE
,
.
au_flavor
=
RPC_AUTH_UNIX
,
...
...
net/sunrpc/sunrpc_syms.c
浏览文件 @
9499b434
...
...
@@ -152,6 +152,7 @@ init_sunrpc(void)
cache_register
(
&
ip_map_cache
);
cache_register
(
&
unix_gid_cache
);
init_socket_xprt
();
rpc_init_authunix
();
out:
return
err
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录