inode.c 43.8 KB
Newer Older
M
Miklos Szeredi 已提交
1 2
/*
  FUSE: Filesystem in Userspace
M
Miklos Szeredi 已提交
3
  Copyright (C) 2001-2008  Miklos Szeredi <miklos@szeredi.hu>
M
Miklos Szeredi 已提交
4 5 6 7 8 9 10 11 12 13 14 15 16

  This program can be distributed under the terms of the GNU GPL.
  See the file COPYING.
*/

#include "fuse_i.h"

#include <linux/pagemap.h>
#include <linux/slab.h>
#include <linux/file.h>
#include <linux/seq_file.h>
#include <linux/init.h>
#include <linux/module.h>
17
#include <linux/moduleparam.h>
18 19
#include <linux/fs_context.h>
#include <linux/fs_parser.h>
M
Miklos Szeredi 已提交
20
#include <linux/statfs.h>
21
#include <linux/random.h>
A
Alexey Dobriyan 已提交
22
#include <linux/sched.h>
M
Miklos Szeredi 已提交
23
#include <linux/exportfs.h>
S
Seth Forshee 已提交
24
#include <linux/posix_acl.h>
25
#include <linux/pid_namespace.h>
M
Miklos Szeredi 已提交
26 27 28 29 30

MODULE_AUTHOR("Miklos Szeredi <miklos@szeredi.hu>");
MODULE_DESCRIPTION("Filesystem in Userspace");
MODULE_LICENSE("GPL");

31
static struct kmem_cache *fuse_inode_cachep;
32 33
struct list_head fuse_conn_list;
DEFINE_MUTEX(fuse_mutex);
M
Miklos Szeredi 已提交
34

35
static int set_global_limit(const char *val, const struct kernel_param *kp);
36

37
unsigned max_user_bgreq;
38 39 40 41 42 43 44
module_param_call(max_user_bgreq, set_global_limit, param_get_uint,
		  &max_user_bgreq, 0644);
__MODULE_PARM_TYPE(max_user_bgreq, "uint");
MODULE_PARM_DESC(max_user_bgreq,
 "Global limit for the maximum number of backgrounded requests an "
 "unprivileged user can set");

45
unsigned max_user_congthresh;
46 47 48 49 50 51 52
module_param_call(max_user_congthresh, set_global_limit, param_get_uint,
		  &max_user_congthresh, 0644);
__MODULE_PARM_TYPE(max_user_congthresh, "uint");
MODULE_PARM_DESC(max_user_congthresh,
 "Global limit for the maximum congestion threshold an "
 "unprivileged user can set");

M
Miklos Szeredi 已提交
53 54
#define FUSE_SUPER_MAGIC 0x65735546

M
Miklos Szeredi 已提交
55 56
#define FUSE_DEFAULT_BLKSIZE 512

57 58 59 60 61 62
/** Maximum number of outstanding background requests */
#define FUSE_DEFAULT_MAX_BACKGROUND 12

/** Congestion starts at 75% of maximum */
#define FUSE_DEFAULT_CONGESTION_THRESHOLD (FUSE_DEFAULT_MAX_BACKGROUND * 3 / 4)

63 64 65 66
#ifdef CONFIG_BLOCK
static struct file_system_type fuseblk_fs_type;
#endif

67
struct fuse_forget_link *fuse_alloc_forget(void)
68
{
69
	return kzalloc(sizeof(struct fuse_forget_link), GFP_KERNEL_ACCOUNT);
70 71
}

M
Miklos Szeredi 已提交
72 73 74 75
static struct inode *fuse_alloc_inode(struct super_block *sb)
{
	struct fuse_inode *fi;

Z
zhangliguang 已提交
76 77
	fi = kmem_cache_alloc(fuse_inode_cachep, GFP_KERNEL);
	if (!fi)
M
Miklos Szeredi 已提交
78 79
		return NULL;

M
Miklos Szeredi 已提交
80
	fi->i_time = 0;
81
	fi->inval_mask = 0;
M
Miklos Szeredi 已提交
82
	fi->nodeid = 0;
83
	fi->nlookup = 0;
84
	fi->attr_version = 0;
85
	fi->orig_ino = 0;
86
	fi->state = 0;
87
	mutex_init(&fi->mutex);
88
	init_rwsem(&fi->i_mmap_sem);
89
	spin_lock_init(&fi->lock);
90
	fi->forget = fuse_alloc_forget();
91 92 93 94 95
	if (!fi->forget)
		goto out_free;

	if (IS_ENABLED(CONFIG_FUSE_DAX) && !fuse_dax_inode_alloc(sb, fi))
		goto out_free_forget;
M
Miklos Szeredi 已提交
96

Z
zhangliguang 已提交
97
	return &fi->inode;
98 99 100 101 102 103

out_free_forget:
	kfree(fi->forget);
out_free:
	kmem_cache_free(fuse_inode_cachep, fi);
	return NULL;
M
Miklos Szeredi 已提交
104 105
}

A
Al Viro 已提交
106
static void fuse_free_inode(struct inode *inode)
M
Miklos Szeredi 已提交
107
{
108
	struct fuse_inode *fi = get_fuse_inode(inode);
A
Al Viro 已提交
109

110
	mutex_destroy(&fi->mutex);
111
	kfree(fi->forget);
112 113 114
#ifdef CONFIG_FUSE_DAX
	kfree(fi->dax);
#endif
A
Al Viro 已提交
115
	kmem_cache_free(fuse_inode_cachep, fi);
M
Miklos Szeredi 已提交
116 117
}

118
static void fuse_evict_inode(struct inode *inode)
M
Miklos Szeredi 已提交
119
{
A
Al Viro 已提交
120 121
	struct fuse_inode *fi = get_fuse_inode(inode);

122
	truncate_inode_pages_final(&inode->i_data);
123
	clear_inode(inode);
124
	if (inode->i_sb->s_flags & SB_ACTIVE) {
M
Miklos Szeredi 已提交
125
		struct fuse_conn *fc = get_fuse_conn(inode);
126 127 128

		if (FUSE_IS_DAX(inode))
			fuse_dax_inode_cleanup(inode);
129 130 131 132 133
		if (fi->nlookup) {
			fuse_queue_forget(fc, fi->forget, fi->nodeid,
					  fi->nlookup);
			fi->forget = NULL;
		}
134
	}
M
Miklos Szeredi 已提交
135
	if (S_ISREG(inode->i_mode) && !fuse_is_bad(inode)) {
A
Al Viro 已提交
136 137 138
		WARN_ON(!list_empty(&fi->write_files));
		WARN_ON(!list_empty(&fi->queued_writes));
	}
M
Miklos Szeredi 已提交
139 140
}

141
static int fuse_reconfigure(struct fs_context *fsc)
142
{
143
	struct super_block *sb = fsc->root->d_sb;
144

145
	sync_filesystem(sb);
146
	if (fsc->sb_flags & SB_MANDLOCK)
147 148 149 150 151
		return -EINVAL;

	return 0;
}

152 153 154 155 156 157 158 159 160 161 162 163
/*
 * ino_t is 32-bits on 32-bit arch. We have to squash the 64-bit value down
 * so that it will fit.
 */
static ino_t fuse_squash_ino(u64 ino64)
{
	ino_t ino = (ino_t) ino64;
	if (sizeof(ino_t) < sizeof(u64))
		ino ^= ino64 >> (sizeof(u64) - sizeof(ino_t)) * 8;
	return ino;
}

M
Miklos Szeredi 已提交
164 165
void fuse_change_attributes_common(struct inode *inode, struct fuse_attr *attr,
				   u64 attr_valid)
M
Miklos Szeredi 已提交
166
{
M
Miklos Szeredi 已提交
167
	struct fuse_conn *fc = get_fuse_conn(inode);
168
	struct fuse_inode *fi = get_fuse_inode(inode);
M
Miklos Szeredi 已提交
169

170 171
	lockdep_assert_held(&fi->lock);

172
	fi->attr_version = atomic64_inc_return(&fc->attr_version);
173
	fi->i_time = attr_valid;
174
	WRITE_ONCE(fi->inval_mask, 0);
175

176
	inode->i_ino     = fuse_squash_ino(attr->ino);
177
	inode->i_mode    = (inode->i_mode & S_IFMT) | (attr->mode & 07777);
M
Miklos Szeredi 已提交
178
	set_nlink(inode, attr->nlink);
179 180
	inode->i_uid     = make_kuid(fc->user_ns, attr->uid);
	inode->i_gid     = make_kgid(fc->user_ns, attr->gid);
M
Miklos Szeredi 已提交
181 182 183
	inode->i_blocks  = attr->blocks;
	inode->i_atime.tv_sec   = attr->atime;
	inode->i_atime.tv_nsec  = attr->atimensec;
M
Maxim Patlasov 已提交
184 185 186 187
	/* mtime from server may be stale due to local buffered write */
	if (!fc->writeback_cache || !S_ISREG(inode->i_mode)) {
		inode->i_mtime.tv_sec   = attr->mtime;
		inode->i_mtime.tv_nsec  = attr->mtimensec;
M
Maxim Patlasov 已提交
188 189
		inode->i_ctime.tv_sec   = attr->ctime;
		inode->i_ctime.tv_nsec  = attr->ctimensec;
M
Maxim Patlasov 已提交
190
	}
191

192 193 194 195 196
	if (attr->blksize != 0)
		inode->i_blkbits = ilog2(attr->blksize);
	else
		inode->i_blkbits = inode->i_sb->s_blocksize_bits;

197 198 199 200 201 202
	/*
	 * Don't set the sticky bit in i_mode, unless we want the VFS
	 * to check permissions.  This prevents failures due to the
	 * check in may_delete().
	 */
	fi->orig_i_mode = inode->i_mode;
M
Miklos Szeredi 已提交
203
	if (!fc->default_permissions)
204
		inode->i_mode &= ~S_ISVTX;
205 206

	fi->orig_ino = attr->ino;
207 208 209 210 211 212 213 214 215 216

	/*
	 * We are refreshing inode data and it is possible that another
	 * client set suid/sgid or security.capability xattr. So clear
	 * S_NOSEC. Ideally, we could have cleared it only if suid/sgid
	 * was set or if security.capability xattr was set. But we don't
	 * know if security.capability has been set or not. So clear it
	 * anyway. Its less efficient but should be safe.
	 */
	inode->i_flags &= ~S_NOSEC;
M
Miklos Szeredi 已提交
217 218 219 220 221 222 223
}

