Commit e11400b0 authored by Miklos Szeredi's avatar Miklos Szeredi Committed by Linus Torvalds

mount options: fix adfs

Add a .show_options super operation to adfs.
Signed-off-by: default avatarMiklos Szeredi <mszeredi@suse.cz>
Acked-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent b3b304a2
...@@ -20,6 +20,8 @@ ...@@ -20,6 +20,8 @@
#include <linux/vfs.h> #include <linux/vfs.h>
#include <linux/parser.h> #include <linux/parser.h>
#include <linux/bitops.h> #include <linux/bitops.h>
#include <linux/mount.h>
#include <linux/seq_file.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include <asm/system.h> #include <asm/system.h>
...@@ -30,6 +32,9 @@ ...@@ -30,6 +32,9 @@
#include "dir_f.h" #include "dir_f.h"
#include "dir_fplus.h" #include "dir_fplus.h"
#define ADFS_DEFAULT_OWNER_MASK S_IRWXU
#define ADFS_DEFAULT_OTHER_MASK (S_IRWXG | S_IRWXO)
void __adfs_error(struct super_block *sb, const char *function, const char *fmt, ...) void __adfs_error(struct super_block *sb, const char *function, const char *fmt, ...)
{ {
char error_buf[128]; char error_buf[128];
...@@ -134,6 +139,22 @@ static void adfs_put_super(struct super_block *sb) ...@@ -134,6 +139,22 @@ static void adfs_put_super(struct super_block *sb)
sb->s_fs_info = NULL; sb->s_fs_info = NULL;
} }
static int adfs_show_options(struct seq_file *seq, struct vfsmount *mnt)
{
struct adfs_sb_info *asb = ADFS_SB(mnt->mnt_sb);
if (asb->s_uid != 0)
seq_printf(seq, ",uid=%u", asb->s_uid);
if (asb->s_gid != 0)
seq_printf(seq, ",gid=%u", asb->s_gid);
if (asb->s_owner_mask != ADFS_DEFAULT_OWNER_MASK)
seq_printf(seq, ",ownmask=%o", asb->s_owner_mask);
if (asb->s_other_mask != ADFS_DEFAULT_OTHER_MASK)
seq_printf(seq, ",othmask=%o", asb->s_other_mask);
return 0;
}
enum {Opt_uid, Opt_gid, Opt_ownmask, Opt_othmask, Opt_err}; enum {Opt_uid, Opt_gid, Opt_ownmask, Opt_othmask, Opt_err};
static match_table_t tokens = { static match_table_t tokens = {
...@@ -259,6 +280,7 @@ static const struct super_operations adfs_sops = { ...@@ -259,6 +280,7 @@ static const struct super_operations adfs_sops = {
.put_super = adfs_put_super, .put_super = adfs_put_super,
.statfs = adfs_statfs, .statfs = adfs_statfs,
.remount_fs = adfs_remount, .remount_fs = adfs_remount,
.show_options = adfs_show_options,
}; };
static struct adfs_discmap *adfs_read_map(struct super_block *sb, struct adfs_discrecord *dr) static struct adfs_discmap *adfs_read_map(struct super_block *sb, struct adfs_discrecord *dr)
...@@ -344,8 +366,8 @@ static int adfs_fill_super(struct super_block *sb, void *data, int silent) ...@@ -344,8 +366,8 @@ static int adfs_fill_super(struct super_block *sb, void *data, int silent)
/* set default options */ /* set default options */
asb->s_uid = 0; asb->s_uid = 0;
asb->s_gid = 0; asb->s_gid = 0;
asb->s_owner_mask = S_IRWXU; asb->s_owner_mask = ADFS_DEFAULT_OWNER_MASK;
asb->s_other_mask = S_IRWXG | S_IRWXO; asb->s_other_mask = ADFS_DEFAULT_OTHER_MASK;
if (parse_options(sb, data)) if (parse_options(sb, data))
goto error; goto error;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment