inode.c 40.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 *fc)
142
{
143 144
	struct super_block *sb = fc->root->d_sb;

145
	sync_filesystem(sb);
146
	if (fc->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 353 354
		inode->i_generation = generation;
		fuse_init_inode(inode, attr);
		unlock_new_inode(inode);
	} else if ((inode->i_mode ^ attr->mode) & S_IFMT) {
		/* Inode has changed type, any I/O on the old 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;
}

M
Miklos Szeredi 已提交
509
enum {
510 511
	OPT_SOURCE,
	OPT_SUBTYPE,
M
Miklos Szeredi 已提交
512 513 514
	OPT_FD,
	OPT_ROOTMODE,
	OPT_USER_ID,
515
	OPT_GROUP_ID,
M
Miklos Szeredi 已提交
516 517
	OPT_DEFAULT_PERMISSIONS,
	OPT_ALLOW_OTHER,
518
	OPT_MAX_READ,
M
Miklos Szeredi 已提交
519
	OPT_BLKSIZE,
M
Miklos Szeredi 已提交
520 521 522
	OPT_ERR
};

523
static const struct fs_parameter_spec fuse_fs_parameters[] = {
524 525 526 527 528 529 530 531 532
	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),
533
	fsparam_string	("subtype",		OPT_SUBTYPE),
534 535 536 537
	{}
};

static int fuse_parse_param(struct fs_context *fc, struct fs_parameter *param)
538
{
539 540 541 542
	struct fs_parse_result result;
	struct fuse_fs_context *ctx = fc->fs_private;
	int opt;

543 544 545 546 547 548 549 550 551 552
	if (fc->purpose == FS_CONTEXT_FOR_RECONFIGURE) {
		/*
		 * Ignore options coming from mount(MS_REMOUNT) for backward
		 * compatibility.
		 */
		if (fc->oldapi)
			return 0;

		return invalfc(fc, "No changes allowed in reconfigure");
	}
553

554
	opt = fs_parse(fc, fuse_fs_parameters, param, &result);
555 556 557 558 559 560
	if (opt < 0)
		return opt;

	switch (opt) {
	case OPT_SOURCE:
		if (fc->source)
A
Al Viro 已提交
561
			return invalfc(fc, "Multiple sources specified");
562 563 564 565 566 567
		fc->source = param->string;
		param->string = NULL;
		break;

	case OPT_SUBTYPE:
		if (ctx->subtype)
A
Al Viro 已提交
568
			return invalfc(fc, "Multiple subtypes specified");
569 570 571 572 573 574
		ctx->subtype = param->string;
		param->string = NULL;
		return 0;

	case OPT_FD:
		ctx->fd = result.uint_32;
575
		ctx->fd_present = true;
576 577 578 579
		break;

	case OPT_ROOTMODE:
		if (!fuse_valid_type(result.uint_32))
A
Al Viro 已提交
580
			return invalfc(fc, "Invalid rootmode");
581
		ctx->rootmode = result.uint_32;
582
		ctx->rootmode_present = true;
583 584 585 586 587
		break;

	case OPT_USER_ID:
		ctx->user_id = make_kuid(fc->user_ns, result.uint_32);
		if (!uid_valid(ctx->user_id))
A
Al Viro 已提交
588
			return invalfc(fc, "Invalid user_id");
589
		ctx->user_id_present = true;
590 591 592 593 594
		break;

	case OPT_GROUP_ID:
		ctx->group_id = make_kgid(fc->user_ns, result.uint_32);
		if (!gid_valid(ctx->group_id))
A
Al Viro 已提交
595
			return invalfc(fc, "Invalid group_id");
596
		ctx->group_id_present = true;
597 598 599
		break;

	case OPT_DEFAULT_PERMISSIONS:
600
		ctx->default_permissions = true;
601 602 603
		break;

	case OPT_ALLOW_OTHER:
604
		ctx->allow_other = true;
605 606 607 608 609 610 611 612
		break;

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

	case OPT_BLKSIZE:
		if (!ctx->is_bdev)
A
Al Viro 已提交
613
			return invalfc(fc, "blksize only supported for fuseblk");
614 615 616 617 618
		ctx->blksize = result.uint_32;
		break;

	default:
		return -EINVAL;
619
	}
620 621

	return 0;
622 623
}

624
static void fuse_free_fc(struct fs_context *fc)
M
Miklos Szeredi 已提交
625
{
626
	struct fuse_fs_context *ctx = fc->fs_private;
627

628 629 630 631
	if (ctx) {
		kfree(ctx->subtype);
		kfree(ctx);
	}
M
Miklos Szeredi 已提交
632 633
}

634
static int fuse_show_options(struct seq_file *m, struct dentry *root)
M
Miklos Szeredi 已提交
635
{
636 637
	struct super_block *sb = root->d_sb;
	struct fuse_conn *fc = get_fuse_conn_super(sb);
M
Miklos Szeredi 已提交
638

639 640 641 642 643 644 645 646 647 648 649 650 651 652
	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);
	}
653 654 655 656
#ifdef CONFIG_FUSE_DAX
	if (fc->dax)
		seq_puts(m, ",dax");
#endif
657

M
Miklos Szeredi 已提交
658 659 660
	return 0;
}

661 662 663
static void fuse_iqueue_init(struct fuse_iqueue *fiq,
			     const struct fuse_iqueue_ops *ops,
			     void *priv)
M
Miklos Szeredi 已提交
664 665
{
	memset(fiq, 0, sizeof(struct fuse_iqueue));
666
	spin_lock_init(&fiq->lock);
M
Miklos Szeredi 已提交
667 668 669 670
	init_waitqueue_head(&fiq->waitq);
	INIT_LIST_HEAD(&fiq->pending);
	INIT_LIST_HEAD(&fiq->interrupts);
	fiq->forget_list_tail = &fiq->forget_list_head;
671
	fiq->connected = 1;
672 673
	fiq->ops = ops;
	fiq->priv = priv;
M
Miklos Szeredi 已提交
674 675
}

676 677
static void fuse_pqueue_init(struct fuse_pqueue *fpq)
{
678 679
	unsigned int i;

M
Miklos Szeredi 已提交
680
	spin_lock_init(&fpq->lock);
681 682
	for (i = 0; i < FUSE_PQ_HASH_SIZE; i++)
		INIT_LIST_HEAD(&fpq->processing[i]);
683
	INIT_LIST_HEAD(&fpq->io);
684
	fpq->connected = 1;
685 686
}

687 688
void fuse_conn_init(struct fuse_conn *fc, struct fuse_mount *fm,
		    struct user_namespace *user_ns,
689
		    const struct fuse_iqueue_ops *fiq_ops, void *fiq_priv)
M
Miklos Szeredi 已提交
690
{
691 692
	memset(fc, 0, sizeof(*fc));
	spin_lock_init(&fc->lock);
K
Kirill Tkhai 已提交
693
	spin_lock_init(&fc->bg_lock);
J
John Muir 已提交
694
	init_rwsem(&fc->killsb);
695
	refcount_set(&fc->count, 1);
696
	atomic_set(&fc->dev_count, 1);
697
	init_waitqueue_head(&fc->blocked_waitq);
698
	fuse_iqueue_init(&fc->iq, fiq_ops, fiq_priv);
699 700
	INIT_LIST_HEAD(&fc->bg_queue);
	INIT_LIST_HEAD(&fc->entry);
701
	INIT_LIST_HEAD(&fc->devices);
702
	atomic_set(&fc->num_waiting, 0);
703 704
	fc->max_background = FUSE_DEFAULT_MAX_BACKGROUND;
	fc->congestion_threshold = FUSE_DEFAULT_CONGESTION_THRESHOLD;
M
Miklos Szeredi 已提交
705
	atomic64_set(&fc->khctr, 0);
706
	fc->polled_files = RB_ROOT;
707
	fc->blocked = 0;
M
Maxim Patlasov 已提交
708
	fc->initialized = 0;
709
	fc->connected = 1;
710
	atomic64_set(&fc->attr_version, 1);
711
	get_random_bytes(&fc->scramble_key, sizeof(fc->scramble_key));
712
	fc->pid_ns = get_pid_ns(task_active_pid_ns(current));
713
	fc->user_ns = get_user_ns(user_ns);
M
Miklos Szeredi 已提交
714
	fc->max_pages = FUSE_DEFAULT_MAX_PAGES_PER_REQ;
715 716 717 718

	INIT_LIST_HEAD(&fc->mounts);
	list_add(&fm->fc_entry, &fc->mounts);
	fm->fc = fc;
M
Miklos Szeredi 已提交
719
}
720
EXPORT_SYMBOL_GPL(fuse_conn_init);
M
Miklos Szeredi 已提交
721

722 723
void fuse_conn_put(struct fuse_conn *fc)
{
724
	if (refcount_dec_and_test(&fc->count)) {
725 726
		struct fuse_iqueue *fiq = &fc->iq;

727 728
		if (IS_ENABLED(CONFIG_FUSE_DAX))
			fuse_dax_conn_free(fc);
729 730
		if (fiq->ops->release)
			fiq->ops->release(fiq);
731
		put_pid_ns(fc->pid_ns);
732
		put_user_ns(fc->user_ns);
T
Tejun Heo 已提交
733
		fc->release(fc);
734
	}
735
}
736
EXPORT_SYMBOL_GPL(fuse_conn_put);
737 738 739

struct fuse_conn *fuse_conn_get(struct fuse_conn *fc)
{
740
	refcount_inc(&fc->count);
741 742
	return fc;
}
743
EXPORT_SYMBOL_GPL(fuse_conn_get);
744

745
static struct inode *fuse_get_root_inode(struct super_block *sb, unsigned mode)
M
Miklos Szeredi 已提交
746 747 748 749 750 751
{
	struct fuse_attr attr;
	memset(&attr, 0, sizeof(attr));

	attr.mode = mode;
	attr.ino = FUSE_ROOT_ID;
752
	attr.nlink = 1;
753
	return fuse_iget(sb, 1, 0, &attr, 0, 0);
M
Miklos Szeredi 已提交
754 755
}

M
Miklos Szeredi 已提交
756
struct fuse_inode_handle {
M
Miklos Szeredi 已提交
757 758 759 760 761 762 763
	u64 nodeid;
	u32 generation;
};

static struct dentry *fuse_get_dentry(struct super_block *sb,
				      struct fuse_inode_handle *handle)
{
764
	struct fuse_conn *fc = get_fuse_conn_super(sb);
M
Miklos Szeredi 已提交
765 766 767 768 769 770 771 772
	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);
773 774
	if (!inode) {
		struct fuse_entry_out outarg;
A
Al Viro 已提交
775
		const struct qstr name = QSTR_INIT(".", 1);
776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791

		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 已提交
792 793 794 795
	err = -ESTALE;
	if (inode->i_generation != handle->generation)
		goto out_iput;

796
	entry = d_obtain_alias(inode);
A
Al Viro 已提交
797
	if (!IS_ERR(entry) && get_node_id(inode) != FUSE_ROOT_ID)
M
Miklos Szeredi 已提交
798 799 800 801 802 803 804 805 806 807
		fuse_invalidate_entry_cache(entry);

	return entry;

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

A
Al Viro 已提交
808 809
static int fuse_encode_fh(struct inode *inode, u32 *fh, int *max_len,
			   struct inode *parent)
M
Miklos Szeredi 已提交
810
{
A
Al Viro 已提交
811
	int len = parent ? 6 : 3;
M
Miklos Szeredi 已提交
812 813 814
	u64 nodeid;
	u32 generation;

815 816
	if (*max_len < len) {
		*max_len = len;
817
		return  FILEID_INVALID;
818
	}
M
Miklos Szeredi 已提交
819 820 821 822 823 824 825 826

	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 已提交
827
	if (parent) {
M
Miklos Szeredi 已提交
828 829 830 831 832 833 834 835 836
		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 已提交
837
	return parent ? 0x82 : 0x81;
M
Miklos Szeredi 已提交
838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867
}

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);
}

868 869
static struct dentry *fuse_get_parent(struct dentry *child)
{
870
	struct inode *child_inode = d_inode(child);
871 872 873 874
	struct fuse_conn *fc = get_fuse_conn(child_inode);
	struct inode *inode;
	struct dentry *parent;
	struct fuse_entry_out outarg;
A
Al Viro 已提交
875
	const struct qstr name = QSTR_INIT("..", 2);
876 877 878 879 880 881 882
	int err;

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

	err = fuse_lookup_name(child_inode->i_sb, get_node_id(child_inode),
			       &name, &outarg, &inode);
883 884 885
	if (err) {
		if (err == -ENOENT)
			return ERR_PTR(-ESTALE);
886 887
		return ERR_PTR(err);
	}
888 889

	parent = d_obtain_alias(inode);
A
Al Viro 已提交
890
	if (!IS_ERR(parent) && get_node_id(inode) != FUSE_ROOT_ID)
891 892 893 894
		fuse_invalidate_entry_cache(parent);

	return parent;
}
M
Miklos Szeredi 已提交
895 896 897 898 899

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,
900
	.get_parent	= fuse_get_parent,
M
Miklos Szeredi 已提交
901 902
};

903
static const struct super_operations fuse_super_operations = {
M
Miklos Szeredi 已提交
904
	.alloc_inode    = fuse_alloc_inode,
A
Al Viro 已提交
905
	.free_inode     = fuse_free_inode,
906
	.evict_inode	= fuse_evict_inode,
M
Miklos Szeredi 已提交
907
	.write_inode	= fuse_write_inode,
M
Miklos Szeredi 已提交
908
	.drop_inode	= generic_delete_inode,
M
Miklos Szeredi 已提交
909
	.put_super	= fuse_put_super,
910
	.umount_begin	= fuse_umount_begin,
911
	.statfs		= fuse_statfs,
M
Miklos Szeredi 已提交
912 913 914
	.show_options	= fuse_show_options,
};

915 916
static void sanitize_global_limit(unsigned *limit)
{
M
Miklos Szeredi 已提交
917 918 919 920
	/*
	 * The default maximum number of async requests is calculated to consume
	 * 1/2^13 of the total memory, assuming 392 bytes per request.
	 */
921
	if (*limit == 0)
M
Miklos Szeredi 已提交
922
		*limit = ((totalram_pages() << PAGE_SHIFT) >> 13) / 392;
923 924 925 926 927

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

928
static int set_global_limit(const char *val, const struct kernel_param *kp)
929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950
{
	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 已提交
951
	spin_lock(&fc->bg_lock);
952 953 954 955 956 957 958 959 960 961 962 963 964
	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 已提交
965
	spin_unlock(&fc->bg_lock);
966 967
}

968 969 970 971 972 973
struct fuse_init_args {
	struct fuse_args args;
	struct fuse_init_in in;
	struct fuse_init_out out;
};

974
static void process_init_reply(struct fuse_mount *fm, struct fuse_args *args,
975
			       int error)
976
{
977
	struct fuse_conn *fc = fm->fc;
978 979
	struct fuse_init_args *ia = container_of(args, typeof(*ia), args);
	struct fuse_init_out *arg = &ia->out;
980
	bool ok = true;
981

982
	if (error || arg->major != FUSE_KERNEL_VERSION)
983
		ok = false;
984
	else {
985 986
		unsigned long ra_pages;

987 988
		process_init_limits(fc, arg);

989
		if (arg->minor >= 6) {
990
			ra_pages = arg->max_readahead / PAGE_SIZE;
991 992
			if (arg->flags & FUSE_ASYNC_READ)
				fc->async_read = 1;
993 994
			if (!(arg->flags & FUSE_POSIX_LOCKS))
				fc->no_lock = 1;
M
Miklos Szeredi 已提交
995 996 997
			if (arg->minor >= 17) {
				if (!(arg->flags & FUSE_FLOCK_LOCKS))
					fc->no_flock = 1;
M
Miklos Szeredi 已提交
998 999 1000
			} else {
				if (!(arg->flags & FUSE_POSIX_LOCKS))
					fc->no_flock = 1;
M
Miklos Szeredi 已提交
1001
			}
1002 1003
			if (arg->flags & FUSE_ATOMIC_O_TRUNC)
				fc->atomic_o_trunc = 1;
1004 1005 1006 1007 1008
			if (arg->minor >= 9) {
				/* LOOKUP has dependency on proto version */
				if (arg->flags & FUSE_EXPORT_SUPPORT)
					fc->export_support = 1;
			}
1009 1010
			if (arg->flags & FUSE_BIG_WRITES)
				fc->big_writes = 1;
1011 1012
			if (arg->flags & FUSE_DONT_MASK)
				fc->dont_mask = 1;
1013 1014
			if (arg->flags & FUSE_AUTO_INVAL_DATA)
				fc->auto_inval_data = 1;
1015 1016
			else if (arg->flags & FUSE_EXPLICIT_INVAL_DATA)
				fc->explicit_inval_data = 1;
1017
			if (arg->flags & FUSE_DO_READDIRPLUS) {
1018
				fc->do_readdirplus = 1;
1019 1020 1021
				if (arg->flags & FUSE_READDIRPLUS_AUTO)
					fc->readdirplus_auto = 1;
			}
1022 1023
			if (arg->flags & FUSE_ASYNC_DIO)
				fc->async_dio = 1;
P
Pavel Emelyanov 已提交
1024 1025
			if (arg->flags & FUSE_WRITEBACK_CACHE)
				fc->writeback_cache = 1;
1026 1027
			if (arg->flags & FUSE_PARALLEL_DIROPS)
				fc->parallel_dirops = 1;
1028 1029
			if (arg->flags & FUSE_HANDLE_KILLPRIV)
				fc->handle_killpriv = 1;
1030
			if (arg->time_gran && arg->time_gran <= 1000000000)
1031
				fm->sb->s_time_gran = arg->time_gran;
S
Seth Forshee 已提交
1032
			if ((arg->flags & FUSE_POSIX_ACL)) {
M
Miklos Szeredi 已提交
1033
				fc->default_permissions = 1;
S
Seth Forshee 已提交
1034
				fc->posix_acl = 1;
1035
				fm->sb->s_xattr = fuse_acl_xattr_handlers;
S
Seth Forshee 已提交
1036
			}
D
Dan Schatzberg 已提交
1037 1038
			if (arg->flags & FUSE_CACHE_SYMLINKS)
				fc->cache_symlinks = 1;
1039 1040
			if (arg->flags & FUSE_ABORT_ERROR)
				fc->abort_err = 1;
1041 1042 1043 1044 1045
			if (arg->flags & FUSE_MAX_PAGES) {
				fc->max_pages =
					min_t(unsigned int, FUSE_MAX_MAX_PAGES,
					max_t(unsigned int, arg->max_pages, 1));
			}
1046 1047 1048 1049 1050
			if (IS_ENABLED(CONFIG_FUSE_DAX) &&
			    arg->flags & FUSE_MAP_ALIGNMENT &&
			    !fuse_dax_check_alignment(fc, arg->map_alignment)) {
				ok = false;
			}
1051
			if (arg->flags & FUSE_HANDLE_KILLPRIV_V2) {
1052
				fc->handle_killpriv_v2 = 1;
1053 1054
				fm->sb->s_flags |= SB_NOSEC;
			}
1055
		} else {
1056
			ra_pages = fc->max_read / PAGE_SIZE;
1057
			fc->no_lock = 1;
M
Miklos Szeredi 已提交
1058
			fc->no_flock = 1;
1059
		}
1060

1061 1062
		fm->sb->s_bdi->ra_pages =
				min(fm->sb->s_bdi->ra_pages, ra_pages);
1063 1064
		fc->minor = arg->minor;
		fc->max_write = arg->minor < 5 ? 4096 : arg->max_write;
1065
		fc->max_write = max_t(unsigned, 4096, fc->max_write);
1066
		fc->conn_init = 1;
1067
	}
1068 1069
	kfree(ia);

1070 1071 1072 1073 1074
	if (!ok) {
		fc->conn_init = 0;
		fc->conn_error = 1;
	}

1075
	fuse_set_initialized(fc);
1076
	wake_up_all(&fc->blocked_waitq);
1077 1078
}

1079
void fuse_send_init(struct fuse_mount *fm)
1080
{
1081
	struct fuse_init_args *ia;
M
Miklos Szeredi 已提交
1082

1083 1084 1085 1086
	ia = kzalloc(sizeof(*ia), GFP_KERNEL | __GFP_NOFAIL);

	ia->in.major = FUSE_KERNEL_VERSION;
	ia->in.minor = FUSE_KERNEL_MINOR_VERSION;
1087
	ia->in.max_readahead = fm->sb->s_bdi->ra_pages * PAGE_SIZE;
1088 1089
	ia->in.flags |=
		FUSE_ASYNC_READ | FUSE_POSIX_LOCKS | FUSE_ATOMIC_O_TRUNC |
M
Miklos Szeredi 已提交
1090
		FUSE_EXPORT_SUPPORT | FUSE_BIG_WRITES | FUSE_DONT_MASK |
M
Miklos Szeredi 已提交
1091
		FUSE_SPLICE_WRITE | FUSE_SPLICE_MOVE | FUSE_SPLICE_READ |
1092
		FUSE_FLOCK_LOCKS | FUSE_HAS_IOCTL_DIR | FUSE_AUTO_INVAL_DATA |
P
Pavel Emelyanov 已提交
1093
		FUSE_DO_READDIRPLUS | FUSE_READDIRPLUS_AUTO | FUSE_ASYNC_DIO |
1094
		FUSE_WRITEBACK_CACHE | FUSE_NO_OPEN_SUPPORT |
1095
		FUSE_PARALLEL_DIROPS | FUSE_HANDLE_KILLPRIV | FUSE_POSIX_ACL |
1096
		FUSE_ABORT_ERROR | FUSE_MAX_PAGES | FUSE_CACHE_SYMLINKS |
1097 1098
		FUSE_NO_OPENDIR_SUPPORT | FUSE_EXPLICIT_INVAL_DATA |
		FUSE_HANDLE_KILLPRIV_V2;
1099
#ifdef CONFIG_FUSE_DAX
1100
	if (fm->fc->dax)
1101 1102
		ia->in.flags |= FUSE_MAP_ALIGNMENT;
#endif
M
Max Reitz 已提交
1103 1104 1105
	if (fm->fc->auto_submounts)
		ia->in.flags |= FUSE_SUBMOUNTS;

1106 1107 1108 1109 1110
	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 已提交
1111
	/* Variable length argument used for backward compatibility
1112 1113
	   with interface version < 7.5.  Rest of init_out is zeroed
	   by do_get_request(), so a short reply is not a problem */
1114
	ia->args.out_argvar = true;
1115 1116 1117 1118 1119 1120
	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;

1121 1122
	if (fuse_simple_background(fm, &ia->args, GFP_KERNEL) != 0)
		process_init_reply(fm, &ia->args, -ENOTCONN);
1123
}
1124
EXPORT_SYMBOL_GPL(fuse_send_init);
1125

1126
void fuse_free_conn(struct fuse_conn *fc)
T
Tejun Heo 已提交
1127
{
1128
	WARN_ON(!list_empty(&fc->devices));
A
Al Viro 已提交
1129
	kfree_rcu(fc, rcu);
T
Tejun Heo 已提交
1130
}
1131
EXPORT_SYMBOL_GPL(fuse_free_conn);
T
Tejun Heo 已提交
1132

1133 1134 1135
static int fuse_bdi_init(struct fuse_conn *fc, struct super_block *sb)
{
	int err;
1136
	char *suffix = "";
1137

1138
	if (sb->s_bdev) {
1139
		suffix = "-fuseblk";
1140 1141 1142 1143 1144 1145 1146
		/*
		 * 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;
	}
1147 1148
	err = super_setup_bdi_name(sb, "%u:%u%s", MAJOR(fc->dev),
				   MINOR(fc->dev), suffix);
1149 1150 1151
	if (err)
		return err;

1152
	/* fuse does it's own writeback accounting */
1153 1154
	sb->s_bdi->capabilities &= ~BDI_CAP_WRITEBACK_ACCT;
	sb->s_bdi->capabilities |= BDI_CAP_STRICTLIMIT;
1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167

	/*
	 * 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
	 */
1168
	bdi_set_max_ratio(sb->s_bdi, 1);
1169 1170 1171 1172

	return 0;
}

1173
struct fuse_dev *fuse_dev_alloc(void)
1174 1175
{
	struct fuse_dev *fud;
1176
	struct list_head *pq;
1177 1178

	fud = kzalloc(sizeof(struct fuse_dev), GFP_KERNEL);
1179 1180
	if (!fud)
		return NULL;
1181

1182 1183 1184 1185
	pq = kcalloc(FUSE_PQ_HASH_SIZE, sizeof(struct list_head), GFP_KERNEL);
	if (!pq) {
		kfree(fud);
		return NULL;
1186 1187
	}

1188 1189 1190
	fud->pq.processing = pq;
	fuse_pqueue_init(&fud->pq);

1191 1192 1193 1194 1195 1196 1197
	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);
1198 1199 1200
	spin_lock(&fc->lock);
	list_add_tail(&fud->entry, &fc->devices);
	spin_unlock(&fc->lock);
1201 1202
}
EXPORT_SYMBOL_GPL(fuse_dev_install);
1203

1204 1205 1206 1207 1208 1209 1210 1211 1212
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);
1213 1214
	return fud;
}
1215
EXPORT_SYMBOL_GPL(fuse_dev_alloc_install);
1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227

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);
	}
1228
	kfree(fud->pq.processing);
1229 1230 1231 1232
	kfree(fud);
}
EXPORT_SYMBOL_GPL(fuse_dev_free);

1233 1234 1235 1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 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
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;
}

int fuse_fill_super_submount(struct super_block *sb,
			     struct fuse_inode *parent_fi)
{
	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;
}

1314
int fuse_fill_super_common(struct super_block *sb, struct fuse_fs_context *ctx)
M
Miklos Szeredi 已提交
1315
{
1316
	struct fuse_dev *fud = NULL;
1317 1318
	struct fuse_mount *fm = get_fuse_mount_super(sb);
	struct fuse_conn *fc = fm->fc;
M
Miklos Szeredi 已提交
1319
	struct inode *root;
1320
	struct dentry *root_dentry;
M
Miklos Szeredi 已提交
1321 1322
	int err;

1323
	err = -EINVAL;
1324
	if (sb->s_flags & SB_MANDLOCK)
1325
		goto err;
1326

1327
	fuse_sb_defaults(sb);
A
Al Viro 已提交
1328

1329
	if (ctx->is_bdev) {
1330
#ifdef CONFIG_BLOCK
1331
		err = -EINVAL;
1332
		if (!sb_set_blocksize(sb, ctx->blksize))
1333
			goto err;
1334
#endif
M
Miklos Szeredi 已提交
1335
	} else {
1336 1337
		sb->s_blocksize = PAGE_SIZE;
		sb->s_blocksize_bits = PAGE_SHIFT;
M
Miklos Szeredi 已提交
1338
	}
1339 1340 1341

	sb->s_subtype = ctx->subtype;
	ctx->subtype = NULL;
1342 1343 1344 1345 1346
	if (IS_ENABLED(CONFIG_FUSE_DAX)) {
		err = fuse_dax_conn_alloc(fc, ctx->dax_dev);
		if (err)
			goto err;
	}
1347

1348 1349 1350 1351
	if (ctx->fudptr) {
		err = -ENOMEM;
		fud = fuse_dev_alloc_install(fc);
		if (!fud)
1352
			goto err_free_dax;
1353
	}
1354

1355
	fc->dev = sb->s_dev;
1356
	fm->sb = sb;
1357 1358
	err = fuse_bdi_init(fc, sb);
	if (err)
1359
		goto err_dev_free;
1360

1361
	/* Handle umasking inside the fuse code */
1362
	if (sb->s_flags & SB_POSIXACL)
1363
		fc->dont_mask = 1;
1364
	sb->s_flags |= SB_POSIXACL;
1365

1366 1367 1368 1369
	fc->default_permissions = ctx->default_permissions;
	fc->allow_other = ctx->allow_other;
	fc->user_id = ctx->user_id;
	fc->group_id = ctx->group_id;
1370
	fc->legacy_opts_show = ctx->legacy_opts_show;
1371
	fc->max_read = max_t(unsigned int, 4096, ctx->max_read);
1372
	fc->destroy = ctx->destroy;
1373 1374
	fc->no_control = ctx->no_control;
	fc->no_force_umount = ctx->no_force_umount;
1375

M
Miklos Szeredi 已提交
1376
	err = -ENOMEM;
1377
	root = fuse_get_root_inode(sb, ctx->rootmode);
1378
	sb->s_d_op = &fuse_root_dentry_operations;
1379 1380
	root_dentry = d_make_root(root);
	if (!root_dentry)
1381
		goto err_dev_free;
1382
	/* Root dentry doesn't have .d_revalidate */
A
Al Viro 已提交
1383
	sb->s_d_op = &fuse_dentry_operations;
1384

1385
	mutex_lock(&fuse_mutex);
1386
	err = -EINVAL;
1387
	if (ctx->fudptr && *ctx->fudptr)
1388
		goto err_unlock;
1389

1390 1391 1392 1393 1394
	err = fuse_ctl_add_conn(fc);
	if (err)
		goto err_unlock;

	list_add_tail(&fc->entry, &fuse_conn_list);
1395
	sb->s_root = root_dentry;
1396 1397
	if (ctx->fudptr)
		*ctx->fudptr = fud;
1398
	mutex_unlock(&fuse_mutex);
1399 1400 1401 1402 1403 1404
	return 0;

 err_unlock:
	mutex_unlock(&fuse_mutex);
	dput(root_dentry);
 err_dev_free:
1405 1406
	if (fud)
		fuse_dev_free(fud);
1407 1408 1409
 err_free_dax:
	if (IS_ENABLED(CONFIG_FUSE_DAX))
		fuse_dax_conn_free(fc);
1410 1411 1412 1413 1414 1415 1416 1417 1418 1419 1420
 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;
	struct file *file;
	int err;
	struct fuse_conn *fc;
1421
	struct fuse_mount *fm;
1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 1440 1441

	err = -EINVAL;
	file = fget(ctx->fd);
	if (!file)
		goto err;

	/*
	 * Require mount to happen from the same user namespace which
	 * opened /dev/fuse to prevent potential attacks.
	 */
	if ((file->f_op != &fuse_dev_operations) ||
	    (file->f_cred->user_ns != sb->s_user_ns))
		goto err_fput;
	ctx->fudptr = &file->private_data;

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

1442 1443 1444 1445 1446 1447 1448
	fm = kzalloc(sizeof(*fm), GFP_KERNEL);
	if (!fm) {
		kfree(fc);
		goto err_fput;
	}

	fuse_conn_init(fc, fm, sb->s_user_ns, &fuse_dev_fiq_ops, NULL);
1449
	fc->release = fuse_free_conn;
1450 1451

	sb->s_fs_info = fm;
1452 1453 1454 1455

	err = fuse_fill_super_common(sb, ctx);
	if (err)
		goto err_put_conn;
M
Miklos Szeredi 已提交
1456 1457 1458 1459 1460 1461
	/*
	 * atomic_dec_and_test() in fput() provides the necessary
	 * memory barrier for file->private_data to be visible on all
	 * CPUs after this
	 */
	fput(file);
1462
	fuse_send_init(get_fuse_mount_super(sb));
M
Miklos Szeredi 已提交
1463 1464
	return 0;

1465
 err_put_conn:
1466 1467
	fuse_conn_put(fc);
	kfree(fm);
1468
	sb->s_fs_info = NULL;
1469 1470 1471
 err_fput:
	fput(file);
 err:
M
Miklos Szeredi 已提交
1472 1473 1474
	return err;
}

1475
static int fuse_get_tree(struct fs_context *fc)
M
Miklos Szeredi 已提交
1476
{
1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493
	struct fuse_fs_context *ctx = fc->fs_private;

	if (!ctx->fd_present || !ctx->rootmode_present ||
	    !ctx->user_id_present || !ctx->group_id_present)
		return -EINVAL;

#ifdef CONFIG_BLOCK
	if (ctx->is_bdev)
		return get_tree_bdev(fc, fuse_fill_super);
#endif

	return get_tree_nodev(fc, fuse_fill_super);
}

static const struct fs_context_operations fuse_context_ops = {
	.free		= fuse_free_fc,
	.parse_param	= fuse_parse_param,
1494
	.reconfigure	= fuse_reconfigure,
1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510
	.get_tree	= fuse_get_tree,
};

/*
 * Set up the filesystem mount context.
 */
static int fuse_init_fs_context(struct fs_context *fc)
{
	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;
1511
	ctx->legacy_opts_show = true;
1512 1513

#ifdef CONFIG_BLOCK
1514
	if (fc->fs_type == &fuseblk_fs_type) {
1515
		ctx->is_bdev = true;
1516 1517
		ctx->destroy = true;
	}
1518 1519 1520 1521 1522
#endif

	fc->fs_private = ctx;
	fc->ops = &fuse_context_ops;
	return 0;
M
Miklos Szeredi 已提交
1523 1524
}

