Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
95e05289
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
160
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
95e05289
编写于
8月 29, 2007
作者:
C
Chris Mason
提交者:
David Woodhouse
8月 29, 2007
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Btrfs: Use mount -o subvol to select the subvol directory instead of dev:
Signed-off-by:
N
Chris Mason
<
chris.mason@oracle.com
>
上级
e9fe395e
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
45 addition
and
10 deletion
+45
-10
fs/btrfs/ctree.h
fs/btrfs/ctree.h
+6
-0
fs/btrfs/super.c
fs/btrfs/super.c
+39
-10
未找到文件。
fs/btrfs/ctree.h
浏览文件 @
95e05289
...
...
@@ -1064,6 +1064,12 @@ static inline int btrfs_set_root_name(struct btrfs_root *root,
((type *)(btrfs_leaf_data(leaf) + \
btrfs_item_offset((leaf)->items + (slot))))
/* mount option defines and helpers */
#define BTRFS_MOUNT_SUBVOL 0x000001
#define btrfs_clear_opt(o, opt) o &= ~BTRFS_MOUNT_##opt
#define btrfs_set_opt(o, opt) o |= BTRFS_MOUNT_##opt
#define btrfs_test_opt(sb, opt) (BTRFS_SB(sb)->s_mount_opt & \
BTRFS_MOUNT_##opt)
/* extent-tree.c */
int
btrfs_extent_post_op
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
);
...
...
fs/btrfs/super.c
浏览文件 @
95e05289
...
...
@@ -33,6 +33,7 @@
#include <linux/writeback.h>
#include <linux/statfs.h>
#include <linux/compat.h>
#include <linux/parser.h>
#include "ctree.h"
#include "disk-io.h"
#include "transaction.h"
...
...
@@ -58,6 +59,41 @@ static void btrfs_put_super (struct super_block * sb)
sb
->
s_fs_info
=
NULL
;
}
enum
{
Opt_subvol
,
Opt_err
,
};
static
match_table_t
tokens
=
{
{
Opt_subvol
,
"subvol=%s"
},
{
Opt_err
,
NULL
}
};
static
int
parse_options
(
char
*
options
,
struct
btrfs_root
*
root
,
char
**
subvol_name
)
{
char
*
p
;
substring_t
args
[
MAX_OPT_ARGS
];
if
(
!
options
)
return
1
;
while
((
p
=
strsep
(
&
options
,
","
))
!=
NULL
)
{
int
token
;
if
(
!*
p
)
continue
;
token
=
match_token
(
p
,
tokens
,
args
);
switch
(
token
)
{
case
Opt_subvol
:
*
subvol_name
=
match_strdup
(
&
args
[
0
]);
break
;
default:
return
0
;
}
}
return
1
;
}
static
int
btrfs_fill_super
(
struct
super_block
*
sb
,
void
*
data
,
int
silent
)
{
struct
inode
*
inode
;
...
...
@@ -250,22 +286,15 @@ int btrfs_get_sb_bdev(struct file_system_type *fs_type,
/* end copy & paste */
static
int
btrfs_get_sb
(
struct
file_system_type
*
fs_type
,
int
flags
,
const
char
*
identifier
,
void
*
data
,
struct
vfsmount
*
mnt
)
int
flags
,
const
char
*
dev_name
,
void
*
data
,
struct
vfsmount
*
mnt
)
{
int
ret
;
char
*
_identifier
=
kstrdup
(
identifier
,
GFP_KERNEL
);
char
*
subvol_name
;
const
char
*
dev_name
;
subvol_name
=
_identifier
;
dev_name
=
strsep
(
&
subvol_name
,
":"
);
if
(
!
dev_name
)
return
-
ENOMEM
;
char
*
subvol_name
=
NULL
;
parse_options
((
char
*
)
data
,
NULL
,
&
subvol_name
);
ret
=
btrfs_get_sb_bdev
(
fs_type
,
flags
,
dev_name
,
data
,
btrfs_fill_super
,
mnt
,
subvol_name
?
subvol_name
:
"default"
);
kfree
(
_identifier
);
return
ret
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录