void fuse_change_attributes(struct inode *inode, struct fuse_attr *attr,
			    u64 attr_valid, u64 attr_version)
{
	struct fuse_conn *fc = get_fuse_conn(inode);
	struct fuse_inode *fi = get_fuse_inode(inode);
P
Pavel Emelyanov 已提交
224
	bool is_wb = fc->writeback_cache;
M
Miklos Szeredi 已提交
225
	loff_t oldsize;
226
	struct timespec64 old_mtime;
M
Miklos Szeredi 已提交
227

228
	spin_lock(&fi->lock);
229 230
	if ((attr_version != 0 && fi->attr_version > attr_version) ||
	    test_bit(FUSE_I_SIZE_UNSTABLE, &fi->state)) {
231
		spin_unlock(&fi->lock);
M
Miklos Szeredi 已提交
232 233 234
		return;
	}

235
	old_mtime = inode->i_mtime;
M
Miklos Szeredi 已提交
236
	fuse_change_attributes_common(inode, attr, attr_valid);
237

238
	oldsize = inode->i_size;
P
Pavel Emelyanov 已提交
239 240 241 242 243 244 245
	/*
	 * In case of writeback_cache enabled, the cached writes beyond EOF
	 * extend local i_size without keeping userspace server in sync. So,
	 * attr->size coming from server can be stale. We cannot trust it.
	 */
	if (!is_wb || !S_ISREG(inode->i_mode))
		i_size_write(inode, attr->size);
246
	spin_unlock(&fi->lock);
247

P
Pavel Emelyanov 已提交
248
	if (!is_wb && S_ISREG(inode->i_mode)) {
249 250 251
		bool inval = false;

		if (oldsize != attr->size) {
252
			truncate_pagecache(inode, attr->size);
253 254
			if (!fc->explicit_inval_data)
				inval = true;
255
		} else if (fc->auto_inval_data) {
256
			struct timespec64 new_mtime = {
257 258 259 260 261 262 263 264
				.tv_sec = attr->mtime,
				.tv_nsec = attr->mtimensec,
			};

			/*
			 * Auto inval mode also checks and invalidates if mtime
			 * has changed.
			 */
265
			if (!timespec64_equal(&old_mtime, &new_mtime))
266 267 268 269 270
				inval = true;
		}

		if (inval)
			invalidate_inode_pages2(inode->i_mapping);
271
	}
M
Miklos Szeredi 已提交
272 273 274 275 276
}

static void fuse_init_inode(struct inode *inode, struct fuse_attr *attr)
{
	inode->i_mode = attr->mode & S_IFMT;
M
Miklos Szeredi 已提交
277
	inode->i_size = attr->size;
M
Maxim Patlasov 已提交
278 279
	inode->i_mtime.tv_sec  = attr->mtime;
	inode->i_mtime.tv_nsec = attr->mtimensec;
M
Maxim Patlasov 已提交
280 281
	inode->i_ctime.tv_sec  = attr->ctime;
	inode->i_ctime.tv_nsec = attr->ctimensec;
282 283
	if (S_ISREG(inode->i_mode)) {
		fuse_init_common(inode);
M
Miklos Szeredi 已提交
284
		fuse_init_file_inode(inode);
285 286 287 288 289 290 291 292 293
	} else if (S_ISDIR(inode->i_mode))
		fuse_init_dir(inode);
	else if (S_ISLNK(inode->i_mode))
		fuse_init_symlink(inode);
	else if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode) ||
		 S_ISFIFO(inode->i_mode) || S_ISSOCK(inode->i_mode)) {
		fuse_init_common(inode);
		init_special_inode(inode, inode->i_mode,
				   new_decode_dev(attr->rdev));
294 295
	} else
		BUG();
M
Miklos Szeredi 已提交
296 297
}

298
static int fuse_inode_eq(struct inode *inode, void *_nodeidp)
M
Miklos Szeredi 已提交
299
{
M
Miklos Szeredi 已提交
300
	u64 nodeid = *(u64 *) _nodeidp;
M
Miklos Szeredi 已提交
301 302 303 304 305 306 307 308
	if (get_node_id(inode) == nodeid)
		return 1;
	else
		return 0;
}

static int fuse_inode_set(struct inode *inode, void *_nodeidp)
{
M
Miklos Szeredi 已提交
309
	u64 nodeid = *(u64 *) _nodeidp;
M
Miklos Szeredi 已提交
310 311 312 313
	get_fuse_inode(inode)->nodeid = nodeid;
	return 0;
}

M
Miklos Szeredi 已提交
314
struct inode *fuse_iget(struct super_block *sb, u64 nodeid,
315 316
			int generation, struct fuse_attr *attr,
			u64 attr_valid, u64 attr_version)
M
Miklos Szeredi 已提交
317 318
{
	struct inode *inode;
319
	struct fuse_inode *fi;
M
Miklos Szeredi 已提交
320 321
	struct fuse_conn *fc = get_fuse_conn_super(sb);

M
Max Reitz 已提交
322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341
	/*
	 * Auto mount points get their node id from the submount root, which is
	 * not a unique identifier within this filesystem.
	 *
	 * To avoid conflicts, do not place submount points into the inode hash
	 * table.
	 */
	if (fc->auto_submounts && (attr->flags & FUSE_ATTR_SUBMOUNT) &&
	    S_ISDIR(attr->mode)) {
		inode = new_inode(sb);
		if (!inode)
			return NULL;

		fuse_init_inode(inode, attr);
		get_fuse_inode(inode)->nodeid = nodeid;
		inode->i_flags |= S_AUTOMOUNT;
		goto done;
	}

retry:
M
Miklos Szeredi 已提交
342 343 344 345 346
	inode = iget5_locked(sb, nodeid, fuse_inode_eq, fuse_inode_set, &nodeid);
	if (!inode)
		return NULL;

	if ((inode->i_state & I_NEW)) {
M
Maxim Patlasov 已提交
347
		inode->i_flags |= S_NOATIME;
348
		if (!fc->writeback_cache || !S_ISREG(attr->mode))
M
Maxim Patlasov 已提交
349
			inode->i_flags |= S_NOCMTIME;
M
Miklos Szeredi 已提交
350 351 352
		inode->i_generation = generation;
		fuse_init_inode(inode, attr);
		unlock_new_inode(inode);
353 354
	} else if (fuse_stale_inode(inode, generation, attr)) {
		/* nodeid was reused, any I/O on the old inode should fail */
M
Miklos Szeredi 已提交
355
		fuse_make_bad(inode);
M
Miklos Szeredi 已提交
356 357 358
		iput(inode);
		goto retry;
	}
M
Max Reitz 已提交
359
done:
360
	fi = get_fuse_inode(inode);
361
	spin_lock(&fi->lock);
M
Miklos Szeredi 已提交
362
	fi->nlookup++;
363
	spin_unlock(&fi->lock);
364 365
	fuse_change_attributes(inode, attr, attr_valid, attr_version);

M
Miklos Szeredi 已提交
366 367 368
	return inode;
}

369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391
struct inode *fuse_ilookup(struct fuse_conn *fc, u64 nodeid,
			   struct fuse_mount **fm)
{
	struct fuse_mount *fm_iter;
	struct inode *inode;

	WARN_ON(!rwsem_is_locked(&fc->killsb));
	list_for_each_entry(fm_iter, &fc->mounts, fc_entry) {
		if (!fm_iter->sb)
			continue;

		inode = ilookup5(fm_iter->sb, nodeid, fuse_inode_eq, &nodeid);
		if (inode) {
			if (fm)
				*fm = fm_iter;
			return inode;
		}
	}

	return NULL;
}

int fuse_reverse_inval_inode(struct fuse_conn *fc, u64 nodeid,
J
John Muir 已提交
392 393
			     loff_t offset, loff_t len)
{
394
	struct fuse_inode *fi;
J
John Muir 已提交
395 396 397 398
	struct inode *inode;
	pgoff_t pg_start;
	pgoff_t pg_end;

399
	inode = fuse_ilookup(fc, nodeid, NULL);
J
John Muir 已提交
400 401 402
	if (!inode)
		return -ENOENT;

403 404 405 406 407
	fi = get_fuse_inode(inode);
	spin_lock(&fi->lock);
	fi->attr_version = atomic64_inc_return(&fc->attr_version);
	spin_unlock(&fi->lock);

J
John Muir 已提交
408
	fuse_invalidate_attr(inode);
S
Seth Forshee 已提交
409
	forget_all_cached_acls(inode);
J
John Muir 已提交
410
	if (offset >= 0) {
411
		pg_start = offset >> PAGE_SHIFT;
J
John Muir 已提交
412 413 414
		if (len <= 0)
			pg_end = -1;
		else
415
			pg_end = (offset + len - 1) >> PAGE_SHIFT;
J
John Muir 已提交
416 417 418 419 420 421 422
		invalidate_inode_pages2_range(inode->i_mapping,
					      pg_start, pg_end);
	}
	iput(inode);
	return 0;
}

423
bool fuse_lock_inode(struct inode *inode)
424
{
425 426 427
	bool locked = false;

	if (!get_fuse_conn(inode)->parallel_dirops) {
428
		mutex_lock(&get_fuse_inode(inode)->mutex);
429 430 431 432
		locked = true;
	}

	return locked;
433 434
}

435
void fuse_unlock_inode(struct inode *inode, bool locked)
436
{
437
	if (locked)
438 439 440
		mutex_unlock(&get_fuse_inode(inode)->mutex);
}

441
static void fuse_umount_begin(struct super_block *sb)
442
{
443 444 445 446
	struct fuse_conn *fc = get_fuse_conn_super(sb);

	if (!fc->no_force_umount)
		fuse_abort_conn(fc);
447 448
}

449
static void fuse_send_destroy(struct fuse_mount *fm)
450
{
451
	if (fm->fc->conn_init) {
452 453 454 455 456
		FUSE_ARGS(args);

		args.opcode = FUSE_DESTROY;
		args.force = true;
		args.nocreds = true;
457
		fuse_simple_request(fm, &args);
458 459 460
	}
}

461 462
static void fuse_put_super(struct super_block *sb)
{
463
	struct fuse_mount *fm = get_fuse_mount_super(sb);
464

465 466
	fuse_conn_put(fm->fc);
	kfree(fm);
M
Miklos Szeredi 已提交
467 468
}

469 470 471 472
static void convert_fuse_statfs(struct kstatfs *stbuf, struct fuse_kstatfs *attr)
{
	stbuf->f_type    = FUSE_SUPER_MAGIC;
	stbuf->f_bsize   = attr->bsize;
473
	stbuf->f_frsize  = attr->frsize;
474 475 476 477 478 479 480 481 482
	stbuf->f_blocks  = attr->blocks;
	stbuf->f_bfree   = attr->bfree;
	stbuf->f_bavail  = attr->bavail;
	stbuf->f_files   = attr->files;
	stbuf->f_ffree   = attr->ffree;
	stbuf->f_namelen = attr->namelen;
	/* fsid is left zero */
}

483
static int fuse_statfs(struct dentry *dentry, struct kstatfs *buf)
484
{
485
	struct super_block *sb = dentry->d_sb;
486
	struct fuse_mount *fm = get_fuse_mount_super(sb);
487
	FUSE_ARGS(args);
488 489 490
	struct fuse_statfs_out outarg;
	int err;

491
	if (!fuse_allow_current_process(fm->fc)) {
M
Miklos Szeredi 已提交
492 493 494 495
		buf->f_type = FUSE_SUPER_MAGIC;
		return 0;
	}

496
	memset(&outarg, 0, sizeof(outarg));
497 498 499 500 501 502
	args.in_numargs = 0;
	args.opcode = FUSE_STATFS;
	args.nodeid = get_node_id(d_inode(dentry));
	args.out_numargs = 1;
	args.out_args[0].size = sizeof(outarg);
	args.out_args[0].value = &outarg;
503
	err = fuse_simple_request(fm, &args);
504 505 506 507 508
	if (!err)
		convert_fuse_statfs(buf, &outarg.st);
	return err;
}

509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547
static int fuse_sync_fs(struct super_block *sb, int wait)
{
	struct fuse_mount *fm = get_fuse_mount_super(sb);
	struct fuse_conn *fc = fm->fc;
	struct fuse_syncfs_in inarg;
	FUSE_ARGS(args);
	int err;

	/*
	 * Userspace cannot handle the wait == 0 case.  Avoid a
	 * gratuitous roundtrip.
	 */
	if (!wait)
		return 0;

	/* The filesystem is being unmounted.  Nothing to do. */
	if (!sb->s_root)
		return 0;

	if (!fc->sync_fs)
		return 0;

	memset(&inarg, 0, sizeof(inarg));
	args.in_numargs = 1;
	args.in_args[0].size = sizeof(inarg);
	args.in_args[0].value = &inarg;
	args.opcode = FUSE_SYNCFS;
	args.nodeid = get_node_id(sb->s_root->d_inode);
	args.out_numargs = 0;

	err = fuse_simple_request(fm, &args);
	if (err == -ENOSYS) {
		fc->sync_fs = 0;
		err = 0;
	}

	return err;
}

M
Miklos Szeredi 已提交
548
enum {
549 550
	OPT_SOURCE,
	OPT_SUBTYPE,
M
Miklos Szeredi 已提交
551 552 553
	OPT_FD,
	OPT_ROOTMODE,
	OPT_USER_ID,
554
	OPT_GROUP_ID,
M
Miklos Szeredi 已提交
555 556
	OPT_DEFAULT_PERMISSIONS,
	OPT_ALLOW_OTHER,
557
	OPT_MAX_READ,
M
Miklos Szeredi 已提交
558
	OPT_BLKSIZE,
M
Miklos Szeredi 已提交
559 560 561
	OPT_ERR
};

562
static const struct fs_parameter_spec fuse_fs_parameters[] = {
563 564 565 566 567 568 569 570 571
	fsparam_string	("source",		OPT_SOURCE),
	fsparam_u32	("fd",			OPT_FD),
	fsparam_u32oct	("rootmode",		OPT_ROOTMODE),
	fsparam_u32	("user_id",		OPT_USER_ID),
	fsparam_u32	("group_id",		OPT_GROUP_ID),
	fsparam_flag	("default_permissions",	OPT_DEFAULT_PERMISSIONS),
	fsparam_flag	("allow_other",		OPT_ALLOW_OTHER),
	fsparam_u32	("max_read",		OPT_MAX_READ),
	fsparam_u32	("blksize",		OPT_BLKSIZE),
572
	fsparam_string	("subtype",		OPT_SUBTYPE),
573 574 575
	{}
};

576
static int fuse_parse_param(struct fs_context *fsc, struct fs_parameter *param)
577
{
578
	struct fs_parse_result result;
579
	struct fuse_fs_context *ctx = fsc->fs_private;
580 581
	int opt;

582
	if (fsc->purpose == FS_CONTEXT_FOR_RECONFIGURE) {
583 584 585 586
		/*
		 * Ignore options coming from mount(MS_REMOUNT) for backward
		 * compatibility.
		 */
587
		if (fsc->oldapi)
588 589
			return 0;

590
		return invalfc(fsc, "No changes allowed in reconfigure");
591
	}
592

593
	opt = fs_parse(fsc, fuse_fs_parameters, param, &result);
594 595 596 597 598
	if (opt < 0)
		return opt;

	switch (opt) {
	case OPT_SOURCE:
599 600 601
		if (fsc->source)
			return invalfc(fsc, "Multiple sources specified");
		fsc->source = param->string;
602 603 604 605 606
		param->string = NULL;
		break;

	case OPT_SUBTYPE:
		if (ctx->subtype)
607
			return invalfc(fsc, "Multiple subtypes specified");
608 609 610 611 612 613
		ctx->subtype = param->string;
		param->string = NULL;
		return 0;

	case OPT_FD:
		ctx->fd = result.uint_32;
614
		ctx->fd_present = true;
615 616 617 618
		break;

	case OPT_ROOTMODE:
		if (!fuse_valid_type(result.uint_32))
619
			return invalfc(fsc, "Invalid rootmode");
620
		ctx->rootmode = result.uint_32;
621
		ctx->rootmode_present = true;
622 623 624
		break;

	case OPT_USER_ID:
625
		ctx->user_id = make_kuid(fsc->user_ns, result.uint_32);
626
		if (!uid_valid(ctx->user_id))
627
			return invalfc(fsc, "Invalid user_id");
628
		ctx->user_id_present = true;
629 630 631
		break;

	case OPT_GROUP_ID:
632
		ctx->group_id = make_kgid(fsc->user_ns, result.uint_32);
633
		if (!gid_valid(ctx->group_id))
634
			return invalfc(fsc, "Invalid group_id");
635
		ctx->group_id_present = true;
636 637 638
		break;

	case OPT_DEFAULT_PERMISSIONS:
639
		ctx->default_permissions = true;
640 641 642
		break;

	case OPT_ALLOW_OTHER:
643
		ctx->allow_other = true;
644 645 646 647 648 649 650 651
		break;

	case OPT_MAX_READ:
		ctx->max_read = result.uint_32;
		break;

	case OPT_BLKSIZE:
		if (!ctx->is_bdev)
652
			return invalfc(fsc, "blksize only supported for fuseblk");
653 654 655 656 657
		ctx->blksize = result.uint_32;
		break;

	default:
		return -EINVAL;
658
	}
659 660

	return 0;
661 662
}

663
static void fuse_free_fsc(struct fs_context *fsc)
M
Miklos Szeredi 已提交
664
{
665
	struct fuse_fs_context *ctx = fsc->fs_private;
666

667 668 669 670
	if (ctx) {
		kfree(ctx->subtype);
		kfree(ctx);
	}
M
Miklos Szeredi 已提交
671 672
}

673
static int fuse_show_options(struct seq_file *m, struct dentry *root)
M
Miklos Szeredi 已提交
674
{
675 676
	struct super_block *sb = root->d_sb;
	struct fuse_conn *fc = get_fuse_conn_super(sb);
M
Miklos Szeredi 已提交
677

678 679 680 681 682 683 684 685 686 687 688 689 690 691
	if (fc->legacy_opts_show) {
		seq_printf(m, ",user_id=%u",
			   from_kuid_munged(fc->user_ns, fc->user_id));
		seq_printf(m, ",group_id=%u",
			   from_kgid_munged(fc->user_ns, fc->group_id));
		if (fc->default_permissions)
			seq_puts(m, ",default_permissions");
		if (fc->allow_other)
			seq_puts(m, ",allow_other");
		if (fc->max_read != ~0)
			seq_printf(m, ",max_read=%u", fc->max_read);
		if (sb->s_bdev && sb->s_blocksize != FUSE_DEFAULT_BLKSIZE)
			seq_printf(m, ",blksize=%lu", sb->s_blocksize);
	}
692 693 694 695
#ifdef CONFIG_FUSE_DAX
	if (fc->dax)
		seq_puts(m, ",dax");
#endif
696

M
Miklos Szeredi 已提交
697 698 699
	return 0;
}

700 701 702
static void fuse_iqueue_init(struct fuse_iqueue *fiq,
			     const struct fuse_iqueue_ops *ops,
			     void *priv)
M
Miklos Szeredi 已提交
703 704
{
	memset(fiq, 0, sizeof(struct fuse_iqueue));
705
	spin_lock_init(&fiq->lock);
M
Miklos Szeredi 已提交
706 707 708 709
	init_waitqueue_head(&fiq->waitq);
	INIT_LIST_HEAD(&fiq->pending);
	INIT_LIST_HEAD(&fiq->interrupts);
	fiq->forget_list_tail = &fiq->forget_list_head;
710
	fiq->connected = 1;
711 712
	fiq->ops = ops;
	fiq->priv = priv;
M
Miklos Szeredi 已提交
713 714
}

715 716
static void fuse_pqueue_init(struct fuse_pqueue *fpq)
{
717 718
	unsigned int i;

M
Miklos Szeredi 已提交
719
	spin_lock_init(&fpq->lock);
720 721
	for (i = 0; i < FUSE_PQ_HASH_SIZE; i++)
		INIT_LIST_HEAD(&fpq->processing[i]);
722
	INIT_LIST_HEAD(&fpq->io);
723
	fpq->connected = 1;
724 725
}

726 727
void fuse_conn_init(struct fuse_conn *fc, struct fuse_mount *fm,
		    struct user_namespace *user_ns,
728
		    const struct fuse_iqueue_ops *fiq_ops, void *fiq_priv)
M
Miklos Szeredi 已提交
729
{
730 731
	memset(fc, 0, sizeof(*fc));
	spin_lock_init(&fc->lock);
K
Kirill Tkhai 已提交
732
	spin_lock_init(&fc->bg_lock);
J
John Muir 已提交
733
	init_rwsem(&fc->killsb);
734
	refcount_set(&fc->count, 1);
735
	atomic_set(&fc->dev_count, 1);
736
	init_waitqueue_head(&fc->blocked_waitq);
737
	fuse_iqueue_init(&fc->iq, fiq_ops, fiq_priv);
738 739
	INIT_LIST_HEAD(&fc->bg_queue);
	INIT_LIST_HEAD(&fc->entry);
740
	INIT_LIST_HEAD(&fc->devices);
741
	atomic_set(&fc->num_waiting, 0);
742 743
	fc->max_background = FUSE_DEFAULT_MAX_BACKGROUND;
	fc->congestion_threshold = FUSE_DEFAULT_CONGESTION_THRESHOLD;
M
Miklos Szeredi 已提交
744
	atomic64_set(&fc->khctr, 0);
745
	fc->polled_files = RB_ROOT;
746
	fc->blocked = 0;
M
Maxim Patlasov 已提交
747
	fc->initialized = 0;
748
	fc->connected = 1;
749
	atomic64_set(&fc->attr_version, 1);
750
	get_random_bytes(&fc->scramble_key, sizeof(fc->scramble_key));
751
	fc->pid_ns = get_pid_ns(task_active_pid_ns(current));
752
	fc->user_ns = get_user_ns(user_ns);
M
Miklos Szeredi 已提交
753
	fc->max_pages = FUSE_DEFAULT_MAX_PAGES_PER_REQ;
754
	fc->max_pages_limit = FUSE_MAX_MAX_PAGES;
755 756 757 758

	INIT_LIST_HEAD(&fc->mounts);
	list_add(&fm->fc_entry, &fc->mounts);
	fm->fc = fc;
M
Miklos Szeredi 已提交
759
}
760
EXPORT_SYMBOL_GPL(fuse_conn_init);
M
Miklos Szeredi 已提交
761

762 763
void fuse_conn_put(struct fuse_conn *fc)
{
764
	if (refcount_dec_and_test(&fc->count)) {
765 766
		struct fuse_iqueue *fiq = &fc->iq;

767 768
		if (IS_ENABLED(CONFIG_FUSE_DAX))
			fuse_dax_conn_free(fc);
769 770
		if (fiq->ops->release)
			fiq->ops->release(fiq);
771
		put_pid_ns(fc->pid_ns);
772
		put_user_ns(fc->user_ns);
T
Tejun Heo 已提交
773
		fc->release(fc);
774
	}
775
}
776
EXPORT_SYMBOL_GPL(fuse_conn_put);
777 778 779

struct fuse_conn *fuse_conn_get(struct fuse_conn *fc)
{
780
	refcount_inc(&fc->count);
781 782
	return fc;
}
783
EXPORT_SYMBOL_GPL(fuse_conn_get);
784

785
static struct inode *fuse_get_root_inode(struct super_block *sb, unsigned mode)
M
Miklos Szeredi 已提交
786 787 788 789 790 791
{
	struct fuse_attr attr;
	memset(&attr, 0, sizeof(attr));

	attr.mode = mode;
	attr.ino = FUSE_ROOT_ID;
792
	attr.nlink = 1;
793
	return fuse_iget(sb, 1, 0, &attr, 0, 0);
M
Miklos Szeredi 已提交
794 795
}

M
Miklos Szeredi 已提交
796
struct fuse_inode_handle {
M
Miklos Szeredi 已提交
797 798 799 800 801 802 803
	u64 nodeid;
	u32 generation;
};

static struct dentry *fuse_get_dentry(struct super_block *sb,
				      struct fuse_inode_handle *handle)
{
804
	struct fuse_conn *fc = get_fuse_conn_super(sb);
M
Miklos Szeredi 已提交
805 806 807 808 809 810 811 812
	struct inode *inode;
	struct dentry *entry;
	int err = -ESTALE;

	if (handle->nodeid == 0)
		goto out_err;

	inode = ilookup5(sb, handle->nodeid, fuse_inode_eq, &handle->nodeid);
813 814
	if (!inode) {
		struct fuse_entry_out outarg;
A
Al Viro 已提交
815
		const struct qstr name = QSTR_INIT(".", 1);
816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831

		if (!fc->export_support)
			goto out_err;

		err = fuse_lookup_name(sb, handle->nodeid, &name, &outarg,
				       &inode);
		if (err && err != -ENOENT)
			goto out_err;
		if (err || !inode) {
			err = -ESTALE;
			goto out_err;
		}
		err = -EIO;
		if (get_node_id(inode) != handle->nodeid)
			goto out_iput;
	}
M
Miklos Szeredi 已提交
832 833 834 835
	err = -ESTALE;
	if (inode->i_generation != handle->generation)
		goto out_iput;

836
	entry = d_obtain_alias(inode);
A
Al Viro 已提交
837
	if (!IS_ERR(entry) && get_node_id(inode) != FUSE_ROOT_ID)
M
Miklos Szeredi 已提交
838 839 840 841 842 843 844 845 846 847
		fuse_invalidate_entry_cache(entry);

	return entry;

 out_iput:
	iput(inode);
 out_err:
	return ERR_PTR(err);
}

A
Al Viro 已提交
848 849
static int fuse_encode_fh(struct inode *inode, u32 *fh, int *max_len,
			   struct inode *parent)
M
Miklos Szeredi 已提交
850
{
A
Al Viro 已提交
851
	int len = parent ? 6 : 3;
M
Miklos Szeredi 已提交
852 853 854
	u64 nodeid;
	u32 generation;

855 856
	if (*max_len < len) {
		*max_len = len;
857
		return  FILEID_INVALID;
858
	}
M
Miklos Szeredi 已提交
859 860 861 862 863 864 865 866

	nodeid = get_fuse_inode(inode)->nodeid;
	generation = inode->i_generation;

	fh[0] = (u32)(nodeid >> 32);
	fh[1] = (u32)(nodeid & 0xffffffff);
	fh[2] = generation;

A
Al Viro 已提交
867
	if (parent) {
M
Miklos Szeredi 已提交
868 869 870 871 872 873 874 875 876
		nodeid = get_fuse_inode(parent)->nodeid;
		generation = parent->i_generation;

		fh[3] = (u32)(nodeid >> 32);
		fh[4] = (u32)(nodeid & 0xffffffff);
		fh[5] = generation;
	}

	*max_len = len;
A
Al Viro 已提交
877
	return parent ? 0x82 : 0x81;
M
Miklos Szeredi 已提交
878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907
}

static struct dentry *fuse_fh_to_dentry(struct super_block *sb,
		struct fid *fid, int fh_len, int fh_type)
{
	struct fuse_inode_handle handle;

	if ((fh_type != 0x81 && fh_type != 0x82) || fh_len < 3)
		return NULL;

	handle.nodeid = (u64) fid->raw[0] << 32;
	handle.nodeid |= (u64) fid->raw[1];
	handle.generation = fid->raw[2];
	return fuse_get_dentry(sb, &handle);
}

static struct dentry *fuse_fh_to_parent(struct super_block *sb,
		struct fid *fid, int fh_len, int fh_type)
{
	struct fuse_inode_handle parent;

	if (fh_type != 0x82 || fh_len < 6)
		return NULL;

	parent.nodeid = (u64) fid->raw[3] << 32;
	parent.nodeid |= (u64) fid->raw[4];
	parent.generation = fid->raw[5];
	return fuse_get_dentry(sb, &parent);
}

908 909
static struct dentry *fuse_get_parent(struct dentry *child)
{
910
	struct inode *child_inode = d_inode(child);
911 912 913 914 915 916 917 918 919 920
	struct fuse_conn *fc = get_fuse_conn(child_inode);
	struct inode *inode;
	struct dentry *parent;
	struct fuse_entry_out outarg;
	int err;

	if (!fc->export_support)
		return ERR_PTR(-ESTALE);

	err = fuse_lookup_name(child_inode->i_sb, get_node_id(child_inode),
A
Al Viro 已提交
921
			       &dotdot_name, &outarg, &inode);
922 923 924
	if (err) {
		if (err == -ENOENT)
			return ERR_PTR(-ESTALE);
925 926
		return ERR_PTR(err);
	}
927 928

	parent = d_obtain_alias(inode);
A
Al Viro 已提交
929
	if (!IS_ERR(parent) && get_node_id(inode) != FUSE_ROOT_ID)
930 931 932 933
		fuse_invalidate_entry_cache(parent);

	return parent;
}
M
Miklos Szeredi 已提交
934 935 936 937 938

static const struct export_operations fuse_export_operations = {
	.fh_to_dentry	= fuse_fh_to_dentry,
	.fh_to_parent	= fuse_fh_to_parent,
	.encode_fh	= fuse_encode_fh,
939
	.get_parent	= fuse_get_parent,
M
Miklos Szeredi 已提交
940 941
};

942
static const struct super_operations fuse_super_operations = {
M
Miklos Szeredi 已提交
943
	.alloc_inode    = fuse_alloc_inode,
A
Al Viro 已提交
944
	.free_inode     = fuse_free_inode,
945
	.evict_inode	= fuse_evict_inode,
M
Miklos Szeredi 已提交
946
	.write_inode	= fuse_write_inode,
M
Miklos Szeredi 已提交
947
	.drop_inode	= generic_delete_inode,
M
Miklos Szeredi 已提交
948
	.put_super	= fuse_put_super,
949
	.umount_begin	= fuse_umount_begin,
950
	.statfs		= fuse_statfs,
951
	.sync_fs	= fuse_sync_fs,
M
Miklos Szeredi 已提交
952 953 954
	.show_options	= fuse_show_options,
};

955 956
static void sanitize_global_limit(unsigned *limit)
{
M
Miklos Szeredi 已提交
957 958 959 960
	/*
	 * The default maximum number of async requests is calculated to consume
	 * 1/2^13 of the total memory, assuming 392 bytes per request.
	 */
961
	if (*limit == 0)
M
Miklos Szeredi 已提交
962
		*limit = ((totalram_pages() << PAGE_SHIFT) >> 13) / 392;
963 964 965 966 967

	if (*limit >= 1 << 16)
		*limit = (1 << 16) - 1;
}

968
static int set_global_limit(const char *val, const struct kernel_param *kp)
969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990
{
	int rv;

	rv = param_set_uint(val, kp);
	if (rv)
		return rv;

	sanitize_global_limit((unsigned *)kp->arg);

	return 0;
}

static void process_init_limits(struct fuse_conn *fc, struct fuse_init_out *arg)
{
	int cap_sys_admin = capable(CAP_SYS_ADMIN);

	if (arg->minor < 13)
		return;

	sanitize_global_limit(&max_user_bgreq);
	sanitize_global_limit(&max_user_congthresh);

K
Kirill Tkhai 已提交
991
	spin_lock(&fc->bg_lock);
992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004
	if (arg->max_background) {
		fc->max_background = arg->max_background;

		if (!cap_sys_admin && fc->max_background > max_user_bgreq)
			fc->max_background = max_user_bgreq;
	}
	if (arg->congestion_threshold) {
		fc->congestion_threshold = arg->congestion_threshold;

		if (!cap_sys_admin &&
		    fc->congestion_threshold > max_user_congthresh)
			fc->congestion_threshold = max_user_congthresh;
	}
K
Kirill Tkhai 已提交
1005
	spin_unlock(&fc->bg_lock);
1006 1007
}

1008 1009 1010 1011 1012 1013
struct fuse_init_args {
	struct fuse_args args;
	struct fuse_init_in in;
	struct fuse_init_out out;
};

1014
static void process_init_reply(struct fuse_mount *fm, struct fuse_args *args,
1015
			       int error)
1016
{
1017
	struct fuse_conn *fc = fm->fc;
1018 1019
	struct fuse_init_args *ia = container_of(args, typeof(*ia), args);
	struct fuse_init_out *arg = &ia->out;
1020
	bool ok = true;
1021

1022
	if (error || arg->major != FUSE_KERNEL_VERSION)
1023
		ok = false;
1024
	else {
1025 1026
		unsigned long ra_pages;

1027 1028
		process_init_limits(fc, arg);

1029
		if (arg->minor >= 6) {
1030
			ra_pages = arg->max_readahead / PAGE_SIZE;
1031 1032
			if (arg->flags & FUSE_ASYNC_READ)
				fc->async_read = 1;
1033 1034
			if (!(arg->flags & FUSE_POSIX_LOCKS))
				fc->no_lock = 1;
M
Miklos Szeredi 已提交
1035 1036 1037
			if (arg->minor >= 17) {
				if (!(arg->flags & FUSE_FLOCK_LOCKS))
					fc->no_flock = 1;
M
Miklos Szeredi 已提交
1038 1039 1040
			} else {
				if (!(arg->flags & FUSE_POSIX_LOCKS))
					fc->no_flock = 1;
M
Miklos Szeredi 已提交
1041
			}
1042 1043
			if (arg->flags & FUSE_ATOMIC_O_TRUNC)
				fc->atomic_o_trunc = 1;
1044 1045 1046 1047 1048
			if (arg->minor >= 9) {
				/* LOOKUP has dependency on proto version */
				if (arg->flags & FUSE_EXPORT_SUPPORT)
					fc->export_support = 1;
			}
1049 1050
			if (arg->flags & FUSE_BIG_WRITES)
				fc->big_writes = 1;
1051 1052
			if (arg->flags & FUSE_DONT_MASK)
				fc->dont_mask = 1;
1053 1054
			if (arg->flags & FUSE_AUTO_INVAL_DATA)
				fc->auto_inval_data = 1;
1055 1056
			else if (arg->flags & FUSE_EXPLICIT_INVAL_DATA)
				fc->explicit_inval_data = 1;
1057
			if (arg->flags & FUSE_DO_READDIRPLUS) {
1058
				fc->do_readdirplus = 1;
1059 1060 1061
				if (arg->flags & FUSE_READDIRPLUS_AUTO)
					fc->readdirplus_auto = 1;
			}
1062 1063
			if (arg->flags & FUSE_ASYNC_DIO)
				fc->async_dio = 1;
P
Pavel Emelyanov 已提交
1064 1065
			if (arg->flags & FUSE_WRITEBACK_CACHE)
				fc->writeback_cache = 1;
1066 1067
			if (arg->flags & FUSE_PARALLEL_DIROPS)
				fc->parallel_dirops = 1;
1068 1069
			if (arg->flags & FUSE_HANDLE_KILLPRIV)
				fc->handle_killpriv = 1;
1070
			if (arg->time_gran && arg->time_gran <= 1000000000)
1071
				fm->sb->s_time_gran = arg->time_gran;
S
Seth Forshee 已提交
1072
			if ((arg->flags & FUSE_POSIX_ACL)) {
M
Miklos Szeredi 已提交
1073
				fc->default_permissions = 1;
S
Seth Forshee 已提交
1074
				fc->posix_acl = 1;
1075
				fm->sb->s_xattr = fuse_acl_xattr_handlers;
S
Seth Forshee 已提交
1076
			}
D
Dan Schatzberg 已提交
1077 1078
			if (arg->flags & FUSE_CACHE_SYMLINKS)
				fc->cache_symlinks = 1;
1079 1080
			if (arg->flags & FUSE_ABORT_ERROR)
				fc->abort_err = 1;
1081 1082
			if (arg->flags & FUSE_MAX_PAGES) {
				fc->max_pages =
1083
					min_t(unsigned int, fc->max_pages_limit,
1084 1085
					max_t(unsigned int, arg->max_pages, 1));
			}
1086 1087 1088 1089 1090
			if (IS_ENABLED(CONFIG_FUSE_DAX) &&
			    arg->flags & FUSE_MAP_ALIGNMENT &&
			    !fuse_dax_check_alignment(fc, arg->map_alignment)) {
				ok = false;
			}
1091
			if (arg->flags & FUSE_HANDLE_KILLPRIV_V2) {
1092
				fc->handle_killpriv_v2 = 1;
1093 1094
				fm->sb->s_flags |= SB_NOSEC;
			}
V
Vivek Goyal 已提交
1095 1096
			if (arg->flags & FUSE_SETXATTR_EXT)
				fc->setxattr_ext = 1;
1097
		} else {
1098
			ra_pages = fc->max_read / PAGE_SIZE;
1099
			fc->no_lock = 1;
M
Miklos Szeredi 已提交
1100
			fc->no_flock = 1;
1101
		}
1102

1103 1104
		fm->sb->s_bdi->ra_pages =
				min(fm->sb->s_bdi->ra_pages, ra_pages);
1105 1106
		fc->minor = arg->minor;
		fc->max_write = arg->minor < 5 ? 4096 : arg->max_write;
1107
		fc->max_write = max_t(unsigned, 4096, fc->max_write);
1108
		fc->conn_init = 1;
1109
	}
1110 1111
	kfree(ia);

1112 1113 1114 1115 1116
	if (!ok) {
		fc->conn_init = 0;
		fc->conn_error = 1;
	}

1117
	fuse_set_initialized(fc);
1118
	wake_up_all(&fc->blocked_waitq);
1119 1120
}

1121
void fuse_send_init(struct fuse_mount *fm)
1122
{
1123
	struct fuse_init_args *ia;
M
Miklos Szeredi 已提交
1124

1125 1126 1127 1128
	ia = kzalloc(sizeof(*ia), GFP_KERNEL | __GFP_NOFAIL);

	ia->in.major = FUSE_KERNEL_VERSION;
	ia->in.minor = FUSE_KERNEL_MINOR_VERSION;
1129
	ia->in.max_readahead = fm->sb->s_bdi->ra_pages * PAGE_SIZE;
1130 1131
	ia->in.flags |=
		FUSE_ASYNC_READ | FUSE_POSIX_LOCKS | FUSE_ATOMIC_O_TRUNC |
M
Miklos Szeredi 已提交
1132
		FUSE_EXPORT_SUPPORT | FUSE_BIG_WRITES | FUSE_DONT_MASK |
M
Miklos Szeredi 已提交
1133
		FUSE_SPLICE_WRITE | FUSE_SPLICE_MOVE | FUSE_SPLICE_READ |
1134
		FUSE_FLOCK_LOCKS | FUSE_HAS_IOCTL_DIR | FUSE_AUTO_INVAL_DATA |
P
Pavel Emelyanov 已提交
1135
		FUSE_DO_READDIRPLUS | FUSE_READDIRPLUS_AUTO | FUSE_ASYNC_DIO |
1136
		FUSE_WRITEBACK_CACHE | FUSE_NO_OPEN_SUPPORT |
1137
		FUSE_PARALLEL_DIROPS | FUSE_HANDLE_KILLPRIV | FUSE_POSIX_ACL |
1138
		FUSE_ABORT_ERROR | FUSE_MAX_PAGES | FUSE_CACHE_SYMLINKS |
1139
		FUSE_NO_OPENDIR_SUPPORT | FUSE_EXPLICIT_INVAL_DATA |
V
Vivek Goyal 已提交
1140
		FUSE_HANDLE_KILLPRIV_V2 | FUSE_SETXATTR_EXT;
1141
#ifdef CONFIG_FUSE_DAX
1142
	if (fm->fc->dax)
1143 1144
		ia->in.flags |= FUSE_MAP_ALIGNMENT;
#endif
M
Max Reitz 已提交
1145 1146 1147
	if (fm->fc->auto_submounts)
		ia->in.flags |= FUSE_SUBMOUNTS;

1148 1149 1150 1151 1152
	ia->args.opcode = FUSE_INIT;
	ia->args.in_numargs = 1;
	ia->args.in_args[0].size = sizeof(ia->in);
	ia->args.in_args[0].value = &ia->in;
	ia->args.out_numargs = 1;
D
Daniel Mack 已提交
1153
	/* Variable length argument used for backward compatibility
1154 1155
	   with interface version < 7.5.  Rest of init_out is zeroed
	   by do_get_request(), so a short reply is not a problem */
1156
	ia->args.out_argvar = true;
1157 1158 1159 1160 1161 1162
	ia->args.out_args[0].size = sizeof(ia->out);
	ia->args.out_args[0].value = &ia->out;
	ia->args.force = true;
	ia->args.nocreds = true;
	ia->args.end = process_init_reply;

1163 1164
	if (fuse_simple_background(fm, &ia->args, GFP_KERNEL) != 0)
		process_init_reply(fm, &ia->args, -ENOTCONN);
1165
}
1166
EXPORT_SYMBOL_GPL(fuse_send_init);
1167

1168
void fuse_free_conn(struct fuse_conn *fc)
T
Tejun Heo 已提交
1169
{
1170
	WARN_ON(!list_empty(&fc->devices));
A
Al Viro 已提交
1171
	kfree_rcu(fc, rcu);
T
Tejun Heo 已提交
1172
}
1173
EXPORT_SYMBOL_GPL(fuse_free_conn);
T
Tejun Heo 已提交
1174

1175 1176 1177
static int fuse_bdi_init(struct fuse_conn *fc, struct super_block *sb)
{
	int err;
1178
	char *suffix = "";
1179

1180
	if (sb->s_bdev) {
1181
		suffix = "-fuseblk";
1182 1183 1184 1185 1186 1187 1188
		/*
		 * sb->s_bdi points to blkdev's bdi however we want to redirect
		 * it to our private bdi...
		 */
		bdi_put(sb->s_bdi);
		sb->s_bdi = &noop_backing_dev_info;
	}
1189 1190
	err = super_setup_bdi_name(sb, "%u:%u%s", MAJOR(fc->dev),
				   MINOR(fc->dev), suffix);
1191 1192 1193
	if (err)
		return err;

1194
	/* fuse does it's own writeback accounting */
1195 1196
	sb->s_bdi->capabilities &= ~BDI_CAP_WRITEBACK_ACCT;
	sb->s_bdi->capabilities |= BDI_CAP_STRICTLIMIT;
1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209

	/*
	 * For a single fuse filesystem use max 1% of dirty +
	 * writeback threshold.
	 *
	 * This gives about 1M of write buffer for memory maps on a
	 * machine with 1G and 10% dirty_ratio, which should be more
	 * than enough.
	 *
	 * Privileged users can raise it by writing to
	 *
	 *    /sys/class/bdi/<bdi>/max_ratio
	 */
1210
	bdi_set_max_ratio(sb->s_bdi, 1);
1211 1212 1213 1214

	return 0;
}

1215
struct fuse_dev *fuse_dev_alloc(void)
1216 1217
{
	struct fuse_dev *fud;
1218
	struct list_head *pq;
1219 1220

	fud = kzalloc(sizeof(struct fuse_dev), GFP_KERNEL);
1221 1222
	if (!fud)
		return NULL;
1223

1224 1225 1226 1227
	pq = kcalloc(FUSE_PQ_HASH_SIZE, sizeof(struct list_head), GFP_KERNEL);
	if (!pq) {
		kfree(fud);
		return NULL;
1228 1229
	}

1230 1231 1232
	fud->pq.processing = pq;
	fuse_pqueue_init(&fud->pq);

1233 1234 1235 1236 1237 1238 1239
	return fud;
}
EXPORT_SYMBOL_GPL(fuse_dev_alloc);

void fuse_dev_install(struct fuse_dev *fud, struct fuse_conn *fc)
{
	fud->fc = fuse_conn_get(fc);
1240 1241 1242
	spin_lock(&fc->lock);
	list_add_tail(&fud->entry, &fc->devices);
	spin_unlock(&fc->lock);
1243 1244
}
EXPORT_SYMBOL_GPL(fuse_dev_install);
1245

1246 1247 1248 1249 1250 1251 1252 1253 1254
struct fuse_dev *fuse_dev_alloc_install(struct fuse_conn *fc)
{
	struct fuse_dev *fud;

	fud = fuse_dev_alloc();
	if (!fud)
		return NULL;

	fuse_dev_install(fud, fc);
1255 1256
	return fud;
}
1257
EXPORT_SYMBOL_GPL(fuse_dev_alloc_install);
1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269

void fuse_dev_free(struct fuse_dev *fud)
{
	struct fuse_conn *fc = fud->fc;

	if (fc) {
		spin_lock(&fc->lock);
		list_del(&fud->entry);
		spin_unlock(&fc->lock);

		fuse_conn_put(fc);
	}
1270
	kfree(fud->pq.processing);
1271 1272 1273 1274
	kfree(fud);
}
EXPORT_SYMBOL_GPL(fuse_dev_free);

1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317
static void fuse_fill_attr_from_inode(struct fuse_attr *attr,
				      const struct fuse_inode *fi)
{
	*attr = (struct fuse_attr){
		.ino		= fi->inode.i_ino,
		.size		= fi->inode.i_size,
		.blocks		= fi->inode.i_blocks,
		.atime		= fi->inode.i_atime.tv_sec,
		.mtime		= fi->inode.i_mtime.tv_sec,
		.ctime		= fi->inode.i_ctime.tv_sec,
		.atimensec	= fi->inode.i_atime.tv_nsec,
		.mtimensec	= fi->inode.i_mtime.tv_nsec,
		.ctimensec	= fi->inode.i_ctime.tv_nsec,
		.mode		= fi->inode.i_mode,
		.nlink		= fi->inode.i_nlink,
		.uid		= fi->inode.i_uid.val,
		.gid		= fi->inode.i_gid.val,
		.rdev		= fi->inode.i_rdev,
		.blksize	= 1u << fi->inode.i_blkbits,
	};
}

static void fuse_sb_defaults(struct super_block *sb)
{
	sb->s_magic = FUSE_SUPER_MAGIC;
	sb->s_op = &fuse_super_operations;
	sb->s_xattr = fuse_xattr_handlers;
	sb->s_maxbytes = MAX_LFS_FILESIZE;
	sb->s_time_gran = 1;
	sb->s_export_op = &fuse_export_operations;
	sb->s_iflags |= SB_I_IMA_UNVERIFIABLE_SIGNATURE;
	if (sb->s_user_ns != &init_user_ns)
		sb->s_iflags |= SB_I_UNTRUSTED_MOUNTER;
	sb->s_flags &= ~(SB_NOSEC | SB_I_VERSION);

	/*
	 * If we are not in the initial user namespace posix
	 * acls must be translated.
	 */
	if (sb->s_user_ns != &init_user_ns)
		sb->s_xattr = fuse_no_acl_xattr_handlers;
}

1318 1319
static int fuse_fill_super_submount(struct super_block *sb,
				    struct fuse_inode *parent_fi)
1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355
{
	struct fuse_mount *fm = get_fuse_mount_super(sb);
	struct super_block *parent_sb = parent_fi->inode.i_sb;
	struct fuse_attr root_attr;
	struct inode *root;

	fuse_sb_defaults(sb);
	fm->sb = sb;

	WARN_ON(sb->s_bdi != &noop_backing_dev_info);
	sb->s_bdi = bdi_get(parent_sb->s_bdi);

	sb->s_xattr = parent_sb->s_xattr;
	sb->s_time_gran = parent_sb->s_time_gran;
	sb->s_blocksize = parent_sb->s_blocksize;
	sb->s_blocksize_bits = parent_sb->s_blocksize_bits;
	sb->s_subtype = kstrdup(parent_sb->s_subtype, GFP_KERNEL);
	if (parent_sb->s_subtype && !sb->s_subtype)
		return -ENOMEM;

	fuse_fill_attr_from_inode(&root_attr, parent_fi);
	root = fuse_iget(sb, parent_fi->nodeid, 0, &root_attr, 0, 0);
	/*
	 * This inode is just a duplicate, so it is not looked up and
	 * its nlookup should not be incremented.  fuse_iget() does
	 * that, though, so undo it here.
	 */
	get_fuse_inode(root)->nlookup--;
	sb->s_d_op = &fuse_dentry_operations;
	sb->s_root = d_make_root(root);
	if (!sb->s_root)
		return -ENOMEM;

	return 0;
}

1356
/* Filesystem context private data holds the FUSE inode of the mount point */
1357 1358
static int fuse_get_tree_submount(struct fs_context *fsc)
{
1359 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393
	struct fuse_mount *fm;
	struct fuse_inode *mp_fi = fsc->fs_private;
	struct fuse_conn *fc = get_fuse_conn(&mp_fi->inode);
	struct super_block *sb;
	int err;

	fm = kzalloc(sizeof(struct fuse_mount), GFP_KERNEL);
	if (!fm)
		return -ENOMEM;

	fsc->s_fs_info = fm;
	sb = sget_fc(fsc, NULL, set_anon_super_fc);
	if (IS_ERR(sb)) {
		kfree(fm);
		return PTR_ERR(sb);
	}
	fm->fc = fuse_conn_get(fc);

	/* Initialize superblock, making @mp_fi its root */
	err = fuse_fill_super_submount(sb, mp_fi);
	if (err) {
		fuse_conn_put(fc);
		kfree(fm);
		sb->s_fs_info = NULL;
		deactivate_locked_super(sb);
		return err;
	}

	down_write(&fc->killsb);
	list_add_tail(&fm->fc_entry, &fc->mounts);
	up_write(&fc->killsb);

	sb->s_flags |= SB_ACTIVE;
	fsc->root = dget(sb->s_root);

1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407
	return 0;
}

static const struct fs_context_operations fuse_context_submount_ops = {
	.get_tree	= fuse_get_tree_submount,
};

int fuse_init_fs_context_submount(struct fs_context *fsc)
{
	fsc->ops = &fuse_context_submount_ops;
	return 0;
}
EXPORT_SYMBOL_GPL(fuse_init_fs_context_submount);

1408
int fuse_fill_super_common(struct super_block *sb, struct fuse_fs_context *ctx)
M
Miklos Szeredi 已提交
1409
{
1410
	struct fuse_dev *fud = NULL;
1411 1412
	struct fuse_mount *fm = get_fuse_mount_super(sb);
	struct fuse_conn *fc = fm->fc;
M
Miklos Szeredi 已提交
1413
	struct inode *root;
1414
	struct dentry *root_dentry;
M
Miklos Szeredi 已提交
1415 1416
	int err;

1417
	err = -EINVAL;
1418
	if (sb->s_flags & SB_MANDLOCK)
1419
		goto err;
1420

1421
	fuse_sb_defaults(sb);
A
Al Viro 已提交
1422

1423
	if (ctx->is_bdev) {
1424
#ifdef CONFIG_BLOCK
1425
		err = -EINVAL;
1426
		if (!sb_set_blocksize(sb, ctx->blksize))
1427
			goto err;
1428
#endif
M
Miklos Szeredi 已提交
1429
	} else {
1430 1431
		sb->s_blocksize = PAGE_SIZE;
		sb->s_blocksize_bits = PAGE_SHIFT;
M
Miklos Szeredi 已提交
1432
	}
1433 1434 1435

	sb->s_subtype = ctx->subtype;
	ctx->subtype = NULL;
1436 1437 1438 1439 1440
	if (IS_ENABLED(CONFIG_FUSE_DAX)) {
		err = fuse_dax_conn_alloc(fc, ctx->dax_dev);
		if (err)
			goto err;
	}
1441

1442 1443 1444 1445
	if (ctx->fudptr) {
		err = -ENOMEM;
		fud = fuse_dev_alloc_install(fc);
		if (!fud)
1446
			goto err_free_dax;
1447
	}
1448

1449
	fc->dev = sb->s_dev;
1450
	fm->sb = sb;
1451 1452
	err = fuse_bdi_init(fc, sb);
	if (err)
1453
		goto err_dev_free;
1454

1455
	/* Handle umasking inside the fuse code */
1456
	if (sb->s_flags & SB_POSIXACL)
1457
		fc->dont_mask = 1;
1458
	sb->s_flags |= SB_POSIXACL;
1459

1460 1461 1462 1463
	fc->default_permissions = ctx->default_permissions;
	fc->allow_other = ctx->allow_other;
	fc->user_id = ctx->user_id;
	fc->group_id = ctx->group_id;
1464
	fc->legacy_opts_show = ctx->legacy_opts_show;
1465
	fc->max_read = max_t(unsigned int, 4096, ctx->max_read);
1466
	fc->destroy = ctx->destroy;
1467 1468
	fc->no_control = ctx->no_control;
	fc->no_force_umount = ctx->no_force_umount;
1469

M
Miklos Szeredi 已提交
1470
	err = -ENOMEM;
1471
	root = fuse_get_root_inode(sb, ctx->rootmode);
1472
	sb->s_d_op = &fuse_root_dentry_operations;
1473 1474
	root_dentry = d_make_root(root);
	if (!root_dentry)
1475
		goto err_dev_free;
1476
	/* Root dentry doesn't have .d_revalidate */
A
Al Viro 已提交
1477
	sb->s_d_op = &fuse_dentry_operations;
1478

1479
	mutex_lock(&fuse_mutex);
1480
	err = -EINVAL;
1481
	if (ctx->fudptr && *ctx->fudptr)
1482
		goto err_unlock;
1483

1484 1485 1486 1487 1488
	err = fuse_ctl_add_conn(fc);
	if (err)
		goto err_unlock;

	list_add_tail(&fc->entry, &fuse_conn_list);
1489
	sb->s_root = root_dentry;
1490 1491
	if (ctx->fudptr)
		*ctx->fudptr = fud;
1492
	mutex_unlock(&fuse_mutex);
1493 1494 1495 1496 1497 1498
	return 0;

 err_unlock:
	mutex_unlock(&fuse_mutex);
	dput(root_dentry);
 err_dev_free:
1499 1500
	if (fud)
		fuse_dev_free(fud);
1501 1502 1503
 err_free_dax:
	if (IS_ENABLED(CONFIG_FUSE_DAX))
		fuse_dax_conn_free(fc);
1504 1505 1506 1507 1508 1509 1510 1511 1512 1513
 err:
	return err;
}
EXPORT_SYMBOL_GPL(fuse_fill_super_common);

static int fuse_fill_super(struct super_block *sb, struct fs_context *fsc)
{
	struct fuse_fs_context *ctx = fsc->fs_private;
	int err;
	struct fuse_conn *fc;
1514
	struct fuse_mount *fm;
1515

1516
	if (!ctx->file || !ctx->rootmode_present ||
1517 1518 1519
	    !ctx->user_id_present || !ctx->group_id_present)
		return -EINVAL;

1520 1521 1522 1523
	/*
	 * Require mount to happen from the same user namespace which
	 * opened /dev/fuse to prevent potential attacks.
	 */
1524 1525 1526 1527 1528
	err = -EINVAL;
	if ((ctx->file->f_op != &fuse_dev_operations) ||
	    (ctx->file->f_cred->user_ns != sb->s_user_ns))
		goto err;
	ctx->fudptr = &ctx->file->private_data;
1529 1530 1531 1532

	fc = kmalloc(sizeof(*fc), GFP_KERNEL);
	err = -ENOMEM;
	if (!fc)
1533
		goto err;
1534

1535 1536 1537
	fm = kzalloc(sizeof(*fm), GFP_KERNEL);
	if (!fm) {
		kfree(fc);
1538
		goto err;
1539 1540 1541
	}

	fuse_conn_init(fc, fm, sb->s_user_ns, &fuse_dev_fiq_ops, NULL);
1542
	fc->release = fuse_free_conn;
1543 1544

	sb->s_fs_info = fm;
1545 1546 1547 1548

	err = fuse_fill_super_common(sb, ctx);
	if (err)
		goto err_put_conn;
1549 1550
	/* file->private_data shall be visible on all CPUs after this */
	smp_mb();
1551
	fuse_send_init(get_fuse_mount_super(sb));
M
Miklos Szeredi 已提交
1552 1553
	return 0;

1554
 err_put_conn:
1555 1556
	fuse_conn_put(fc);
	kfree(fm);
1557
	sb->s_fs_info = NULL;
1558
 err:
M
Miklos Szeredi 已提交
1559 1560 1561
	return err;
}

M
Miklos Szeredi 已提交
1562 1563 1564 1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576
/*
 * This is the path where user supplied an already initialized fuse dev.  In
 * this case never create a new super if the old one is gone.
 */
static int fuse_set_no_super(struct super_block *sb, struct fs_context *fsc)
{
	return -ENOTCONN;
}

static int fuse_test_super(struct super_block *sb, struct fs_context *fsc)
{

	return fsc->sget_key == get_fuse_conn_super(sb);
}

1577
static int fuse_get_tree(struct fs_context *fsc)
M
Miklos Szeredi 已提交
1578
{
1579
	struct fuse_fs_context *ctx = fsc->fs_private;
M
Miklos Szeredi 已提交
1580 1581
	struct fuse_dev *fud;
	struct super_block *sb;
1582 1583 1584 1585
	int err;

	if (ctx->fd_present)
		ctx->file = fget(ctx->fd);
1586

1587
	if (IS_ENABLED(CONFIG_BLOCK) && ctx->is_bdev) {
1588 1589
		err = get_tree_bdev(fsc, fuse_fill_super);
		goto out_fput;
1590
	}
M
Miklos Szeredi 已提交
1591 1592 1593 1594 1595 1596
	/*
	 * While block dev mount can be initialized with a dummy device fd
	 * (found by device name), normal fuse mounts can't
	 */
	if (!ctx->file)
		return -EINVAL;
1597

M
Miklos Szeredi 已提交
1598 1599 1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611
	/*
	 * Allow creating a fuse mount with an already initialized fuse
	 * connection
	 */
	fud = READ_ONCE(ctx->file->private_data);
	if (ctx->file->f_op == &fuse_dev_operations && fud) {
		fsc->sget_key = fud->fc;
		sb = sget_fc(fsc, fuse_test_super, fuse_set_no_super);
		err = PTR_ERR_OR_ZERO(sb);
		if (!IS_ERR(sb))
			fsc->root = dget(sb->s_root);
	} else {
		err = get_tree_nodev(fsc, fuse_fill_super);
	}
1612 1613 1614 1615
out_fput:
	if (ctx->file)
		fput(ctx->file);
	return err;
1616 1617 1618
}

static const struct fs_context_operations fuse_context_ops = {
1619
	.free		= fuse_free_fsc,
1620
	.parse_param	= fuse_parse_param,
1621
	.reconfigure	= fuse_reconfigure,
1622 1623 1624 1625 1626 1627
	.get_tree	= fuse_get_tree,
};

/*
 * Set up the filesystem mount context.
 */
1628
static int fuse_init_fs_context(struct fs_context *fsc)
1629 1630 1631 1632 1633 1634 1635 1636 1637
{
	struct fuse_fs_context *ctx;

	ctx = kzalloc(sizeof(struct fuse_fs_context), GFP_KERNEL);
	if (!ctx)
		return -ENOMEM;

	ctx->max_read = ~0;
	ctx->blksize = FUSE_DEFAULT_BLKSIZE;
1638
	ctx->legacy_opts_show = true;
1639 1640

#ifdef CONFIG_BLOCK
1641
	if (fsc->fs_type == &fuseblk_fs_type) {
1642
		ctx->is_bdev = true;
1643 1644
		ctx->destroy = true;
	}
1645 1646
#endif

1647 1648
	fsc->fs_private = ctx;
	fsc->ops = &fuse_context_ops;
1649
	return 0;
M
Miklos Szeredi 已提交
1650 1651
}

1652
bool fuse_mount_remove(struct fuse_mount *fm)
J
John Muir 已提交
1653
{
1654 1655
	struct fuse_conn *fc = fm->fc;
	bool last = false;
J
John Muir 已提交
1656

1657 1658 1659 1660 1661
	down_write(&fc->killsb);
	list_del_init(&fm->fc_entry);
	if (list_empty(&fc->mounts))
		last = true;
	up_write(&fc->killsb);
1662

1663 1664 1665
	return last;
}
EXPORT_SYMBOL_GPL(fuse_mount_remove);
1666

1667 1668 1669 1670 1671 1672 1673 1674 1675
void fuse_conn_destroy(struct fuse_mount *fm)
{
	struct fuse_conn *fc = fm->fc;

	if (fc->destroy)
		fuse_send_destroy(fm);

	fuse_abort_conn(fc);
	fuse_wait_aborted(fc);
M
Miklos Szeredi 已提交
1676 1677 1678 1679 1680 1681

	if (!list_empty(&fc->entry)) {
		mutex_lock(&fuse_mutex);
		list_del(&fc->entry);
		fuse_ctl_remove_conn(fc);
		mutex_unlock(&fuse_mutex);
J
John Muir 已提交
1682
	}
1683
}
1684
EXPORT_SYMBOL_GPL(fuse_conn_destroy);
J
John Muir 已提交
1685

1686
static void fuse_sb_destroy(struct super_block *sb)
1687
{
1688 1689 1690 1691 1692 1693 1694 1695
	struct fuse_mount *fm = get_fuse_mount_super(sb);
	bool last;

	if (fm) {
		last = fuse_mount_remove(fm);
		if (last)
			fuse_conn_destroy(fm);
	}
1696 1697 1698 1699 1700
}

static void fuse_kill_sb_anon(struct super_block *sb)
{
	fuse_sb_destroy(sb);
J
John Muir 已提交
1701 1702 1703
	kill_anon_super(sb);
}

1704 1705 1706
static struct file_system_type fuse_fs_type = {
	.owner		= THIS_MODULE,
	.name		= "fuse",
1707
	.fs_flags	= FS_HAS_SUBTYPE | FS_USERNS_MOUNT,
1708
	.init_fs_context = fuse_init_fs_context,
1709
	.parameters	= fuse_fs_parameters,
J
John Muir 已提交
1710
	.kill_sb	= fuse_kill_sb_anon,
1711
};
1712
MODULE_ALIAS_FS("fuse");
1713 1714

#ifdef CONFIG_BLOCK
J
John Muir 已提交
1715 1716
static void fuse_kill_sb_blk(struct super_block *sb)
{
1717
	fuse_sb_destroy(sb);
J
John Muir 已提交
1718 1719 1720
	kill_block_super(sb);
}

1721 1722 1723
static struct file_system_type fuseblk_fs_type = {
	.owner		= THIS_MODULE,
	.name		= "fuseblk",
1724
	.init_fs_context = fuse_init_fs_context,
1725
	.parameters	= fuse_fs_parameters,
J
John Muir 已提交
1726
	.kill_sb	= fuse_kill_sb_blk,
A
Alexey Dobriyan 已提交
1727
	.fs_flags	= FS_REQUIRES_DEV | FS_HAS_SUBTYPE,
1728
};
1729
MODULE_ALIAS_FS("fuseblk");
1730

1731 1732 1733 1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749 1750
static inline int register_fuseblk(void)
{
	return register_filesystem(&fuseblk_fs_type);
}

static inline void unregister_fuseblk(void)
{
	unregister_filesystem(&fuseblk_fs_type);
}
#else
static inline int register_fuseblk(void)
{
	return 0;
}

static inline void unregister_fuseblk(void)
{
}
#endif

1751
static void fuse_inode_init_once(void *foo)
M
Miklos Szeredi 已提交
1752
{
M
Miklos Szeredi 已提交
1753
	struct inode *inode = foo;
M
Miklos Szeredi 已提交
1754

C
Christoph Lameter 已提交
1755
	inode_init_once(inode);
M
Miklos Szeredi 已提交
1756 1757 1758 1759 1760 1761
}

static int __init fuse_fs_init(void)
{
	int err;

1762
	fuse_inode_cachep = kmem_cache_create("fuse_inode",
1763 1764 1765
			sizeof(struct fuse_inode), 0,
			SLAB_HWCACHE_ALIGN|SLAB_ACCOUNT|SLAB_RECLAIM_ACCOUNT,
			fuse_inode_init_once);
1766 1767
	err = -ENOMEM;
	if (!fuse_inode_cachep)
1768 1769 1770 1771 1772 1773 1774 1775 1776
		goto out;

	err = register_fuseblk();
	if (err)
		goto out2;

	err = register_filesystem(&fuse_fs_type);
	if (err)
		goto out3;
1777 1778

	return 0;
M
Miklos Szeredi 已提交
1779

1780
 out3:
1781
	unregister_fuseblk();
1782 1783
 out2:
	kmem_cache_destroy(fuse_inode_cachep);
1784
 out:
M
Miklos Szeredi 已提交
1785 1786 1787 1788 1789 1790
	return err;
}

static void fuse_fs_cleanup(void)
{
	unregister_filesystem(&fuse_fs_type);
1791
	unregister_fuseblk();
1792 1793 1794 1795 1796 1797

	/*
	 * Make sure all delayed rcu free inodes are flushed before we
	 * destroy cache.
	 */
	rcu_barrier();
M
Miklos Szeredi 已提交
1798 1799 1800
	kmem_cache_destroy(fuse_inode_cachep);
}

1801 1802
static struct kobject *fuse_kobj;

1803 1804 1805 1806
static int fuse_sysfs_init(void)
{
	int err;

1807
	fuse_kobj = kobject_create_and_add("fuse", fs_kobj);
1808 1809
	if (!fuse_kobj) {
		err = -ENOMEM;
1810
		goto out_err;
1811
	}
1812

1813 1814
	err = sysfs_create_mount_point(fuse_kobj, "connections");
	if (err)
1815 1816 1817 1818 1819
		goto out_fuse_unregister;

	return 0;

 out_fuse_unregister:
1820
	kobject_put(fuse_kobj);
1821 1822 1823 1824 1825 1826
 out_err:
	return err;
}

static void fuse_sysfs_cleanup(void)
{
1827
	sysfs_remove_mount_point(fuse_kobj, "connections");
1828
	kobject_put(fuse_kobj);
1829 1830
}

M
Miklos Szeredi 已提交
1831 1832 1833 1834
static int __init fuse_init(void)
{
	int res;

K
Kirill Smelkov 已提交
1835 1836
	pr_info("init (API version %i.%i)\n",
		FUSE_KERNEL_VERSION, FUSE_KERNEL_MINOR_VERSION);
M
Miklos Szeredi 已提交
1837

1838
	INIT_LIST_HEAD(&fuse_conn_list);
M
Miklos Szeredi 已提交
1839 1840 1841 1842
	res = fuse_fs_init();
	if (res)
		goto err;

M
Miklos Szeredi 已提交
1843 1844 1845 1846
	res = fuse_dev_init();
	if (res)
		goto err_fs_cleanup;

1847 1848 1849 1850
	res = fuse_sysfs_init();
	if (res)
		goto err_dev_cleanup;

1851 1852 1853 1854
	res = fuse_ctl_init();
	if (res)
		goto err_sysfs_cleanup;

1855 1856 1857
	sanitize_global_limit(&max_user_bgreq);
	sanitize_global_limit(&max_user_congthresh);

M
Miklos Szeredi 已提交
1858 1859
	return 0;

1860 1861
 err_sysfs_cleanup:
	fuse_sysfs_cleanup();
1862 1863
 err_dev_cleanup:
	fuse_dev_cleanup();
M
Miklos Szeredi 已提交
1864 1865
 err_fs_cleanup:
	fuse_fs_cleanup();
M
Miklos Szeredi 已提交
1866 1867 1868 1869 1870 1871
 err:
	return res;
}

static void __exit fuse_exit(void)
{
K
Kirill Smelkov 已提交
1872
	pr_debug("exit\n");
M
Miklos Szeredi 已提交
1873

1874
	fuse_ctl_cleanup();
1875
	fuse_sysfs_cleanup();
M
Miklos Szeredi 已提交
1876
	fuse_fs_cleanup();
M
Miklos Szeredi 已提交
1877
	fuse_dev_cleanup();
M
Miklos Szeredi 已提交
1878 1879 1880 1881
}

module_init(fuse_init);
module_exit(fuse_exit);