1525
bool fuse_mount_remove(struct fuse_mount *fm)
J
John Muir 已提交
1526
{
1527 1528
	struct fuse_conn *fc = fm->fc;
	bool last = false;
J
John Muir 已提交
1529

1530 1531 1532 1533 1534
	down_write(&fc->killsb);
	list_del_init(&fm->fc_entry);
	if (list_empty(&fc->mounts))
		last = true;
	up_write(&fc->killsb);
1535

1536 1537 1538
	return last;
}
EXPORT_SYMBOL_GPL(fuse_mount_remove);
1539

1540 1541 1542 1543 1544 1545 1546 1547 1548
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 已提交
1549 1550 1551 1552 1553 1554

	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 已提交
1555
	}
1556
}
1557
EXPORT_SYMBOL_GPL(fuse_conn_destroy);
J
John Muir 已提交
1558

1559
static void fuse_sb_destroy(struct super_block *sb)
1560
{
1561 1562 1563 1564 1565 1566 1567 1568
	struct fuse_mount *fm = get_fuse_mount_super(sb);
	bool last;

	if (fm) {
		last = fuse_mount_remove(fm);
		if (last)
			fuse_conn_destroy(fm);
	}
1569 1570 1571 1572 1573
}

static void fuse_kill_sb_anon(struct super_block *sb)
{
	fuse_sb_destroy(sb);
J
John Muir 已提交
1574 1575 1576
	kill_anon_super(sb);
}

1577 1578 1579
static struct file_system_type fuse_fs_type = {
	.owner		= THIS_MODULE,
	.name		= "fuse",
1580
	.fs_flags	= FS_HAS_SUBTYPE | FS_USERNS_MOUNT,
1581
	.init_fs_context = fuse_init_fs_context,
1582
	.parameters	= fuse_fs_parameters,
J
John Muir 已提交
1583
	.kill_sb	= fuse_kill_sb_anon,
1584
};
1585
MODULE_ALIAS_FS("fuse");
1586 1587

#ifdef CONFIG_BLOCK
J
John Muir 已提交
1588 1589
static void fuse_kill_sb_blk(struct super_block *sb)
{
1590
	fuse_sb_destroy(sb);
J
John Muir 已提交
1591 1592 1593
	kill_block_super(sb);
}

1594 1595 1596
static struct file_system_type fuseblk_fs_type = {
	.owner		= THIS_MODULE,
	.name		= "fuseblk",
1597
	.init_fs_context = fuse_init_fs_context,
1598
	.parameters	= fuse_fs_parameters,
J
John Muir 已提交
1599
	.kill_sb	= fuse_kill_sb_blk,
A
Alexey Dobriyan 已提交
1600
	.fs_flags	= FS_REQUIRES_DEV | FS_HAS_SUBTYPE,
1601
};
1602
MODULE_ALIAS_FS("fuseblk");
1603

1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621 1622 1623
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

1624
static void fuse_inode_init_once(void *foo)
M
Miklos Szeredi 已提交
1625
{
M
Miklos Szeredi 已提交
1626
	struct inode *inode = foo;
M
Miklos Szeredi 已提交
1627

C
Christoph Lameter 已提交
1628
	inode_init_once(inode);
M
Miklos Szeredi 已提交
1629 1630 1631 1632 1633 1634
}

static int __init fuse_fs_init(void)
{
	int err;

1635
	fuse_inode_cachep = kmem_cache_create("fuse_inode",
1636 1637 1638
			sizeof(struct fuse_inode), 0,
			SLAB_HWCACHE_ALIGN|SLAB_ACCOUNT|SLAB_RECLAIM_ACCOUNT,
			fuse_inode_init_once);
1639 1640
	err = -ENOMEM;
	if (!fuse_inode_cachep)
1641 1642 1643 1644 1645 1646 1647 1648 1649
		goto out;

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

	err = register_filesystem(&fuse_fs_type);
	if (err)
		goto out3;
1650 1651

	return 0;
M
Miklos Szeredi 已提交
1652

1653
 out3:
1654
	unregister_fuseblk();
1655 1656
 out2:
	kmem_cache_destroy(fuse_inode_cachep);
1657
 out:
M
Miklos Szeredi 已提交
1658 1659 1660 1661 1662 1663
	return err;
}

static void fuse_fs_cleanup(void)
{
	unregister_filesystem(&fuse_fs_type);
1664
	unregister_fuseblk();
1665 1666 1667 1668 1669 1670

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

1674 1675
static struct kobject *fuse_kobj;

1676 1677 1678 1679
static int fuse_sysfs_init(void)
{
	int err;

1680
	fuse_kobj = kobject_create_and_add("fuse", fs_kobj);
1681 1682
	if (!fuse_kobj) {
		err = -ENOMEM;
1683
		goto out_err;
1684
	}
1685

1686 1687
	err = sysfs_create_mount_point(fuse_kobj, "connections");
	if (err)
1688 1689 1690 1691 1692
		goto out_fuse_unregister;

	return 0;

 out_fuse_unregister:
1693
	kobject_put(fuse_kobj);
1694 1695 1696 1697 1698 1699
 out_err:
	return err;
}

static void fuse_sysfs_cleanup(void)
{
1700
	sysfs_remove_mount_point(fuse_kobj, "connections");
1701
	kobject_put(fuse_kobj);
1702 1703
}

M
Miklos Szeredi 已提交
1704 1705 1706 1707
static int __init fuse_init(void)
{
	int res;

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

1711
	INIT_LIST_HEAD(&fuse_conn_list);
M
Miklos Szeredi 已提交
1712 1713 1714 1715
	res = fuse_fs_init();
	if (res)
		goto err;

M
Miklos Szeredi 已提交
1716 1717 1718 1719
	res = fuse_dev_init();
	if (res)
		goto err_fs_cleanup;

1720 1721 1722 1723
	res = fuse_sysfs_init();
	if (res)
		goto err_dev_cleanup;

1724 1725 1726 1727
	res = fuse_ctl_init();
	if (res)
		goto err_sysfs_cleanup;

1728 1729 1730
	sanitize_global_limit(&max_user_bgreq);
	sanitize_global_limit(&max_user_congthresh);

M
Miklos Szeredi 已提交
1731 1732
	return 0;

1733 1734
 err_sysfs_cleanup:
	fuse_sysfs_cleanup();
1735 1736
 err_dev_cleanup:
	fuse_dev_cleanup();
M
Miklos Szeredi 已提交
1737 1738
 err_fs_cleanup:
	fuse_fs_cleanup();
M
Miklos Szeredi 已提交
1739 1740 1741 1742 1743 1744
 err:
	return res;
}

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

1747
	fuse_ctl_cleanup();
1748
	fuse_sysfs_cleanup();
M
Miklos Szeredi 已提交
1749
	fuse_fs_cleanup();
M
Miklos Szeredi 已提交
1750
	fuse_dev_cleanup();
M
Miklos Szeredi 已提交
1751 1752 1753 1754
}

module_init(fuse_init);
module_exit(fuse_exit);