Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Open sidebar
Bricked
flo
Commits
ceefda69
Commit
ceefda69
authored
14 years ago
by
Al Viro
Browse files
Options
Download
Email Patches
Plain Diff
switch get_sb_ns() users
Signed-off-by:
Al Viro
<
viro@zeniv.linux.org.uk
>
parent
aed1d84f
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
12 additions
and
15 deletions
+12
-15
fs/super.c
fs/super.c
+6
-8
include/linux/fs.h
include/linux/fs.h
+2
-3
ipc/mqueue.c
ipc/mqueue.c
+4
-4
No files found.
fs/super.c
View file @
ceefda69
...
...
@@ -715,15 +715,14 @@ static int ns_set_super(struct super_block *sb, void *data)
return
set_anon_super
(
sb
,
NULL
);
}
int
get_sb_ns
(
struct
file_system_type
*
fs_type
,
int
flags
,
void
*
data
,
int
(
*
fill_super
)(
struct
super_block
*
,
void
*
,
int
),
struct
vfsmount
*
mnt
)
struct
dentry
*
mount_ns
(
struct
file_system_type
*
fs_type
,
int
flags
,
void
*
data
,
int
(
*
fill_super
)(
struct
super_block
*
,
void
*
,
int
))
{
struct
super_block
*
sb
;
sb
=
sget
(
fs_type
,
ns_test_super
,
ns_set_super
,
data
);
if
(
IS_ERR
(
sb
))
return
PTR_ERR
(
sb
);
return
ERR_CAST
(
sb
);
if
(
!
sb
->
s_root
)
{
int
err
;
...
...
@@ -731,17 +730,16 @@ int get_sb_ns(struct file_system_type *fs_type, int flags, void *data,
err
=
fill_super
(
sb
,
data
,
flags
&
MS_SILENT
?
1
:
0
);
if
(
err
)
{
deactivate_locked_super
(
sb
);
return
err
;
return
ERR_PTR
(
err
)
;
}
sb
->
s_flags
|=
MS_ACTIVE
;
}
simple_set_mnt
(
mnt
,
sb
);
return
0
;
return
dget
(
sb
->
s_root
);
}
EXPORT_SYMBOL
(
get_sb
_ns
);
EXPORT_SYMBOL
(
mount
_ns
);
#ifdef CONFIG_BLOCK
static
int
set_bdev_super
(
struct
super_block
*
s
,
void
*
data
)
...
...
This diff is collapsed.
Click to expand it.
include/linux/fs.h
View file @
ceefda69
...
...
@@ -1789,9 +1789,8 @@ struct file_system_type {
struct
lock_class_key
i_alloc_sem_key
;
};
extern
int
get_sb_ns
(
struct
file_system_type
*
fs_type
,
int
flags
,
void
*
data
,
int
(
*
fill_super
)(
struct
super_block
*
,
void
*
,
int
),
struct
vfsmount
*
mnt
);
extern
struct
dentry
*
mount_ns
(
struct
file_system_type
*
fs_type
,
int
flags
,
void
*
data
,
int
(
*
fill_super
)(
struct
super_block
*
,
void
*
,
int
));
extern
struct
dentry
*
mount_bdev
(
struct
file_system_type
*
fs_type
,
int
flags
,
const
char
*
dev_name
,
void
*
data
,
int
(
*
fill_super
)(
struct
super_block
*
,
void
*
,
int
));
...
...
This diff is collapsed.
Click to expand it.
ipc/mqueue.c
View file @
ceefda69
...
...
@@ -211,13 +211,13 @@ out:
return
error
;
}
static
int
mqueue_
get_sb
(
struct
file_system_type
*
fs_type
,
static
struct
dentry
*
mqueue_
mount
(
struct
file_system_type
*
fs_type
,
int
flags
,
const
char
*
dev_name
,
void
*
data
,
struct
vfsmount
*
mnt
)
void
*
data
)
{
if
(
!
(
flags
&
MS_KERNMOUNT
))
data
=
current
->
nsproxy
->
ipc_ns
;
return
get_sb
_ns
(
fs_type
,
flags
,
data
,
mqueue_fill_super
,
mnt
);
return
mount
_ns
(
fs_type
,
flags
,
data
,
mqueue_fill_super
);
}
static
void
init_once
(
void
*
foo
)
...
...
@@ -1232,7 +1232,7 @@ static const struct super_operations mqueue_super_ops = {
static
struct
file_system_type
mqueue_fs_type
=
{
.
name
=
"mqueue"
,
.
get_sb
=
mqueue_
get_sb
,
.
mount
=
mqueue_
mount
,
.
kill_sb
=
kill_litter_super
,
};
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment