Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
X
xv6-public
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
问题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
银宸时代
OS Lab Group
奖励实验
xv6-public
提交
2744a423
提交
2744a423
6月 18, 2011
创建
作者:
Nickolai Zeldovich
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
double-int keys for dev/ino
上级
b635db5d
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
29 行增加
和
10 行删除
+29
-10
defs.h
defs.h
+9
-2
fs.c
fs.c
+4
-5
ns.c
ns.c
+16
-3
没有找到文件。
defs.h
浏览文件 @
2744a423
...
...
@@ -101,19 +101,26 @@ void mpstartthem(void);
// ns.c
enum
{
nskey_int
=
1
,
nskey_ii
,
nskey_str
,
nskey_iistr
};
struct
nskey
{
int
type
;
union
{
uint
i
;
struct
{
uint
a
;
uint
b
;
}
ii
;
char
*
s
;
}
u
;
};
#define KI(v) (struct nskey){.type=nskey_int,.u.i=v}
#define KS(v) (struct nskey){.type=nskey_str,.u.s=v}
#define KI(v) (struct nskey){.type=nskey_int,.u.i=v}
#define KII(x,y) (struct nskey){.type=nskey_ii,.u.ii.a=x,.u.ii.b=y}
#define KS(v) (struct nskey){.type=nskey_str,.u.s=v}
void
nsinit
(
void
);
struct
ns
*
nsalloc
(
int
allowdup
);
...
...
fs.c
浏览文件 @
2744a423
...
...
@@ -143,7 +143,7 @@ iinit(void)
ip
->
inum
=
-
i
-
1
;
initlock
(
&
ip
->
lock
,
"icache-lock"
);
initcondvar
(
&
ip
->
cv
,
"icache-cv"
);
ns_insert
(
ins
,
KI
(
ip
->
inum
),
ip
);
ns_insert
(
ins
,
KI
I
(
ip
->
dev
,
ip
->
inum
),
ip
);
}
}
...
...
@@ -230,9 +230,8 @@ iget(uint dev, uint inum)
retry:
// Try for cached inode.
rcu_begin_read
();
ip
=
ns_lookup
(
ins
,
KI
(
inum
));
// XXX ignore dev
ip
=
ns_lookup
(
ins
,
KI
I
(
dev
,
inum
));
if
(
ip
)
{
if
(
ip
->
dev
!=
dev
)
panic
(
"iget dev mismatch"
);
// tricky: first bump ref, then check free flag
__sync_fetch_and_add
(
&
ip
->
ref
,
1
);
if
(
ip
->
flags
&
I_FREE
)
{
...
...
@@ -265,7 +264,7 @@ iget(uint dev, uint inum)
goto
retry_evict
;
}
release
(
&
victim
->
lock
);
ns_remove
(
ins
,
KI
(
victim
->
inum
),
victim
);
ns_remove
(
ins
,
KI
I
(
victim
->
dev
,
victim
->
inum
),
victim
);
rcu_delayed
(
victim
,
kmfree
);
ip
=
kmalloc
(
sizeof
(
*
ip
));
...
...
@@ -277,7 +276,7 @@ iget(uint dev, uint inum)
snprintf
(
ip
->
lockname
,
sizeof
(
ip
->
lockname
),
"cv:ino:%d"
,
ip
->
inum
);
initlock
(
&
ip
->
lock
,
ip
->
lockname
+
3
);
initcondvar
(
&
ip
->
cv
,
ip
->
lockname
);
if
(
ns_insert
(
ins
,
KI
(
ip
->
inum
),
ip
)
<
0
)
{
if
(
ns_insert
(
ins
,
KI
I
(
ip
->
dev
,
ip
->
inum
),
ip
)
<
0
)
{
rcu_delayed
(
ip
,
kmfree
);
goto
retry
;
}
...
...
ns.c
浏览文件 @
2744a423
...
...
@@ -19,6 +19,10 @@ struct elem {
struct
elem
*
volatile
next
;
union
{
uint
ikey
;
struct
{
uint
a
;
uint
b
;
}
iikey
;
char
skey
[
0
];
};
};
...
...
@@ -60,7 +64,10 @@ elemalloc(struct nskey *k)
int
sz
;
switch
(
k
->
type
)
{
case
nskey_int
:
sz
=
sizeof
(
*
e
);
sz
=
offsetof
(
struct
elem
,
ikey
)
+
sizeof
(
e
->
ikey
);
break
;
case
nskey_ii
:
sz
=
offsetof
(
struct
elem
,
iikey
)
+
sizeof
(
e
->
iikey
);
break
;
case
nskey_str
:
sz
=
offsetof
(
struct
elem
,
skey
)
+
strlen
(
k
->
u
.
s
)
+
1
;
...
...
@@ -82,6 +89,8 @@ h(struct nskey *k)
switch
(
k
->
type
)
{
case
nskey_int
:
return
k
->
u
.
i
%
NHASH
;
case
nskey_ii
:
return
(
k
->
u
.
ii
.
a
^
k
->
u
.
ii
.
b
)
%
NHASH
;
case
nskey_str
:
return
k
->
u
.
s
[
0
]
%
NHASH
;
// XXX
default:
...
...
@@ -96,6 +105,10 @@ setkey(struct elem *e, struct nskey *k)
case
nskey_int
:
e
->
ikey
=
k
->
u
.
i
;
break
;
case
nskey_ii
:
e
->
iikey
.
a
=
k
->
u
.
ii
.
a
;
e
->
iikey
.
b
=
k
->
u
.
ii
.
b
;
break
;
case
nskey_str
:
strncpy
(
e
->
skey
,
k
->
u
.
s
,
__INT_MAX__
);
break
;
...
...
@@ -110,10 +123,10 @@ cmpkey(struct elem *e, struct nskey *k)
switch
(
k
->
type
)
{
case
nskey_int
:
return
e
->
ikey
==
k
->
u
.
i
;
break
;
case
nskey_ii
:
return
e
->
iikey
.
a
==
k
->
u
.
ii
.
a
&&
e
->
iikey
.
b
==
k
->
u
.
ii
.
b
;
case
nskey_str
:
return
!
strcmp
(
e
->
skey
,
k
->
u
.
s
);
break
;
default:
panic
(
"key type"
);
}
...
...
编写
预览
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论