Linux Audio

Check our new training course

Loading...
v3.1
   1/*
   2 * Copyright 2000 by Hans Reiser, licensing governed by reiserfs/README
   3 *
   4 * Trivial changes by Alan Cox to add the LFS fixes
   5 *
   6 * Trivial Changes:
   7 * Rights granted to Hans Reiser to redistribute under other terms providing
   8 * he accepts all liability including but not limited to patent, fitness
   9 * for purpose, and direct or indirect claims arising from failure to perform.
  10 *
  11 * NO WARRANTY
  12 */
  13
  14#include <linux/module.h>
  15#include <linux/slab.h>
  16#include <linux/vmalloc.h>
  17#include <linux/time.h>
  18#include <asm/uaccess.h>
  19#include <linux/reiserfs_fs.h>
  20#include <linux/reiserfs_acl.h>
  21#include <linux/reiserfs_xattr.h>
  22#include <linux/init.h>
  23#include <linux/blkdev.h>
 
  24#include <linux/buffer_head.h>
  25#include <linux/exportfs.h>
  26#include <linux/quotaops.h>
  27#include <linux/vfs.h>
  28#include <linux/mount.h>
  29#include <linux/namei.h>
  30#include <linux/crc32.h>
 
  31
  32struct file_system_type reiserfs_fs_type;
  33
  34static const char reiserfs_3_5_magic_string[] = REISERFS_SUPER_MAGIC_STRING;
  35static const char reiserfs_3_6_magic_string[] = REISER2FS_SUPER_MAGIC_STRING;
  36static const char reiserfs_jr_magic_string[] = REISER2FS_JR_SUPER_MAGIC_STRING;
  37
  38int is_reiserfs_3_5(struct reiserfs_super_block *rs)
  39{
  40	return !strncmp(rs->s_v1.s_magic, reiserfs_3_5_magic_string,
  41			strlen(reiserfs_3_5_magic_string));
  42}
  43
  44int is_reiserfs_3_6(struct reiserfs_super_block *rs)
  45{
  46	return !strncmp(rs->s_v1.s_magic, reiserfs_3_6_magic_string,
  47			strlen(reiserfs_3_6_magic_string));
  48}
  49
  50int is_reiserfs_jr(struct reiserfs_super_block *rs)
  51{
  52	return !strncmp(rs->s_v1.s_magic, reiserfs_jr_magic_string,
  53			strlen(reiserfs_jr_magic_string));
  54}
  55
  56static int is_any_reiserfs_magic_string(struct reiserfs_super_block *rs)
  57{
  58	return (is_reiserfs_3_5(rs) || is_reiserfs_3_6(rs) ||
  59		is_reiserfs_jr(rs));
  60}
  61
  62static int reiserfs_remount(struct super_block *s, int *flags, char *data);
  63static int reiserfs_statfs(struct dentry *dentry, struct kstatfs *buf);
  64
  65static int reiserfs_sync_fs(struct super_block *s, int wait)
  66{
  67	struct reiserfs_transaction_handle th;
  68
 
 
 
 
 
  69	reiserfs_write_lock(s);
  70	if (!journal_begin(&th, s, 1))
  71		if (!journal_end_sync(&th, s, 1))
  72			reiserfs_flush_old_commits(s);
  73	s->s_dirt = 0;	/* Even if it's not true.
  74			 * We'll loop forever in sync_supers otherwise */
  75	reiserfs_write_unlock(s);
  76	return 0;
  77}
  78
  79static void reiserfs_write_super(struct super_block *s)
  80{
 
 
 
 
 
 
 
 
 
 
  81	reiserfs_sync_fs(s, 1);
  82}
  83
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  84static int reiserfs_freeze(struct super_block *s)
  85{
  86	struct reiserfs_transaction_handle th;
 
 
 
  87	reiserfs_write_lock(s);
  88	if (!(s->s_flags & MS_RDONLY)) {
  89		int err = journal_begin(&th, s, 1);
  90		if (err) {
  91			reiserfs_block_writes(&th);
  92		} else {
  93			reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s),
  94						     1);
  95			journal_mark_dirty(&th, s, SB_BUFFER_WITH_SB(s));
  96			reiserfs_block_writes(&th);
  97			journal_end_sync(&th, s, 1);
  98		}
  99	}
 100	s->s_dirt = 0;
 101	reiserfs_write_unlock(s);
 102	return 0;
 103}
 104
 105static int reiserfs_unfreeze(struct super_block *s)
 106{
 107	reiserfs_allow_writes(s);
 108	return 0;
 109}
 110
 111extern const struct in_core_key MAX_IN_CORE_KEY;
 112
 113/* this is used to delete "save link" when there are no items of a
 114   file it points to. It can either happen if unlink is completed but
 115   "save unlink" removal, or if file has both unlink and truncate
 116   pending and as unlink completes first (because key of "save link"
 117   protecting unlink is bigger that a key lf "save link" which
 118   protects truncate), so there left no items to make truncate
 119   completion on */
 
 
 120static int remove_save_link_only(struct super_block *s,
 121				 struct reiserfs_key *key, int oid_free)
 122{
 123	struct reiserfs_transaction_handle th;
 124	int err;
 125
 126	/* we are going to do one balancing */
 127	err = journal_begin(&th, s, JOURNAL_PER_BALANCE_CNT);
 128	if (err)
 129		return err;
 130
 131	reiserfs_delete_solid_item(&th, NULL, key);
 132	if (oid_free)
 133		/* removals are protected by direct items */
 134		reiserfs_release_objectid(&th, le32_to_cpu(key->k_objectid));
 135
 136	return journal_end(&th, s, JOURNAL_PER_BALANCE_CNT);
 137}
 138
 139#ifdef CONFIG_QUOTA
 140static int reiserfs_quota_on_mount(struct super_block *, int);
 141#endif
 142
 143/* look for uncompleted unlinks and truncates and complete them */
 144static int finish_unfinished(struct super_block *s)
 145{
 146	INITIALIZE_PATH(path);
 147	struct cpu_key max_cpu_key, obj_key;
 148	struct reiserfs_key save_link_key, last_inode_key;
 149	int retval = 0;
 150	struct item_head *ih;
 151	struct buffer_head *bh;
 152	int item_pos;
 153	char *item;
 154	int done;
 155	struct inode *inode;
 156	int truncate;
 157#ifdef CONFIG_QUOTA
 158	int i;
 159	int ms_active_set;
 160	int quota_enabled[MAXQUOTAS];
 161#endif
 162
 163	/* compose key to look for "save" links */
 164	max_cpu_key.version = KEY_FORMAT_3_5;
 165	max_cpu_key.on_disk_key.k_dir_id = ~0U;
 166	max_cpu_key.on_disk_key.k_objectid = ~0U;
 167	set_cpu_key_k_offset(&max_cpu_key, ~0U);
 168	max_cpu_key.key_length = 3;
 169
 170	memset(&last_inode_key, 0, sizeof(last_inode_key));
 171
 172#ifdef CONFIG_QUOTA
 173	/* Needed for iput() to work correctly and not trash data */
 174	if (s->s_flags & MS_ACTIVE) {
 175		ms_active_set = 0;
 176	} else {
 177		ms_active_set = 1;
 178		s->s_flags |= MS_ACTIVE;
 179	}
 180	/* Turn on quotas so that they are updated correctly */
 181	for (i = 0; i < MAXQUOTAS; i++) {
 182		quota_enabled[i] = 1;
 183		if (REISERFS_SB(s)->s_qf_names[i]) {
 184			int ret;
 185
 186			if (sb_has_quota_active(s, i)) {
 187				quota_enabled[i] = 0;
 188				continue;
 189			}
 190			ret = reiserfs_quota_on_mount(s, i);
 191			if (ret < 0)
 192				reiserfs_warning(s, "reiserfs-2500",
 193						 "cannot turn on journaled "
 194						 "quota: error %d", ret);
 195		}
 196	}
 197#endif
 198
 199	done = 0;
 200	REISERFS_SB(s)->s_is_unlinked_ok = 1;
 201	while (!retval) {
 
 202		retval = search_item(s, &max_cpu_key, &path);
 203		if (retval != ITEM_NOT_FOUND) {
 204			reiserfs_error(s, "vs-2140",
 205				       "search_by_key returned %d", retval);
 206			break;
 207		}
 208
 209		bh = get_last_bh(&path);
 210		item_pos = get_item_pos(&path);
 211		if (item_pos != B_NR_ITEMS(bh)) {
 212			reiserfs_warning(s, "vs-2060",
 213					 "wrong position found");
 214			break;
 215		}
 216		item_pos--;
 217		ih = B_N_PITEM_HEAD(bh, item_pos);
 218
 219		if (le32_to_cpu(ih->ih_key.k_dir_id) != MAX_KEY_OBJECTID)
 220			/* there are no "save" links anymore */
 221			break;
 222
 223		save_link_key = ih->ih_key;
 224		if (is_indirect_le_ih(ih))
 225			truncate = 1;
 226		else
 227			truncate = 0;
 228
 229		/* reiserfs_iget needs k_dirid and k_objectid only */
 230		item = B_I_PITEM(bh, ih);
 231		obj_key.on_disk_key.k_dir_id = le32_to_cpu(*(__le32 *) item);
 232		obj_key.on_disk_key.k_objectid =
 233		    le32_to_cpu(ih->ih_key.k_objectid);
 234		obj_key.on_disk_key.k_offset = 0;
 235		obj_key.on_disk_key.k_type = 0;
 236
 237		pathrelse(&path);
 238
 239		inode = reiserfs_iget(s, &obj_key);
 240		if (!inode) {
 241			/* the unlink almost completed, it just did not manage to remove
 242			   "save" link and release objectid */
 
 
 243			reiserfs_warning(s, "vs-2180", "iget failed for %K",
 244					 &obj_key);
 245			retval = remove_save_link_only(s, &save_link_key, 1);
 246			continue;
 247		}
 248
 249		if (!truncate && inode->i_nlink) {
 250			/* file is not unlinked */
 251			reiserfs_warning(s, "vs-2185",
 252					 "file %K is not unlinked",
 253					 &obj_key);
 254			retval = remove_save_link_only(s, &save_link_key, 0);
 255			continue;
 256		}
 
 257		dquot_initialize(inode);
 
 258
 259		if (truncate && S_ISDIR(inode->i_mode)) {
 260			/* We got a truncate request for a dir which is impossible.
 261			   The only imaginable way is to execute unfinished truncate request
 262			   then boot into old kernel, remove the file and create dir with
 263			   the same key. */
 
 
 
 264			reiserfs_warning(s, "green-2101",
 265					 "impossible truncate on a "
 266					 "directory %k. Please report",
 267					 INODE_PKEY(inode));
 268			retval = remove_save_link_only(s, &save_link_key, 0);
 269			truncate = 0;
 270			iput(inode);
 271			continue;
 272		}
 273
 274		if (truncate) {
 275			REISERFS_I(inode)->i_flags |=
 276			    i_link_saved_truncate_mask;
 277			/* not completed truncate found. New size was committed together
 278			   with "save" link */
 279			reiserfs_info(s, "Truncating %k to %Ld ..",
 
 
 280				      INODE_PKEY(inode), inode->i_size);
 281			reiserfs_truncate_file(inode,
 282					       0
 283					       /*don't update modification time */
 284					       );
 285			retval = remove_save_link(inode, truncate);
 286		} else {
 287			REISERFS_I(inode)->i_flags |= i_link_saved_unlink_mask;
 288			/* not completed unlink (rmdir) found */
 289			reiserfs_info(s, "Removing %k..", INODE_PKEY(inode));
 290			if (memcmp(&last_inode_key, INODE_PKEY(inode),
 291					sizeof(last_inode_key))){
 292				last_inode_key = *INODE_PKEY(inode);
 293				/* removal gets completed in iput */
 294				retval = 0;
 295			} else {
 296				reiserfs_warning(s, "super-2189", "Dead loop "
 297						 "in finish_unfinished "
 298						 "detected, just remove "
 299						 "save link\n");
 300				retval = remove_save_link_only(s,
 301							&save_link_key, 0);
 302			}
 303		}
 304
 305		iput(inode);
 306		printk("done\n");
 307		done++;
 308	}
 309	REISERFS_SB(s)->s_is_unlinked_ok = 0;
 310
 311#ifdef CONFIG_QUOTA
 312	/* Turn quotas off */
 313	for (i = 0; i < MAXQUOTAS; i++) {
 
 314		if (sb_dqopt(s)->files[i] && quota_enabled[i])
 315			dquot_quota_off(s, i);
 316	}
 
 317	if (ms_active_set)
 318		/* Restore the flag back */
 319		s->s_flags &= ~MS_ACTIVE;
 320#endif
 321	pathrelse(&path);
 322	if (done)
 323		reiserfs_info(s, "There were %d uncompleted unlinks/truncates. "
 324			      "Completed\n", done);
 325	return retval;
 326}
 327
 328/* to protect file being unlinked from getting lost we "safe" link files
 329   being unlinked. This link will be deleted in the same transaction with last
 330   item of file. mounting the filesystem we scan all these links and remove
 331   files which almost got lost */
 
 
 332void add_save_link(struct reiserfs_transaction_handle *th,
 333		   struct inode *inode, int truncate)
 334{
 335	INITIALIZE_PATH(path);
 336	int retval;
 337	struct cpu_key key;
 338	struct item_head ih;
 339	__le32 link;
 340
 341	BUG_ON(!th->t_trans_id);
 342
 343	/* file can only get one "save link" of each kind */
 344	RFALSE(truncate &&
 345	       (REISERFS_I(inode)->i_flags & i_link_saved_truncate_mask),
 346	       "saved link already exists for truncated inode %lx",
 347	       (long)inode->i_ino);
 348	RFALSE(!truncate &&
 349	       (REISERFS_I(inode)->i_flags & i_link_saved_unlink_mask),
 350	       "saved link already exists for unlinked inode %lx",
 351	       (long)inode->i_ino);
 352
 353	/* setup key of "save" link */
 354	key.version = KEY_FORMAT_3_5;
 355	key.on_disk_key.k_dir_id = MAX_KEY_OBJECTID;
 356	key.on_disk_key.k_objectid = inode->i_ino;
 357	if (!truncate) {
 358		/* unlink, rmdir, rename */
 359		set_cpu_key_k_offset(&key, 1 + inode->i_sb->s_blocksize);
 360		set_cpu_key_k_type(&key, TYPE_DIRECT);
 361
 362		/* item head of "safe" link */
 363		make_le_item_head(&ih, &key, key.version,
 364				  1 + inode->i_sb->s_blocksize, TYPE_DIRECT,
 365				  4 /*length */ , 0xffff /*free space */ );
 366	} else {
 367		/* truncate */
 368		if (S_ISDIR(inode->i_mode))
 369			reiserfs_warning(inode->i_sb, "green-2102",
 370					 "Adding a truncate savelink for "
 371					 "a directory %k! Please report",
 372					 INODE_PKEY(inode));
 373		set_cpu_key_k_offset(&key, 1);
 374		set_cpu_key_k_type(&key, TYPE_INDIRECT);
 375
 376		/* item head of "safe" link */
 377		make_le_item_head(&ih, &key, key.version, 1, TYPE_INDIRECT,
 378				  4 /*length */ , 0 /*free space */ );
 379	}
 380	key.key_length = 3;
 381
 382	/* look for its place in the tree */
 383	retval = search_item(inode->i_sb, &key, &path);
 384	if (retval != ITEM_NOT_FOUND) {
 385		if (retval != -ENOSPC)
 386			reiserfs_error(inode->i_sb, "vs-2100",
 387				       "search_by_key (%K) returned %d", &key,
 388				       retval);
 389		pathrelse(&path);
 390		return;
 391	}
 392
 393	/* body of "save" link */
 394	link = INODE_PKEY(inode)->k_dir_id;
 395
 396	/* put "save" link into tree, don't charge quota to anyone */
 397	retval =
 398	    reiserfs_insert_item(th, &path, &key, &ih, NULL, (char *)&link);
 399	if (retval) {
 400		if (retval != -ENOSPC)
 401			reiserfs_error(inode->i_sb, "vs-2120",
 402				       "insert_item returned %d", retval);
 403	} else {
 404		if (truncate)
 405			REISERFS_I(inode)->i_flags |=
 406			    i_link_saved_truncate_mask;
 407		else
 408			REISERFS_I(inode)->i_flags |= i_link_saved_unlink_mask;
 409	}
 410}
 411
 412/* this opens transaction unlike add_save_link */
 413int remove_save_link(struct inode *inode, int truncate)
 414{
 415	struct reiserfs_transaction_handle th;
 416	struct reiserfs_key key;
 417	int err;
 418
 419	/* we are going to do one balancing only */
 420	err = journal_begin(&th, inode->i_sb, JOURNAL_PER_BALANCE_CNT);
 421	if (err)
 422		return err;
 423
 424	/* setup key of "save" link */
 425	key.k_dir_id = cpu_to_le32(MAX_KEY_OBJECTID);
 426	key.k_objectid = INODE_PKEY(inode)->k_objectid;
 427	if (!truncate) {
 428		/* unlink, rmdir, rename */
 429		set_le_key_k_offset(KEY_FORMAT_3_5, &key,
 430				    1 + inode->i_sb->s_blocksize);
 431		set_le_key_k_type(KEY_FORMAT_3_5, &key, TYPE_DIRECT);
 432	} else {
 433		/* truncate */
 434		set_le_key_k_offset(KEY_FORMAT_3_5, &key, 1);
 435		set_le_key_k_type(KEY_FORMAT_3_5, &key, TYPE_INDIRECT);
 436	}
 437
 438	if ((truncate &&
 439	     (REISERFS_I(inode)->i_flags & i_link_saved_truncate_mask)) ||
 440	    (!truncate &&
 441	     (REISERFS_I(inode)->i_flags & i_link_saved_unlink_mask)))
 442		/* don't take quota bytes from anywhere */
 443		reiserfs_delete_solid_item(&th, NULL, &key);
 444	if (!truncate) {
 445		reiserfs_release_objectid(&th, inode->i_ino);
 446		REISERFS_I(inode)->i_flags &= ~i_link_saved_unlink_mask;
 447	} else
 448		REISERFS_I(inode)->i_flags &= ~i_link_saved_truncate_mask;
 449
 450	return journal_end(&th, inode->i_sb, JOURNAL_PER_BALANCE_CNT);
 451}
 452
 453static void reiserfs_kill_sb(struct super_block *s)
 454{
 455	if (REISERFS_SB(s)) {
 456		if (REISERFS_SB(s)->xattr_root) {
 457			d_invalidate(REISERFS_SB(s)->xattr_root);
 458			dput(REISERFS_SB(s)->xattr_root);
 459			REISERFS_SB(s)->xattr_root = NULL;
 460		}
 461		if (REISERFS_SB(s)->priv_root) {
 462			d_invalidate(REISERFS_SB(s)->priv_root);
 463			dput(REISERFS_SB(s)->priv_root);
 464			REISERFS_SB(s)->priv_root = NULL;
 465		}
 
 
 
 
 
 466	}
 467
 468	kill_block_super(s);
 469}
 470
 471static void reiserfs_put_super(struct super_block *s)
 472{
 473	struct reiserfs_transaction_handle th;
 474	th.t_trans_id = 0;
 475
 476	dquot_disable(s, -1, DQUOT_USAGE_ENABLED | DQUOT_LIMITS_ENABLED);
 477
 478	reiserfs_write_lock(s);
 479
 480	if (s->s_dirt)
 481		reiserfs_write_super(s);
 482
 483	/* change file system state to current state if it was mounted with read-write permissions */
 484	if (!(s->s_flags & MS_RDONLY)) {
 485		if (!journal_begin(&th, s, 10)) {
 486			reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s),
 487						     1);
 488			set_sb_umount_state(SB_DISK_SUPER_BLOCK(s),
 489					    REISERFS_SB(s)->s_mount_state);
 490			journal_mark_dirty(&th, s, SB_BUFFER_WITH_SB(s));
 491		}
 492	}
 493
 494	/* note, journal_release checks for readonly mount, and can decide not
 495	 ** to do a journal_end
 
 496	 */
 497	journal_release(&th, s);
 498
 499	reiserfs_free_bitmap_cache(s);
 500
 501	brelse(SB_BUFFER_WITH_SB(s));
 502
 503	print_statistics(s);
 504
 505	if (REISERFS_SB(s)->reserved_blocks != 0) {
 506		reiserfs_warning(s, "green-2005", "reserved blocks left %d",
 507				 REISERFS_SB(s)->reserved_blocks);
 508	}
 509
 510	reiserfs_proc_info_done(s);
 511
 512	reiserfs_write_unlock(s);
 513	mutex_destroy(&REISERFS_SB(s)->lock);
 
 514	kfree(s->s_fs_info);
 515	s->s_fs_info = NULL;
 516}
 517
 518static struct kmem_cache *reiserfs_inode_cachep;
 519
 520static struct inode *reiserfs_alloc_inode(struct super_block *sb)
 521{
 522	struct reiserfs_inode_info *ei;
 523	ei = (struct reiserfs_inode_info *)
 524	    kmem_cache_alloc(reiserfs_inode_cachep, GFP_KERNEL);
 525	if (!ei)
 526		return NULL;
 527	atomic_set(&ei->openers, 0);
 528	mutex_init(&ei->tailpack);
 
 
 
 
 529	return &ei->vfs_inode;
 530}
 531
 532static void reiserfs_i_callback(struct rcu_head *head)
 533{
 534	struct inode *inode = container_of(head, struct inode, i_rcu);
 535	INIT_LIST_HEAD(&inode->i_dentry);
 536	kmem_cache_free(reiserfs_inode_cachep, REISERFS_I(inode));
 537}
 538
 539static void reiserfs_destroy_inode(struct inode *inode)
 540{
 541	call_rcu(&inode->i_rcu, reiserfs_i_callback);
 542}
 543
 544static void init_once(void *foo)
 545{
 546	struct reiserfs_inode_info *ei = (struct reiserfs_inode_info *)foo;
 547
 548	INIT_LIST_HEAD(&ei->i_prealloc_list);
 549	inode_init_once(&ei->vfs_inode);
 550}
 551
 552static int init_inodecache(void)
 553{
 554	reiserfs_inode_cachep = kmem_cache_create("reiser_inode_cache",
 555						  sizeof(struct
 556							 reiserfs_inode_info),
 557						  0, (SLAB_RECLAIM_ACCOUNT|
 558							SLAB_MEM_SPREAD),
 
 559						  init_once);
 560	if (reiserfs_inode_cachep == NULL)
 561		return -ENOMEM;
 562	return 0;
 563}
 564
 565static void destroy_inodecache(void)
 566{
 
 
 
 
 
 567	kmem_cache_destroy(reiserfs_inode_cachep);
 568}
 569
 570/* we don't mark inodes dirty, we just log them */
 571static void reiserfs_dirty_inode(struct inode *inode, int flags)
 572{
 573	struct reiserfs_transaction_handle th;
 574
 575	int err = 0;
 576	int lock_depth;
 577
 578	if (inode->i_sb->s_flags & MS_RDONLY) {
 579		reiserfs_warning(inode->i_sb, "clm-6006",
 580				 "writing inode %lu on readonly FS",
 581				 inode->i_ino);
 582		return;
 583	}
 584	lock_depth = reiserfs_write_lock_once(inode->i_sb);
 585
 586	/* this is really only used for atime updates, so they don't have
 587	 ** to be included in O_SYNC or fsync
 
 588	 */
 589	err = journal_begin(&th, inode->i_sb, 1);
 590	if (err)
 591		goto out;
 592
 593	reiserfs_update_sd(&th, inode);
 594	journal_end(&th, inode->i_sb, 1);
 595
 596out:
 597	reiserfs_write_unlock_once(inode->i_sb, lock_depth);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 598}
 599
 600#ifdef CONFIG_QUOTA
 601static ssize_t reiserfs_quota_write(struct super_block *, int, const char *,
 602				    size_t, loff_t);
 603static ssize_t reiserfs_quota_read(struct super_block *, int, char *, size_t,
 604				   loff_t);
 
 
 
 
 
 605#endif
 606
 607static const struct super_operations reiserfs_sops = {
 608	.alloc_inode = reiserfs_alloc_inode,
 609	.destroy_inode = reiserfs_destroy_inode,
 610	.write_inode = reiserfs_write_inode,
 611	.dirty_inode = reiserfs_dirty_inode,
 612	.evict_inode = reiserfs_evict_inode,
 613	.put_super = reiserfs_put_super,
 614	.write_super = reiserfs_write_super,
 615	.sync_fs = reiserfs_sync_fs,
 616	.freeze_fs = reiserfs_freeze,
 617	.unfreeze_fs = reiserfs_unfreeze,
 618	.statfs = reiserfs_statfs,
 619	.remount_fs = reiserfs_remount,
 620	.show_options = generic_show_options,
 621#ifdef CONFIG_QUOTA
 622	.quota_read = reiserfs_quota_read,
 623	.quota_write = reiserfs_quota_write,
 
 624#endif
 625};
 626
 627#ifdef CONFIG_QUOTA
 628#define QTYPE2NAME(t) ((t)==USRQUOTA?"user":"group")
 629
 630static int reiserfs_write_dquot(struct dquot *);
 631static int reiserfs_acquire_dquot(struct dquot *);
 632static int reiserfs_release_dquot(struct dquot *);
 633static int reiserfs_mark_dquot_dirty(struct dquot *);
 634static int reiserfs_write_info(struct super_block *, int);
 635static int reiserfs_quota_on(struct super_block *, int, int, struct path *);
 636
 637static const struct dquot_operations reiserfs_quota_operations = {
 638	.write_dquot = reiserfs_write_dquot,
 639	.acquire_dquot = reiserfs_acquire_dquot,
 640	.release_dquot = reiserfs_release_dquot,
 641	.mark_dirty = reiserfs_mark_dquot_dirty,
 642	.write_info = reiserfs_write_info,
 643	.alloc_dquot	= dquot_alloc,
 644	.destroy_dquot	= dquot_destroy,
 
 645};
 646
 647static const struct quotactl_ops reiserfs_qctl_operations = {
 648	.quota_on = reiserfs_quota_on,
 649	.quota_off = dquot_quota_off,
 650	.quota_sync = dquot_quota_sync,
 651	.get_info = dquot_get_dqinfo,
 652	.set_info = dquot_set_dqinfo,
 653	.get_dqblk = dquot_get_dqblk,
 654	.set_dqblk = dquot_set_dqblk,
 655};
 656#endif
 657
 658static const struct export_operations reiserfs_export_ops = {
 659	.encode_fh = reiserfs_encode_fh,
 660	.fh_to_dentry = reiserfs_fh_to_dentry,
 661	.fh_to_parent = reiserfs_fh_to_parent,
 662	.get_parent = reiserfs_get_parent,
 663};
 664
 665/* this struct is used in reiserfs_getopt () for containing the value for those
 666   mount options that have values rather than being toggles. */
 
 
 667typedef struct {
 668	char *value;
 669	int setmask;		/* bitmask which is to set on mount_options bitmask when this
 670				   value is found, 0 is no bits are to be changed. */
 671	int clrmask;		/* bitmask which is to clear on mount_options bitmask when  this
 672				   value is found, 0 is no bits are to be changed. This is
 673				   applied BEFORE setmask */
 
 
 
 
 
 
 674} arg_desc_t;
 675
 676/* Set this bit in arg_required to allow empty arguments */
 677#define REISERFS_OPT_ALLOWEMPTY 31
 678
 679/* this struct is used in reiserfs_getopt() for describing the set of reiserfs
 680   mount options */
 
 
 681typedef struct {
 682	char *option_name;
 683	int arg_required;	/* 0 if argument is not required, not 0 otherwise */
 684	const arg_desc_t *values;	/* list of values accepted by an option */
 685	int setmask;		/* bitmask which is to set on mount_options bitmask when this
 686				   value is found, 0 is no bits are to be changed. */
 687	int clrmask;		/* bitmask which is to clear on mount_options bitmask when  this
 688				   value is found, 0 is no bits are to be changed. This is
 689				   applied BEFORE setmask */
 
 
 
 
 
 
 
 
 
 
 
 
 690} opt_desc_t;
 691
 692/* possible values for -o data= */
 693static const arg_desc_t logging_mode[] = {
 694	{"ordered", 1 << REISERFS_DATA_ORDERED,
 695	 (1 << REISERFS_DATA_LOG | 1 << REISERFS_DATA_WRITEBACK)},
 696	{"journal", 1 << REISERFS_DATA_LOG,
 697	 (1 << REISERFS_DATA_ORDERED | 1 << REISERFS_DATA_WRITEBACK)},
 698	{"writeback", 1 << REISERFS_DATA_WRITEBACK,
 699	 (1 << REISERFS_DATA_ORDERED | 1 << REISERFS_DATA_LOG)},
 700	{.value = NULL}
 701};
 702
 703/* possible values for -o barrier= */
 704static const arg_desc_t barrier_mode[] = {
 705	{"none", 1 << REISERFS_BARRIER_NONE, 1 << REISERFS_BARRIER_FLUSH},
 706	{"flush", 1 << REISERFS_BARRIER_FLUSH, 1 << REISERFS_BARRIER_NONE},
 707	{.value = NULL}
 708};
 709
 710/* possible values for "-o block-allocator=" and bits which are to be set in
 711   s_mount_opt of reiserfs specific part of in-core super block */
 
 
 712static const arg_desc_t balloc[] = {
 713	{"noborder", 1 << REISERFS_NO_BORDER, 0},
 714	{"border", 0, 1 << REISERFS_NO_BORDER},
 715	{"no_unhashed_relocation", 1 << REISERFS_NO_UNHASHED_RELOCATION, 0},
 716	{"hashed_relocation", 1 << REISERFS_HASHED_RELOCATION, 0},
 717	{"test4", 1 << REISERFS_TEST4, 0},
 718	{"notest4", 0, 1 << REISERFS_TEST4},
 719	{NULL, 0, 0}
 720};
 721
 722static const arg_desc_t tails[] = {
 723	{"on", 1 << REISERFS_LARGETAIL, 1 << REISERFS_SMALLTAIL},
 724	{"off", 0, (1 << REISERFS_LARGETAIL) | (1 << REISERFS_SMALLTAIL)},
 725	{"small", 1 << REISERFS_SMALLTAIL, 1 << REISERFS_LARGETAIL},
 726	{NULL, 0, 0}
 727};
 728
 729static const arg_desc_t error_actions[] = {
 730	{"panic", 1 << REISERFS_ERROR_PANIC,
 731	 (1 << REISERFS_ERROR_RO | 1 << REISERFS_ERROR_CONTINUE)},
 732	{"ro-remount", 1 << REISERFS_ERROR_RO,
 733	 (1 << REISERFS_ERROR_PANIC | 1 << REISERFS_ERROR_CONTINUE)},
 734#ifdef REISERFS_JOURNAL_ERROR_ALLOWS_NO_LOG
 735	{"continue", 1 << REISERFS_ERROR_CONTINUE,
 736	 (1 << REISERFS_ERROR_PANIC | 1 << REISERFS_ERROR_RO)},
 737#endif
 738	{NULL, 0, 0},
 739};
 740
 741/* proceed only one option from a list *cur - string containing of mount options
 742   opts - array of options which are accepted
 743   opt_arg - if option is found and requires an argument and if it is specifed
 744   in the input - pointer to the argument is stored here
 745   bit_flags - if option requires to set a certain bit - it is set here
 746   return -1 if unknown option is found, opt->arg_required otherwise */
 
 
 
 747static int reiserfs_getopt(struct super_block *s, char **cur, opt_desc_t * opts,
 748			   char **opt_arg, unsigned long *bit_flags)
 749{
 750	char *p;
 751	/* foo=bar,
 752	   ^   ^  ^
 753	   |   |  +-- option_end
 754	   |   +-- arg_start
 755	   +-- option_start
 
 756	 */
 757	const opt_desc_t *opt;
 758	const arg_desc_t *arg;
 759
 760	p = *cur;
 761
 762	/* assume argument cannot contain commas */
 763	*cur = strchr(p, ',');
 764	if (*cur) {
 765		*(*cur) = '\0';
 766		(*cur)++;
 767	}
 768
 769	if (!strncmp(p, "alloc=", 6)) {
 770		/* Ugly special case, probably we should redo options parser so that
 771		   it can understand several arguments for some options, also so that
 772		   it can fill several bitfields with option values. */
 
 
 
 773		if (reiserfs_parse_alloc_options(s, p + 6)) {
 774			return -1;
 775		} else {
 776			return 0;
 777		}
 778	}
 779
 780	/* for every option in the list */
 781	for (opt = opts; opt->option_name; opt++) {
 782		if (!strncmp(p, opt->option_name, strlen(opt->option_name))) {
 783			if (bit_flags) {
 784				if (opt->clrmask ==
 785				    (1 << REISERFS_UNSUPPORTED_OPT))
 786					reiserfs_warning(s, "super-6500",
 787							 "%s not supported.\n",
 788							 p);
 789				else
 790					*bit_flags &= ~opt->clrmask;
 791				if (opt->setmask ==
 792				    (1 << REISERFS_UNSUPPORTED_OPT))
 793					reiserfs_warning(s, "super-6501",
 794							 "%s not supported.\n",
 795							 p);
 796				else
 797					*bit_flags |= opt->setmask;
 798			}
 799			break;
 800		}
 801	}
 802	if (!opt->option_name) {
 803		reiserfs_warning(s, "super-6502",
 804				 "unknown mount option \"%s\"", p);
 805		return -1;
 806	}
 807
 808	p += strlen(opt->option_name);
 809	switch (*p) {
 810	case '=':
 811		if (!opt->arg_required) {
 812			reiserfs_warning(s, "super-6503",
 813					 "the option \"%s\" does not "
 814					 "require an argument\n",
 815					 opt->option_name);
 816			return -1;
 817		}
 818		break;
 819
 820	case 0:
 821		if (opt->arg_required) {
 822			reiserfs_warning(s, "super-6504",
 823					 "the option \"%s\" requires an "
 824					 "argument\n", opt->option_name);
 825			return -1;
 826		}
 827		break;
 828	default:
 829		reiserfs_warning(s, "super-6505",
 830				 "head of option \"%s\" is only correct\n",
 831				 opt->option_name);
 832		return -1;
 833	}
 834
 835	/* move to the argument, or to next option if argument is not required */
 
 
 
 836	p++;
 837
 838	if (opt->arg_required
 839	    && !(opt->arg_required & (1 << REISERFS_OPT_ALLOWEMPTY))
 840	    && !strlen(p)) {
 841		/* this catches "option=," if not allowed */
 842		reiserfs_warning(s, "super-6506",
 843				 "empty argument for \"%s\"\n",
 844				 opt->option_name);
 845		return -1;
 846	}
 847
 848	if (!opt->values) {
 849		/* *=NULLopt_arg contains pointer to argument */
 850		*opt_arg = p;
 851		return opt->arg_required & ~(1 << REISERFS_OPT_ALLOWEMPTY);
 852	}
 853
 854	/* values possible for this option are listed in opt->values */
 855	for (arg = opt->values; arg->value; arg++) {
 856		if (!strcmp(p, arg->value)) {
 857			if (bit_flags) {
 858				*bit_flags &= ~arg->clrmask;
 859				*bit_flags |= arg->setmask;
 860			}
 861			return opt->arg_required;
 862		}
 863	}
 864
 865	reiserfs_warning(s, "super-6506",
 866			 "bad value \"%s\" for option \"%s\"\n", p,
 867			 opt->option_name);
 868	return -1;
 869}
 870
 871/* returns 0 if something is wrong in option string, 1 - otherwise */
 872static int reiserfs_parse_options(struct super_block *s, char *options,	/* string given via mount's -o */
 
 
 
 
 
 
 
 
 
 873				  unsigned long *mount_options,
 874				  /* after the parsing phase, contains the
 875				     collection of bitflags defining what
 876				     mount options were selected. */
 877				  unsigned long *blocks,	/* strtol-ed from NNN of resize=NNN */
 878				  char **jdev_name,
 879				  unsigned int *commit_max_age,
 880				  char **qf_names,
 881				  unsigned int *qfmt)
 882{
 883	int c;
 884	char *arg = NULL;
 885	char *pos;
 886	opt_desc_t opts[] = {
 887		/* Compatibility stuff, so that -o notail for old setups still work */
 
 
 
 888		{"tails",.arg_required = 't',.values = tails},
 889		{"notail",.clrmask =
 890		 (1 << REISERFS_LARGETAIL) | (1 << REISERFS_SMALLTAIL)},
 891		{"conv",.setmask = 1 << REISERFS_CONVERT},
 892		{"attrs",.setmask = 1 << REISERFS_ATTRS},
 893		{"noattrs",.clrmask = 1 << REISERFS_ATTRS},
 894		{"expose_privroot", .setmask = 1 << REISERFS_EXPOSE_PRIVROOT},
 895#ifdef CONFIG_REISERFS_FS_XATTR
 896		{"user_xattr",.setmask = 1 << REISERFS_XATTRS_USER},
 897		{"nouser_xattr",.clrmask = 1 << REISERFS_XATTRS_USER},
 898#else
 899		{"user_xattr",.setmask = 1 << REISERFS_UNSUPPORTED_OPT},
 900		{"nouser_xattr",.clrmask = 1 << REISERFS_UNSUPPORTED_OPT},
 901#endif
 902#ifdef CONFIG_REISERFS_FS_POSIX_ACL
 903		{"acl",.setmask = 1 << REISERFS_POSIXACL},
 904		{"noacl",.clrmask = 1 << REISERFS_POSIXACL},
 905#else
 906		{"acl",.setmask = 1 << REISERFS_UNSUPPORTED_OPT},
 907		{"noacl",.clrmask = 1 << REISERFS_UNSUPPORTED_OPT},
 908#endif
 909		{.option_name = "nolog"},
 910		{"replayonly",.setmask = 1 << REPLAYONLY},
 911		{"block-allocator",.arg_required = 'a',.values = balloc},
 912		{"data",.arg_required = 'd',.values = logging_mode},
 913		{"barrier",.arg_required = 'b',.values = barrier_mode},
 914		{"resize",.arg_required = 'r',.values = NULL},
 915		{"jdev",.arg_required = 'j',.values = NULL},
 916		{"nolargeio",.arg_required = 'w',.values = NULL},
 917		{"commit",.arg_required = 'c',.values = NULL},
 918		{"usrquota",.setmask = 1 << REISERFS_QUOTA},
 919		{"grpquota",.setmask = 1 << REISERFS_QUOTA},
 920		{"noquota",.clrmask = 1 << REISERFS_QUOTA},
 921		{"errors",.arg_required = 'e',.values = error_actions},
 922		{"usrjquota",.arg_required =
 923		 'u' | (1 << REISERFS_OPT_ALLOWEMPTY),.values = NULL},
 924		{"grpjquota",.arg_required =
 925		 'g' | (1 << REISERFS_OPT_ALLOWEMPTY),.values = NULL},
 926		{"jqfmt",.arg_required = 'f',.values = NULL},
 927		{.option_name = NULL}
 928	};
 929
 930	*blocks = 0;
 931	if (!options || !*options)
 932		/* use default configuration: create tails, journaling on, no
 933		   conversion to newest format */
 
 
 934		return 1;
 935
 936	for (pos = options; pos;) {
 937		c = reiserfs_getopt(s, &pos, opts, &arg, mount_options);
 938		if (c == -1)
 939			/* wrong option is given */
 940			return 0;
 941
 942		if (c == 'r') {
 943			char *p;
 944
 945			p = NULL;
 946			/* "resize=NNN" or "resize=auto" */
 947
 948			if (!strcmp(arg, "auto")) {
 949				/* From JFS code, to auto-get the size. */
 950				*blocks =
 951				    s->s_bdev->bd_inode->i_size >> s->
 952				    s_blocksize_bits;
 953			} else {
 954				*blocks = simple_strtoul(arg, &p, 0);
 955				if (*p != '\0') {
 956					/* NNN does not look like a number */
 957					reiserfs_warning(s, "super-6507",
 958							 "bad value %s for "
 959							 "-oresize\n", arg);
 960					return 0;
 961				}
 962			}
 963		}
 964
 965		if (c == 'c') {
 966			char *p = NULL;
 967			unsigned long val = simple_strtoul(arg, &p, 0);
 968			/* commit=NNN (time in seconds) */
 969			if (*p != '\0' || val >= (unsigned int)-1) {
 970				reiserfs_warning(s, "super-6508",
 971						 "bad value %s for -ocommit\n",
 972						 arg);
 973				return 0;
 974			}
 975			*commit_max_age = (unsigned int)val;
 976		}
 977
 978		if (c == 'w') {
 979			reiserfs_warning(s, "super-6509", "nolargeio option "
 980					 "is no longer supported");
 981			return 0;
 982		}
 983
 984		if (c == 'j') {
 985			if (arg && *arg && jdev_name) {
 986				if (*jdev_name) {	//Hm, already assigned?
 
 987					reiserfs_warning(s, "super-6510",
 988							 "journal device was "
 989							 "already specified to "
 990							 "be %s", *jdev_name);
 991					return 0;
 992				}
 993				*jdev_name = arg;
 994			}
 995		}
 996#ifdef CONFIG_QUOTA
 997		if (c == 'u' || c == 'g') {
 998			int qtype = c == 'u' ? USRQUOTA : GRPQUOTA;
 999
1000			if (sb_any_quota_loaded(s) &&
1001			    (!*arg != !REISERFS_SB(s)->s_qf_names[qtype])) {
1002				reiserfs_warning(s, "super-6511",
1003						 "cannot change journaled "
1004						 "quota options when quota "
1005						 "turned on.");
1006				return 0;
1007			}
1008			if (*arg) {	/* Some filename specified? */
1009				if (REISERFS_SB(s)->s_qf_names[qtype]
1010				    && strcmp(REISERFS_SB(s)->s_qf_names[qtype],
1011					      arg)) {
1012					reiserfs_warning(s, "super-6512",
1013							 "%s quota file "
1014							 "already specified.",
1015							 QTYPE2NAME(qtype));
1016					return 0;
1017				}
1018				if (strchr(arg, '/')) {
1019					reiserfs_warning(s, "super-6513",
1020							 "quotafile must be "
1021							 "on filesystem root.");
1022					return 0;
1023				}
1024				qf_names[qtype] =
1025				    kmalloc(strlen(arg) + 1, GFP_KERNEL);
1026				if (!qf_names[qtype]) {
1027					reiserfs_warning(s, "reiserfs-2502",
1028							 "not enough memory "
1029							 "for storing "
1030							 "quotafile name.");
1031					return 0;
1032				}
1033				strcpy(qf_names[qtype], arg);
1034				*mount_options |= 1 << REISERFS_QUOTA;
 
 
1035			} else {
1036				if (qf_names[qtype] !=
1037				    REISERFS_SB(s)->s_qf_names[qtype])
1038					kfree(qf_names[qtype]);
1039				qf_names[qtype] = NULL;
 
 
 
 
1040			}
1041		}
1042		if (c == 'f') {
1043			if (!strcmp(arg, "vfsold"))
1044				*qfmt = QFMT_VFS_OLD;
1045			else if (!strcmp(arg, "vfsv0"))
1046				*qfmt = QFMT_VFS_V0;
1047			else {
1048				reiserfs_warning(s, "super-6514",
1049						 "unknown quota format "
1050						 "specified.");
1051				return 0;
1052			}
1053			if (sb_any_quota_loaded(s) &&
1054			    *qfmt != REISERFS_SB(s)->s_jquota_fmt) {
1055				reiserfs_warning(s, "super-6515",
1056						 "cannot change journaled "
1057						 "quota options when quota "
1058						 "turned on.");
1059				return 0;
1060			}
1061		}
1062#else
1063		if (c == 'u' || c == 'g' || c == 'f') {
1064			reiserfs_warning(s, "reiserfs-2503", "journaled "
1065					 "quota options not supported.");
1066			return 0;
1067		}
1068#endif
1069	}
1070
1071#ifdef CONFIG_QUOTA
1072	if (!REISERFS_SB(s)->s_jquota_fmt && !*qfmt
1073	    && (qf_names[USRQUOTA] || qf_names[GRPQUOTA])) {
1074		reiserfs_warning(s, "super-6515",
1075				 "journaled quota format not specified.");
1076		return 0;
1077	}
1078	/* This checking is not precise wrt the quota type but for our purposes it is sufficient */
1079	if (!(*mount_options & (1 << REISERFS_QUOTA))
1080	    && sb_any_quota_loaded(s)) {
 
1081		reiserfs_warning(s, "super-6516", "quota options must "
1082				 "be present when quota is turned on.");
1083		return 0;
1084	}
1085#endif
1086
1087	return 1;
1088}
1089
1090static void switch_data_mode(struct super_block *s, unsigned long mode)
1091{
1092	REISERFS_SB(s)->s_mount_opt &= ~((1 << REISERFS_DATA_LOG) |
1093					 (1 << REISERFS_DATA_ORDERED) |
1094					 (1 << REISERFS_DATA_WRITEBACK));
1095	REISERFS_SB(s)->s_mount_opt |= (1 << mode);
1096}
1097
1098static void handle_data_mode(struct super_block *s, unsigned long mount_options)
1099{
1100	if (mount_options & (1 << REISERFS_DATA_LOG)) {
1101		if (!reiserfs_data_log(s)) {
1102			switch_data_mode(s, REISERFS_DATA_LOG);
1103			reiserfs_info(s, "switching to journaled data mode\n");
1104		}
1105	} else if (mount_options & (1 << REISERFS_DATA_ORDERED)) {
1106		if (!reiserfs_data_ordered(s)) {
1107			switch_data_mode(s, REISERFS_DATA_ORDERED);
1108			reiserfs_info(s, "switching to ordered data mode\n");
1109		}
1110	} else if (mount_options & (1 << REISERFS_DATA_WRITEBACK)) {
1111		if (!reiserfs_data_writeback(s)) {
1112			switch_data_mode(s, REISERFS_DATA_WRITEBACK);
1113			reiserfs_info(s, "switching to writeback data mode\n");
1114		}
1115	}
1116}
1117
1118static void handle_barrier_mode(struct super_block *s, unsigned long bits)
1119{
1120	int flush = (1 << REISERFS_BARRIER_FLUSH);
1121	int none = (1 << REISERFS_BARRIER_NONE);
1122	int all_barrier = flush | none;
1123
1124	if (bits & all_barrier) {
1125		REISERFS_SB(s)->s_mount_opt &= ~all_barrier;
1126		if (bits & flush) {
1127			REISERFS_SB(s)->s_mount_opt |= flush;
1128			printk("reiserfs: enabling write barrier flush mode\n");
1129		} else if (bits & none) {
1130			REISERFS_SB(s)->s_mount_opt |= none;
1131			printk("reiserfs: write barriers turned off\n");
1132		}
1133	}
1134}
1135
1136static void handle_attrs(struct super_block *s)
1137{
1138	struct reiserfs_super_block *rs = SB_DISK_SUPER_BLOCK(s);
1139
1140	if (reiserfs_attrs(s)) {
1141		if (old_format_only(s)) {
1142			reiserfs_warning(s, "super-6517", "cannot support "
1143					 "attributes on 3.5.x disk format");
1144			REISERFS_SB(s)->s_mount_opt &= ~(1 << REISERFS_ATTRS);
1145			return;
1146		}
1147		if (!(le32_to_cpu(rs->s_flags) & reiserfs_attrs_cleared)) {
1148			reiserfs_warning(s, "super-6518", "cannot support "
1149					 "attributes until flag is set in "
1150					 "super-block");
1151			REISERFS_SB(s)->s_mount_opt &= ~(1 << REISERFS_ATTRS);
1152		}
1153	}
1154}
1155
1156#ifdef CONFIG_QUOTA
1157static void handle_quota_files(struct super_block *s, char **qf_names,
1158			       unsigned int *qfmt)
1159{
1160	int i;
1161
1162	for (i = 0; i < MAXQUOTAS; i++) {
1163		if (qf_names[i] != REISERFS_SB(s)->s_qf_names[i])
1164			kfree(REISERFS_SB(s)->s_qf_names[i]);
1165		REISERFS_SB(s)->s_qf_names[i] = qf_names[i];
1166	}
1167	REISERFS_SB(s)->s_jquota_fmt = *qfmt;
 
1168}
1169#endif
1170
1171static int reiserfs_remount(struct super_block *s, int *mount_flags, char *arg)
1172{
1173	struct reiserfs_super_block *rs;
1174	struct reiserfs_transaction_handle th;
1175	unsigned long blocks;
1176	unsigned long mount_options = REISERFS_SB(s)->s_mount_opt;
1177	unsigned long safe_mask = 0;
1178	unsigned int commit_max_age = (unsigned int)-1;
1179	struct reiserfs_journal *journal = SB_JOURNAL(s);
1180	char *new_opts = kstrdup(arg, GFP_KERNEL);
1181	int err;
1182	char *qf_names[MAXQUOTAS];
1183	unsigned int qfmt = 0;
1184#ifdef CONFIG_QUOTA
1185	int i;
1186#endif
1187
 
1188	reiserfs_write_lock(s);
1189
1190#ifdef CONFIG_QUOTA
1191	memcpy(qf_names, REISERFS_SB(s)->s_qf_names, sizeof(qf_names));
1192#endif
1193
1194	rs = SB_DISK_SUPER_BLOCK(s);
1195
1196	if (!reiserfs_parse_options
1197	    (s, arg, &mount_options, &blocks, NULL, &commit_max_age,
1198	    qf_names, &qfmt)) {
1199#ifdef CONFIG_QUOTA
1200		for (i = 0; i < MAXQUOTAS; i++)
1201			if (qf_names[i] != REISERFS_SB(s)->s_qf_names[i])
1202				kfree(qf_names[i]);
1203#endif
1204		err = -EINVAL;
1205		goto out_err;
1206	}
1207#ifdef CONFIG_QUOTA
1208	handle_quota_files(s, qf_names, &qfmt);
1209#endif
1210
1211	handle_attrs(s);
1212
1213	/* Add options that are safe here */
1214	safe_mask |= 1 << REISERFS_SMALLTAIL;
1215	safe_mask |= 1 << REISERFS_LARGETAIL;
1216	safe_mask |= 1 << REISERFS_NO_BORDER;
1217	safe_mask |= 1 << REISERFS_NO_UNHASHED_RELOCATION;
1218	safe_mask |= 1 << REISERFS_HASHED_RELOCATION;
1219	safe_mask |= 1 << REISERFS_TEST4;
1220	safe_mask |= 1 << REISERFS_ATTRS;
1221	safe_mask |= 1 << REISERFS_XATTRS_USER;
1222	safe_mask |= 1 << REISERFS_POSIXACL;
1223	safe_mask |= 1 << REISERFS_BARRIER_FLUSH;
1224	safe_mask |= 1 << REISERFS_BARRIER_NONE;
1225	safe_mask |= 1 << REISERFS_ERROR_RO;
1226	safe_mask |= 1 << REISERFS_ERROR_CONTINUE;
1227	safe_mask |= 1 << REISERFS_ERROR_PANIC;
1228	safe_mask |= 1 << REISERFS_QUOTA;
 
1229
1230	/* Update the bitmask, taking care to keep
1231	 * the bits we're not allowed to change here */
 
 
1232	REISERFS_SB(s)->s_mount_opt =
1233	    (REISERFS_SB(s)->
1234	     s_mount_opt & ~safe_mask) | (mount_options & safe_mask);
1235
1236	if (commit_max_age != 0 && commit_max_age != (unsigned int)-1) {
1237		journal->j_max_commit_age = commit_max_age;
1238		journal->j_max_trans_age = commit_max_age;
1239	} else if (commit_max_age == 0) {
1240		/* 0 means restore defaults. */
1241		journal->j_max_commit_age = journal->j_default_max_commit_age;
1242		journal->j_max_trans_age = JOURNAL_MAX_TRANS_AGE;
1243	}
1244
1245	if (blocks) {
1246		err = reiserfs_resize(s, blocks);
1247		if (err != 0)
1248			goto out_err;
1249	}
1250
1251	if (*mount_flags & MS_RDONLY) {
 
1252		reiserfs_xattr_init(s, *mount_flags);
1253		/* remount read-only */
1254		if (s->s_flags & MS_RDONLY)
1255			/* it is read-only already */
1256			goto out_ok;
1257
1258		err = dquot_suspend(s, -1);
1259		if (err < 0)
1260			goto out_err;
1261
1262		/* try to remount file system with read-only permissions */
1263		if (sb_umount_state(rs) == REISERFS_VALID_FS
1264		    || REISERFS_SB(s)->s_mount_state != REISERFS_VALID_FS) {
1265			goto out_ok;
1266		}
1267
 
 
1268		err = journal_begin(&th, s, 10);
1269		if (err)
1270			goto out_err;
1271
1272		/* Mounting a rw partition read-only. */
1273		reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s), 1);
1274		set_sb_umount_state(rs, REISERFS_SB(s)->s_mount_state);
1275		journal_mark_dirty(&th, s, SB_BUFFER_WITH_SB(s));
1276	} else {
1277		/* remount read-write */
1278		if (!(s->s_flags & MS_RDONLY)) {
 
1279			reiserfs_xattr_init(s, *mount_flags);
1280			goto out_ok;	/* We are read-write already */
1281		}
1282
1283		if (reiserfs_is_journal_aborted(journal)) {
1284			err = journal->j_errno;
1285			goto out_err;
1286		}
1287
1288		handle_data_mode(s, mount_options);
1289		handle_barrier_mode(s, mount_options);
1290		REISERFS_SB(s)->s_mount_state = sb_umount_state(rs);
1291		s->s_flags &= ~MS_RDONLY;	/* now it is safe to call journal_begin */
 
 
1292		err = journal_begin(&th, s, 10);
1293		if (err)
1294			goto out_err;
1295
1296		/* Mount a partition which is read-only, read-write */
1297		reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s), 1);
1298		REISERFS_SB(s)->s_mount_state = sb_umount_state(rs);
1299		s->s_flags &= ~MS_RDONLY;
1300		set_sb_umount_state(rs, REISERFS_ERROR_FS);
1301		if (!old_format_only(s))
1302			set_sb_mnt_count(rs, sb_mnt_count(rs) + 1);
1303		/* mark_buffer_dirty (SB_BUFFER_WITH_SB (s), 1); */
1304		journal_mark_dirty(&th, s, SB_BUFFER_WITH_SB(s));
1305		REISERFS_SB(s)->s_mount_state = REISERFS_VALID_FS;
1306	}
1307	/* this will force a full flush of all journal lists */
1308	SB_JOURNAL(s)->j_must_wait = 1;
1309	err = journal_end(&th, s, 10);
1310	if (err)
1311		goto out_err;
1312	s->s_dirt = 0;
1313
 
1314	if (!(*mount_flags & MS_RDONLY)) {
1315		dquot_resume(s, -1);
 
1316		finish_unfinished(s);
 
1317		reiserfs_xattr_init(s, *mount_flags);
1318	}
1319
1320out_ok:
1321	replace_mount_options(s, new_opts);
1322	reiserfs_write_unlock(s);
1323	return 0;
1324
 
 
1325out_err:
1326	kfree(new_opts);
1327	reiserfs_write_unlock(s);
1328	return err;
1329}
1330
1331static int read_super_block(struct super_block *s, int offset)
1332{
1333	struct buffer_head *bh;
1334	struct reiserfs_super_block *rs;
1335	int fs_blocksize;
1336
1337	bh = sb_bread(s, offset / s->s_blocksize);
1338	if (!bh) {
1339		reiserfs_warning(s, "sh-2006",
1340				 "bread failed (dev %s, block %lu, size %lu)",
1341				 reiserfs_bdevname(s), offset / s->s_blocksize,
1342				 s->s_blocksize);
1343		return 1;
1344	}
1345
1346	rs = (struct reiserfs_super_block *)bh->b_data;
1347	if (!is_any_reiserfs_magic_string(rs)) {
1348		brelse(bh);
1349		return 1;
1350	}
1351	//
1352	// ok, reiserfs signature (old or new) found in at the given offset
1353	//
1354	fs_blocksize = sb_blocksize(rs);
1355	brelse(bh);
1356	sb_set_blocksize(s, fs_blocksize);
1357
1358	bh = sb_bread(s, offset / s->s_blocksize);
1359	if (!bh) {
1360		reiserfs_warning(s, "sh-2007",
1361				 "bread failed (dev %s, block %lu, size %lu)",
1362				 reiserfs_bdevname(s), offset / s->s_blocksize,
1363				 s->s_blocksize);
1364		return 1;
1365	}
1366
1367	rs = (struct reiserfs_super_block *)bh->b_data;
1368	if (sb_blocksize(rs) != s->s_blocksize) {
1369		reiserfs_warning(s, "sh-2011", "can't find a reiserfs "
1370				 "filesystem on (dev %s, block %Lu, size %lu)",
1371				 reiserfs_bdevname(s),
1372				 (unsigned long long)bh->b_blocknr,
1373				 s->s_blocksize);
1374		brelse(bh);
1375		return 1;
1376	}
1377
1378	if (rs->s_v1.s_root_block == cpu_to_le32(-1)) {
1379		brelse(bh);
1380		reiserfs_warning(s, "super-6519", "Unfinished reiserfsck "
1381				 "--rebuild-tree run detected. Please run\n"
1382				 "reiserfsck --rebuild-tree and wait for a "
1383				 "completion. If that fails\n"
1384				 "get newer reiserfsprogs package");
1385		return 1;
1386	}
1387
1388	SB_BUFFER_WITH_SB(s) = bh;
1389	SB_DISK_SUPER_BLOCK(s) = rs;
1390
 
 
 
 
1391	if (is_reiserfs_jr(rs)) {
1392		/* magic is of non-standard journal filesystem, look at s_version to
1393		   find which format is in use */
1394		if (sb_version(rs) == REISERFS_VERSION_2)
1395			reiserfs_info(s, "found reiserfs format \"3.6\""
1396				      " with non-standard journal\n");
1397		else if (sb_version(rs) == REISERFS_VERSION_1)
1398			reiserfs_info(s, "found reiserfs format \"3.5\""
1399				      " with non-standard journal\n");
1400		else {
1401			reiserfs_warning(s, "sh-2012", "found unknown "
1402					 "format \"%u\" of reiserfs with "
1403					 "non-standard magic", sb_version(rs));
1404			return 1;
1405		}
1406	} else
1407		/* s_version of standard format may contain incorrect information,
1408		   so we just look at the magic string */
 
 
1409		reiserfs_info(s,
1410			      "found reiserfs format \"%s\" with standard journal\n",
1411			      is_reiserfs_3_5(rs) ? "3.5" : "3.6");
1412
1413	s->s_op = &reiserfs_sops;
1414	s->s_export_op = &reiserfs_export_ops;
1415#ifdef CONFIG_QUOTA
1416	s->s_qcop = &reiserfs_qctl_operations;
1417	s->dq_op = &reiserfs_quota_operations;
 
1418#endif
1419
1420	/* new format is limited by the 32 bit wide i_blocks field, want to
1421	 ** be one full block below that.
 
1422	 */
1423	s->s_maxbytes = (512LL << 32) - s->s_blocksize;
1424	return 0;
1425}
1426
1427/* after journal replay, reread all bitmap and super blocks */
1428static int reread_meta_blocks(struct super_block *s)
1429{
1430	ll_rw_block(READ, 1, &(SB_BUFFER_WITH_SB(s)));
1431	reiserfs_write_unlock(s);
1432	wait_on_buffer(SB_BUFFER_WITH_SB(s));
1433	reiserfs_write_lock(s);
1434	if (!buffer_uptodate(SB_BUFFER_WITH_SB(s))) {
1435		reiserfs_warning(s, "reiserfs-2504", "error reading the super");
1436		return 1;
1437	}
1438
1439	return 0;
1440}
1441
1442/////////////////////////////////////////////////////
1443// hash detection stuff
1444
1445// if root directory is empty - we set default - Yura's - hash and
1446// warn about it
1447// FIXME: we look for only one name in a directory. If tea and yura
1448// bith have the same value - we ask user to send report to the
1449// mailing list
 
 
1450static __u32 find_hash_out(struct super_block *s)
1451{
1452	int retval;
1453	struct inode *inode;
1454	struct cpu_key key;
1455	INITIALIZE_PATH(path);
1456	struct reiserfs_dir_entry de;
 
1457	__u32 hash = DEFAULT_HASH;
 
1458
1459	inode = s->s_root->d_inode;
1460
1461	do {			// Some serious "goto"-hater was there ;)
1462		u32 teahash, r5hash, yurahash;
 
 
 
 
 
 
1463
1464		make_cpu_key(&key, inode, ~0, TYPE_DIRENTRY, 3);
1465		retval = search_by_entry_key(s, &key, &path, &de);
1466		if (retval == IO_ERROR) {
1467			pathrelse(&path);
1468			return UNSET_HASH;
1469		}
1470		if (retval == NAME_NOT_FOUND)
1471			de.de_entry_num--;
1472		set_de_name_and_namelen(&de);
1473		if (deh_offset(&(de.de_deh[de.de_entry_num])) == DOT_DOT_OFFSET) {
1474			/* allow override in this case */
1475			if (reiserfs_rupasov_hash(s)) {
1476				hash = YURA_HASH;
1477			}
1478			reiserfs_info(s, "FS seems to be empty, autodetect "
1479					 "is using the default hash\n");
1480			break;
1481		}
1482		r5hash = GET_HASH_VALUE(r5_hash(de.de_name, de.de_namelen));
1483		teahash = GET_HASH_VALUE(keyed_hash(de.de_name, de.de_namelen));
1484		yurahash = GET_HASH_VALUE(yura_hash(de.de_name, de.de_namelen));
1485		if (((teahash == r5hash)
1486		     &&
1487		     (GET_HASH_VALUE(deh_offset(&(de.de_deh[de.de_entry_num])))
1488		      == r5hash)) || ((teahash == yurahash)
1489				      && (yurahash ==
1490					  GET_HASH_VALUE(deh_offset
1491							 (&
1492							  (de.
1493							   de_deh[de.
1494								  de_entry_num])))))
1495		    || ((r5hash == yurahash)
1496			&& (yurahash ==
1497			    GET_HASH_VALUE(deh_offset
1498					   (&(de.de_deh[de.de_entry_num])))))) {
1499			reiserfs_warning(s, "reiserfs-2506", "Unable to "
1500					 "automatically detect hash function. "
1501					 "Please mount with -o "
1502					 "hash={tea,rupasov,r5}");
1503			hash = UNSET_HASH;
1504			break;
1505		}
1506		if (GET_HASH_VALUE(deh_offset(&(de.de_deh[de.de_entry_num]))) ==
1507		    yurahash)
1508			hash = YURA_HASH;
1509		else if (GET_HASH_VALUE
1510			 (deh_offset(&(de.de_deh[de.de_entry_num]))) == teahash)
1511			hash = TEA_HASH;
1512		else if (GET_HASH_VALUE
1513			 (deh_offset(&(de.de_deh[de.de_entry_num]))) == r5hash)
1514			hash = R5_HASH;
1515		else {
1516			reiserfs_warning(s, "reiserfs-2506",
1517					 "Unrecognised hash function");
1518			hash = UNSET_HASH;
1519		}
1520	} while (0);
1521
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1522	pathrelse(&path);
1523	return hash;
1524}
1525
1526// finds out which hash names are sorted with
1527static int what_hash(struct super_block *s)
1528{
1529	__u32 code;
1530
1531	code = sb_hash_function_code(SB_DISK_SUPER_BLOCK(s));
1532
1533	/* reiserfs_hash_detect() == true if any of the hash mount options
1534	 ** were used.  We must check them to make sure the user isn't
1535	 ** using a bad hash value
 
1536	 */
1537	if (code == UNSET_HASH || reiserfs_hash_detect(s))
1538		code = find_hash_out(s);
1539
1540	if (code != UNSET_HASH && reiserfs_hash_detect(s)) {
1541		/* detection has found the hash, and we must check against the
1542		 ** mount options
 
1543		 */
1544		if (reiserfs_rupasov_hash(s) && code != YURA_HASH) {
1545			reiserfs_warning(s, "reiserfs-2507",
1546					 "Error, %s hash detected, "
1547					 "unable to force rupasov hash",
1548					 reiserfs_hashname(code));
1549			code = UNSET_HASH;
1550		} else if (reiserfs_tea_hash(s) && code != TEA_HASH) {
1551			reiserfs_warning(s, "reiserfs-2508",
1552					 "Error, %s hash detected, "
1553					 "unable to force tea hash",
1554					 reiserfs_hashname(code));
1555			code = UNSET_HASH;
1556		} else if (reiserfs_r5_hash(s) && code != R5_HASH) {
1557			reiserfs_warning(s, "reiserfs-2509",
1558					 "Error, %s hash detected, "
1559					 "unable to force r5 hash",
1560					 reiserfs_hashname(code));
1561			code = UNSET_HASH;
1562		}
1563	} else {
1564		/* find_hash_out was not called or could not determine the hash */
 
 
 
1565		if (reiserfs_rupasov_hash(s)) {
1566			code = YURA_HASH;
1567		} else if (reiserfs_tea_hash(s)) {
1568			code = TEA_HASH;
1569		} else if (reiserfs_r5_hash(s)) {
1570			code = R5_HASH;
1571		}
1572	}
1573
1574	/* if we are mounted RW, and we have a new valid hash code, update
1575	 ** the super
 
1576	 */
1577	if (code != UNSET_HASH &&
1578	    !(s->s_flags & MS_RDONLY) &&
1579	    code != sb_hash_function_code(SB_DISK_SUPER_BLOCK(s))) {
1580		set_sb_hash_function_code(SB_DISK_SUPER_BLOCK(s), code);
1581	}
1582	return code;
1583}
1584
1585// return pointer to appropriate function
1586static hashf_t hash_function(struct super_block *s)
1587{
1588	switch (what_hash(s)) {
1589	case TEA_HASH:
1590		reiserfs_info(s, "Using tea hash to sort names\n");
1591		return keyed_hash;
1592	case YURA_HASH:
1593		reiserfs_info(s, "Using rupasov hash to sort names\n");
1594		return yura_hash;
1595	case R5_HASH:
1596		reiserfs_info(s, "Using r5 hash to sort names\n");
1597		return r5_hash;
1598	}
1599	return NULL;
1600}
1601
1602// this is used to set up correct value for old partitions
1603static int function2code(hashf_t func)
1604{
1605	if (func == keyed_hash)
1606		return TEA_HASH;
1607	if (func == yura_hash)
1608		return YURA_HASH;
1609	if (func == r5_hash)
1610		return R5_HASH;
1611
1612	BUG();			// should never happen
1613
1614	return 0;
1615}
1616
1617#define SWARN(silent, s, id, ...)			\
1618	if (!(silent))				\
1619		reiserfs_warning(s, id, __VA_ARGS__)
1620
1621static int reiserfs_fill_super(struct super_block *s, void *data, int silent)
1622{
1623	struct inode *root_inode;
1624	struct reiserfs_transaction_handle th;
1625	int old_format = 0;
1626	unsigned long blocks;
1627	unsigned int commit_max_age = 0;
1628	int jinit_done = 0;
1629	struct reiserfs_iget_args args;
1630	struct reiserfs_super_block *rs;
1631	char *jdev_name;
1632	struct reiserfs_sb_info *sbi;
1633	int errval = -EINVAL;
1634	char *qf_names[MAXQUOTAS] = {};
1635	unsigned int qfmt = 0;
1636
1637	save_mount_options(s, data);
1638
1639	sbi = kzalloc(sizeof(struct reiserfs_sb_info), GFP_KERNEL);
1640	if (!sbi)
1641		return -ENOMEM;
1642	s->s_fs_info = sbi;
1643	/* Set default values for options: non-aggressive tails, RO on errors */
1644	REISERFS_SB(s)->s_mount_opt |= (1 << REISERFS_SMALLTAIL);
1645	REISERFS_SB(s)->s_mount_opt |= (1 << REISERFS_ERROR_RO);
1646	REISERFS_SB(s)->s_mount_opt |= (1 << REISERFS_BARRIER_FLUSH);
1647	/* no preallocation minimum, be smart in
1648	   reiserfs_file_write instead */
1649	REISERFS_SB(s)->s_alloc_options.preallocmin = 0;
1650	/* Preallocate by 16 blocks (17-1) at once */
1651	REISERFS_SB(s)->s_alloc_options.preallocsize = 17;
1652	/* setup default block allocator options */
1653	reiserfs_init_alloc_options(s);
1654
1655	mutex_init(&REISERFS_SB(s)->lock);
1656	REISERFS_SB(s)->lock_depth = -1;
1657
1658	/*
1659	 * This function is called with the bkl, which also was the old
1660	 * locking used here.
1661	 * do_journal_begin() will soon check if we hold the lock (ie: was the
1662	 * bkl). This is likely because do_journal_begin() has several another
1663	 * callers because at this time, it doesn't seem to be necessary to
1664	 * protect against anything.
1665	 * Anyway, let's be conservative and lock for now.
1666	 */
1667	reiserfs_write_lock(s);
1668
1669	jdev_name = NULL;
1670	if (reiserfs_parse_options
1671	    (s, (char *)data, &(sbi->s_mount_opt), &blocks, &jdev_name,
1672	     &commit_max_age, qf_names, &qfmt) == 0) {
1673		goto error;
 
 
 
 
 
 
 
 
1674	}
1675#ifdef CONFIG_QUOTA
1676	handle_quota_files(s, qf_names, &qfmt);
1677#endif
1678
1679	if (blocks) {
1680		SWARN(silent, s, "jmacd-7", "resize option for remount only");
1681		goto error;
1682	}
1683
1684	/* try old format (undistributed bitmap, super block in 8-th 1k block of a device) */
 
 
 
1685	if (!read_super_block(s, REISERFS_OLD_DISK_OFFSET_IN_BYTES))
1686		old_format = 1;
1687	/* try new format (64-th 1k block), which can contain reiserfs super block */
 
 
 
 
1688	else if (read_super_block(s, REISERFS_DISK_OFFSET_IN_BYTES)) {
1689		SWARN(silent, s, "sh-2021", "can not find reiserfs on %s",
1690		      reiserfs_bdevname(s));
1691		goto error;
1692	}
1693
1694	rs = SB_DISK_SUPER_BLOCK(s);
1695	/* Let's do basic sanity check to verify that underlying device is not
1696	   smaller than the filesystem. If the check fails then abort and scream,
1697	   because bad stuff will happen otherwise. */
 
 
1698	if (s->s_bdev && s->s_bdev->bd_inode
1699	    && i_size_read(s->s_bdev->bd_inode) <
1700	    sb_block_count(rs) * sb_blocksize(rs)) {
1701		SWARN(silent, s, "", "Filesystem cannot be "
1702		      "mounted because it is bigger than the device");
1703		SWARN(silent, s, "", "You may need to run fsck "
1704		      "or increase size of your LVM partition");
1705		SWARN(silent, s, "", "Or may be you forgot to "
1706		      "reboot after fdisk when it told you to");
1707		goto error;
1708	}
1709
1710	sbi->s_mount_state = SB_REISERFS_STATE(s);
1711	sbi->s_mount_state = REISERFS_VALID_FS;
1712
1713	if ((errval = reiserfs_init_bitmap_cache(s))) {
1714		SWARN(silent, s, "jmacd-8", "unable to read bitmap");
1715		goto error;
1716	}
 
1717	errval = -EINVAL;
1718#ifdef CONFIG_REISERFS_CHECK
1719	SWARN(silent, s, "", "CONFIG_REISERFS_CHECK is set ON");
1720	SWARN(silent, s, "", "- it is slow mode for debugging.");
1721#endif
1722
1723	/* make data=ordered the default */
1724	if (!reiserfs_data_log(s) && !reiserfs_data_ordered(s) &&
1725	    !reiserfs_data_writeback(s)) {
1726		REISERFS_SB(s)->s_mount_opt |= (1 << REISERFS_DATA_ORDERED);
1727	}
1728
1729	if (reiserfs_data_log(s)) {
1730		reiserfs_info(s, "using journaled data mode\n");
1731	} else if (reiserfs_data_ordered(s)) {
1732		reiserfs_info(s, "using ordered data mode\n");
1733	} else {
1734		reiserfs_info(s, "using writeback data mode\n");
1735	}
1736	if (reiserfs_barrier_flush(s)) {
1737		printk("reiserfs: using flush barriers\n");
1738	}
1739	// set_device_ro(s->s_dev, 1) ;
1740	if (journal_init(s, jdev_name, old_format, commit_max_age)) {
1741		SWARN(silent, s, "sh-2022",
1742		      "unable to initialize journal space");
1743		goto error;
1744	} else {
1745		jinit_done = 1;	/* once this is set, journal_release must be called
1746				 ** if we error out of the mount
1747				 */
 
 
1748	}
 
1749	if (reread_meta_blocks(s)) {
1750		SWARN(silent, s, "jmacd-9",
1751		      "unable to reread meta blocks after journal init");
1752		goto error;
1753	}
1754
1755	if (replay_only(s))
1756		goto error;
1757
1758	if (bdev_read_only(s->s_bdev) && !(s->s_flags & MS_RDONLY)) {
1759		SWARN(silent, s, "clm-7000",
1760		      "Detected readonly device, marking FS readonly");
1761		s->s_flags |= MS_RDONLY;
1762	}
1763	args.objectid = REISERFS_ROOT_OBJECTID;
1764	args.dirid = REISERFS_ROOT_PARENT_OBJECTID;
1765	root_inode =
1766	    iget5_locked(s, REISERFS_ROOT_OBJECTID, reiserfs_find_actor,
1767			 reiserfs_init_locked_inode, (void *)(&args));
1768	if (!root_inode) {
1769		SWARN(silent, s, "jmacd-10", "get root inode failed");
1770		goto error;
1771	}
1772
 
 
 
 
 
 
 
 
 
 
1773	if (root_inode->i_state & I_NEW) {
1774		reiserfs_read_locked_inode(root_inode, &args);
1775		unlock_new_inode(root_inode);
1776	}
1777
1778	s->s_root = d_alloc_root(root_inode);
1779	if (!s->s_root) {
1780		iput(root_inode);
1781		goto error;
1782	}
1783	// define and initialize hash function
1784	sbi->s_hash_function = hash_function(s);
1785	if (sbi->s_hash_function == NULL) {
1786		dput(s->s_root);
1787		s->s_root = NULL;
1788		goto error;
1789	}
1790
1791	if (is_reiserfs_3_5(rs)
1792	    || (is_reiserfs_jr(rs) && SB_VERSION(s) == REISERFS_VERSION_1))
1793		set_bit(REISERFS_3_5, &(sbi->s_properties));
1794	else if (old_format)
1795		set_bit(REISERFS_OLD_FORMAT, &(sbi->s_properties));
1796	else
1797		set_bit(REISERFS_3_6, &(sbi->s_properties));
1798
1799	if (!(s->s_flags & MS_RDONLY)) {
1800
1801		errval = journal_begin(&th, s, 1);
1802		if (errval) {
1803			dput(s->s_root);
1804			s->s_root = NULL;
1805			goto error;
1806		}
1807		reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s), 1);
1808
1809		set_sb_umount_state(rs, REISERFS_ERROR_FS);
1810		set_sb_fs_state(rs, 0);
1811
1812		/* Clear out s_bmap_nr if it would wrap. We can handle this
 
1813		 * case, but older revisions can't. This will cause the
1814		 * file system to fail mount on those older implementations,
1815		 * avoiding corruption. -jeffm */
 
1816		if (bmap_would_wrap(reiserfs_bmap_count(s)) &&
1817		    sb_bmap_nr(rs) != 0) {
1818			reiserfs_warning(s, "super-2030", "This file system "
1819					"claims to use %u bitmap blocks in "
1820					"its super block, but requires %u. "
1821					"Clearing to zero.", sb_bmap_nr(rs),
1822					reiserfs_bmap_count(s));
1823
1824			set_sb_bmap_nr(rs, 0);
1825		}
1826
1827		if (old_format_only(s)) {
1828			/* filesystem of format 3.5 either with standard or non-standard
1829			   journal */
 
 
1830			if (convert_reiserfs(s)) {
1831				/* and -o conv is given */
1832				if (!silent)
1833					reiserfs_info(s,
1834						      "converting 3.5 filesystem to the 3.6 format");
1835
1836				if (is_reiserfs_3_5(rs))
1837					/* put magic string of 3.6 format. 2.2 will not be able to
1838					   mount this filesystem anymore */
 
 
 
1839					memcpy(rs->s_v1.s_magic,
1840					       reiserfs_3_6_magic_string,
1841					       sizeof
1842					       (reiserfs_3_6_magic_string));
1843
1844				set_sb_version(rs, REISERFS_VERSION_2);
1845				reiserfs_convert_objectid_map_v1(s);
1846				set_bit(REISERFS_3_6, &(sbi->s_properties));
1847				clear_bit(REISERFS_3_5, &(sbi->s_properties));
1848			} else if (!silent) {
1849				reiserfs_info(s, "using 3.5.x disk format\n");
1850			}
1851		} else
1852			set_sb_mnt_count(rs, sb_mnt_count(rs) + 1);
1853
1854
1855		journal_mark_dirty(&th, s, SB_BUFFER_WITH_SB(s));
1856		errval = journal_end(&th, s, 1);
1857		if (errval) {
1858			dput(s->s_root);
1859			s->s_root = NULL;
1860			goto error;
1861		}
1862
 
1863		if ((errval = reiserfs_lookup_privroot(s)) ||
1864		    (errval = reiserfs_xattr_init(s, s->s_flags))) {
1865			dput(s->s_root);
1866			s->s_root = NULL;
1867			goto error;
1868		}
 
1869
1870		/* look for files which were to be removed in previous session */
 
 
1871		finish_unfinished(s);
1872	} else {
1873		if (old_format_only(s) && !silent) {
1874			reiserfs_info(s, "using 3.5.x disk format\n");
1875		}
1876
 
1877		if ((errval = reiserfs_lookup_privroot(s)) ||
1878		    (errval = reiserfs_xattr_init(s, s->s_flags))) {
1879			dput(s->s_root);
1880			s->s_root = NULL;
1881			goto error;
1882		}
 
1883	}
1884	// mark hash in super block: it could be unset. overwrite should be ok
 
 
1885	set_sb_hash_function_code(rs, function2code(sbi->s_hash_function));
1886
1887	handle_attrs(s);
1888
1889	reiserfs_proc_info_init(s);
1890
1891	init_waitqueue_head(&(sbi->s_wait));
1892	spin_lock_init(&sbi->bitmap_lock);
1893
1894	reiserfs_write_unlock(s);
1895
1896	return (0);
1897
1898error:
1899	if (jinit_done) {	/* kill the commit thread, free journal ram */
 
 
 
 
 
1900		journal_release_error(NULL, s);
 
1901	}
1902
1903	reiserfs_write_unlock(s);
 
 
 
1904
1905	reiserfs_free_bitmap_cache(s);
1906	if (SB_BUFFER_WITH_SB(s))
1907		brelse(SB_BUFFER_WITH_SB(s));
1908#ifdef CONFIG_QUOTA
1909	{
1910		int j;
1911		for (j = 0; j < MAXQUOTAS; j++)
1912			kfree(qf_names[j]);
1913	}
1914#endif
1915	kfree(sbi);
1916
1917	s->s_fs_info = NULL;
1918	return errval;
1919}
1920
1921static int reiserfs_statfs(struct dentry *dentry, struct kstatfs *buf)
1922{
1923	struct reiserfs_super_block *rs = SB_DISK_SUPER_BLOCK(dentry->d_sb);
1924
1925	buf->f_namelen = (REISERFS_MAX_NAME(s->s_blocksize));
1926	buf->f_bfree = sb_free_blocks(rs);
1927	buf->f_bavail = buf->f_bfree;
1928	buf->f_blocks = sb_block_count(rs) - sb_bmap_nr(rs) - 1;
1929	buf->f_bsize = dentry->d_sb->s_blocksize;
1930	/* changed to accommodate gcc folks. */
1931	buf->f_type = REISERFS_SUPER_MAGIC;
1932	buf->f_fsid.val[0] = (u32)crc32_le(0, rs->s_uuid, sizeof(rs->s_uuid)/2);
1933	buf->f_fsid.val[1] = (u32)crc32_le(0, rs->s_uuid + sizeof(rs->s_uuid)/2,
1934				sizeof(rs->s_uuid)/2);
1935
1936	return 0;
1937}
1938
1939#ifdef CONFIG_QUOTA
1940static int reiserfs_write_dquot(struct dquot *dquot)
1941{
1942	struct reiserfs_transaction_handle th;
1943	int ret, err;
 
1944
1945	reiserfs_write_lock(dquot->dq_sb);
1946	ret =
1947	    journal_begin(&th, dquot->dq_sb,
1948			  REISERFS_QUOTA_TRANS_BLOCKS(dquot->dq_sb));
1949	if (ret)
1950		goto out;
 
1951	ret = dquot_commit(dquot);
1952	err =
1953	    journal_end(&th, dquot->dq_sb,
1954			REISERFS_QUOTA_TRANS_BLOCKS(dquot->dq_sb));
1955	if (!ret && err)
1956		ret = err;
1957      out:
1958	reiserfs_write_unlock(dquot->dq_sb);
1959	return ret;
1960}
1961
1962static int reiserfs_acquire_dquot(struct dquot *dquot)
1963{
1964	struct reiserfs_transaction_handle th;
1965	int ret, err;
 
1966
1967	reiserfs_write_lock(dquot->dq_sb);
1968	ret =
1969	    journal_begin(&th, dquot->dq_sb,
1970			  REISERFS_QUOTA_INIT_BLOCKS(dquot->dq_sb));
1971	if (ret)
1972		goto out;
 
1973	ret = dquot_acquire(dquot);
1974	err =
1975	    journal_end(&th, dquot->dq_sb,
1976			REISERFS_QUOTA_INIT_BLOCKS(dquot->dq_sb));
1977	if (!ret && err)
1978		ret = err;
1979      out:
1980	reiserfs_write_unlock(dquot->dq_sb);
1981	return ret;
1982}
1983
1984static int reiserfs_release_dquot(struct dquot *dquot)
1985{
1986	struct reiserfs_transaction_handle th;
1987	int ret, err;
1988
1989	reiserfs_write_lock(dquot->dq_sb);
1990	ret =
1991	    journal_begin(&th, dquot->dq_sb,
1992			  REISERFS_QUOTA_DEL_BLOCKS(dquot->dq_sb));
 
1993	if (ret) {
1994		/* Release dquot anyway to avoid endless cycle in dqput() */
1995		dquot_release(dquot);
1996		goto out;
1997	}
1998	ret = dquot_release(dquot);
1999	err =
2000	    journal_end(&th, dquot->dq_sb,
2001			REISERFS_QUOTA_DEL_BLOCKS(dquot->dq_sb));
2002	if (!ret && err)
2003		ret = err;
2004      out:
2005	reiserfs_write_unlock(dquot->dq_sb);
 
2006	return ret;
2007}
2008
2009static int reiserfs_mark_dquot_dirty(struct dquot *dquot)
2010{
2011	/* Are we journaling quotas? */
2012	if (REISERFS_SB(dquot->dq_sb)->s_qf_names[USRQUOTA] ||
2013	    REISERFS_SB(dquot->dq_sb)->s_qf_names[GRPQUOTA]) {
2014		dquot_mark_dquot_dirty(dquot);
2015		return reiserfs_write_dquot(dquot);
2016	} else
2017		return dquot_mark_dquot_dirty(dquot);
2018}
2019
2020static int reiserfs_write_info(struct super_block *sb, int type)
2021{
2022	struct reiserfs_transaction_handle th;
2023	int ret, err;
 
2024
2025	/* Data block + inode block */
2026	reiserfs_write_lock(sb);
2027	ret = journal_begin(&th, sb, 2);
2028	if (ret)
2029		goto out;
 
2030	ret = dquot_commit_info(sb, type);
2031	err = journal_end(&th, sb, 2);
 
2032	if (!ret && err)
2033		ret = err;
2034      out:
2035	reiserfs_write_unlock(sb);
2036	return ret;
2037}
2038
2039/*
2040 * Turn on quotas during mount time - we need to find the quota file and such...
2041 */
2042static int reiserfs_quota_on_mount(struct super_block *sb, int type)
2043{
2044	return dquot_quota_on_mount(sb, REISERFS_SB(sb)->s_qf_names[type],
2045					REISERFS_SB(sb)->s_jquota_fmt, type);
2046}
2047
2048/*
2049 * Standard function to be called on quota_on
2050 */
2051static int reiserfs_quota_on(struct super_block *sb, int type, int format_id,
2052			     struct path *path)
2053{
2054	int err;
2055	struct inode *inode;
2056	struct reiserfs_transaction_handle th;
 
2057
2058	if (!(REISERFS_SB(sb)->s_mount_opt & (1 << REISERFS_QUOTA)))
2059		return -EINVAL;
 
 
 
2060
2061	/* Quotafile not on the same filesystem? */
2062	if (path->mnt->mnt_sb != sb) {
2063		err = -EXDEV;
2064		goto out;
2065	}
2066	inode = path->dentry->d_inode;
2067	/* We must not pack tails for quota files on reiserfs for quota IO to work */
 
 
 
2068	if (!(REISERFS_I(inode)->i_flags & i_nopack_mask)) {
2069		err = reiserfs_unpack(inode, NULL);
2070		if (err) {
2071			reiserfs_warning(sb, "super-6520",
2072				"Unpacking tail of quota file failed"
2073				" (%d). Cannot turn on quotas.", err);
2074			err = -EINVAL;
2075			goto out;
2076		}
2077		mark_inode_dirty(inode);
2078	}
2079	/* Journaling quota? */
2080	if (REISERFS_SB(sb)->s_qf_names[type]) {
2081		/* Quotafile not of fs root? */
2082		if (path->dentry->d_parent != sb->s_root)
2083			reiserfs_warning(sb, "super-6521",
2084				 "Quota file not on filesystem root. "
2085				 "Journalled quota will not work.");
2086	}
2087
2088	/*
2089	 * When we journal data on quota file, we have to flush journal to see
2090	 * all updates to the file when we bypass pagecache...
2091	 */
2092	if (reiserfs_file_data_log(inode)) {
2093		/* Just start temporary transaction and finish it */
2094		err = journal_begin(&th, sb, 1);
2095		if (err)
2096			goto out;
2097		err = journal_end_sync(&th, sb, 1);
2098		if (err)
2099			goto out;
2100	}
2101	err = dquot_quota_on(sb, type, format_id, path);
 
2102out:
 
2103	return err;
2104}
2105
2106/* Read data from quotafile - avoid pagecache and such because we cannot afford
 
2107 * acquiring the locks... As quota files are never truncated and quota code
2108 * itself serializes the operations (and no one else should touch the files)
2109 * we don't have to be afraid of races */
 
2110static ssize_t reiserfs_quota_read(struct super_block *sb, int type, char *data,
2111				   size_t len, loff_t off)
2112{
2113	struct inode *inode = sb_dqopt(sb)->files[type];
2114	unsigned long blk = off >> sb->s_blocksize_bits;
2115	int err = 0, offset = off & (sb->s_blocksize - 1), tocopy;
2116	size_t toread;
2117	struct buffer_head tmp_bh, *bh;
2118	loff_t i_size = i_size_read(inode);
2119
2120	if (off > i_size)
2121		return 0;
2122	if (off + len > i_size)
2123		len = i_size - off;
2124	toread = len;
2125	while (toread > 0) {
2126		tocopy =
2127		    sb->s_blocksize - offset <
2128		    toread ? sb->s_blocksize - offset : toread;
2129		tmp_bh.b_state = 0;
2130		/* Quota files are without tails so we can safely use this function */
 
 
 
2131		reiserfs_write_lock(sb);
2132		err = reiserfs_get_block(inode, blk, &tmp_bh, 0);
2133		reiserfs_write_unlock(sb);
2134		if (err)
2135			return err;
2136		if (!buffer_mapped(&tmp_bh))	/* A hole? */
2137			memset(data, 0, tocopy);
2138		else {
2139			bh = sb_bread(sb, tmp_bh.b_blocknr);
2140			if (!bh)
2141				return -EIO;
2142			memcpy(data, bh->b_data + offset, tocopy);
2143			brelse(bh);
2144		}
2145		offset = 0;
2146		toread -= tocopy;
2147		data += tocopy;
2148		blk++;
2149	}
2150	return len;
2151}
2152
2153/* Write to quotafile (we know the transaction is already started and has
2154 * enough credits) */
 
 
2155static ssize_t reiserfs_quota_write(struct super_block *sb, int type,
2156				    const char *data, size_t len, loff_t off)
2157{
2158	struct inode *inode = sb_dqopt(sb)->files[type];
2159	unsigned long blk = off >> sb->s_blocksize_bits;
2160	int err = 0, offset = off & (sb->s_blocksize - 1), tocopy;
2161	int journal_quota = REISERFS_SB(sb)->s_qf_names[type] != NULL;
2162	size_t towrite = len;
2163	struct buffer_head tmp_bh, *bh;
2164
2165	if (!current->journal_info) {
2166		printk(KERN_WARNING "reiserfs: Quota write (off=%Lu, len=%Lu)"
2167			" cancelled because transaction is not started.\n",
2168			(unsigned long long)off, (unsigned long long)len);
2169		return -EIO;
2170	}
2171	mutex_lock_nested(&inode->i_mutex, I_MUTEX_QUOTA);
2172	while (towrite > 0) {
2173		tocopy = sb->s_blocksize - offset < towrite ?
2174		    sb->s_blocksize - offset : towrite;
2175		tmp_bh.b_state = 0;
 
2176		err = reiserfs_get_block(inode, blk, &tmp_bh, GET_BLOCK_CREATE);
 
2177		if (err)
2178			goto out;
2179		if (offset || tocopy != sb->s_blocksize)
2180			bh = sb_bread(sb, tmp_bh.b_blocknr);
2181		else
2182			bh = sb_getblk(sb, tmp_bh.b_blocknr);
2183		if (!bh) {
2184			err = -EIO;
2185			goto out;
2186		}
2187		lock_buffer(bh);
2188		memcpy(bh->b_data + offset, data, tocopy);
2189		flush_dcache_page(bh->b_page);
2190		set_buffer_uptodate(bh);
2191		unlock_buffer(bh);
 
2192		reiserfs_prepare_for_journal(sb, bh, 1);
2193		journal_mark_dirty(current->journal_info, sb, bh);
2194		if (!journal_quota)
2195			reiserfs_add_ordered_list(inode, bh);
 
2196		brelse(bh);
2197		offset = 0;
2198		towrite -= tocopy;
2199		data += tocopy;
2200		blk++;
2201	}
2202out:
2203	if (len == towrite) {
2204		mutex_unlock(&inode->i_mutex);
2205		return err;
2206	}
2207	if (inode->i_size < off + len - towrite)
2208		i_size_write(inode, off + len - towrite);
2209	inode->i_version++;
2210	inode->i_mtime = inode->i_ctime = CURRENT_TIME;
2211	mark_inode_dirty(inode);
2212	mutex_unlock(&inode->i_mutex);
2213	return len - towrite;
2214}
2215
2216#endif
2217
2218static struct dentry *get_super_block(struct file_system_type *fs_type,
2219			   int flags, const char *dev_name,
2220			   void *data)
2221{
2222	return mount_bdev(fs_type, flags, dev_name, data, reiserfs_fill_super);
2223}
2224
2225static int __init init_reiserfs_fs(void)
2226{
2227	int ret;
2228
2229	if ((ret = init_inodecache())) {
 
2230		return ret;
2231	}
2232
2233	reiserfs_proc_info_global_init();
2234
2235	ret = register_filesystem(&reiserfs_fs_type);
 
 
2236
2237	if (ret == 0) {
2238		return 0;
2239	}
2240
2241	reiserfs_proc_info_global_done();
2242	destroy_inodecache();
2243
2244	return ret;
2245}
2246
2247static void __exit exit_reiserfs_fs(void)
2248{
2249	reiserfs_proc_info_global_done();
2250	unregister_filesystem(&reiserfs_fs_type);
2251	destroy_inodecache();
2252}
2253
2254struct file_system_type reiserfs_fs_type = {
2255	.owner = THIS_MODULE,
2256	.name = "reiserfs",
2257	.mount = get_super_block,
2258	.kill_sb = reiserfs_kill_sb,
2259	.fs_flags = FS_REQUIRES_DEV,
2260};
 
2261
2262MODULE_DESCRIPTION("ReiserFS journaled filesystem");
2263MODULE_AUTHOR("Hans Reiser <reiser@namesys.com>");
2264MODULE_LICENSE("GPL");
2265
2266module_init(init_reiserfs_fs);
2267module_exit(exit_reiserfs_fs);
v4.6
   1/*
   2 * Copyright 2000 by Hans Reiser, licensing governed by reiserfs/README
   3 *
   4 * Trivial changes by Alan Cox to add the LFS fixes
   5 *
   6 * Trivial Changes:
   7 * Rights granted to Hans Reiser to redistribute under other terms providing
   8 * he accepts all liability including but not limited to patent, fitness
   9 * for purpose, and direct or indirect claims arising from failure to perform.
  10 *
  11 * NO WARRANTY
  12 */
  13
  14#include <linux/module.h>
  15#include <linux/slab.h>
  16#include <linux/vmalloc.h>
  17#include <linux/time.h>
  18#include <linux/uaccess.h>
  19#include "reiserfs.h"
  20#include "acl.h"
  21#include "xattr.h"
  22#include <linux/init.h>
  23#include <linux/blkdev.h>
  24#include <linux/backing-dev.h>
  25#include <linux/buffer_head.h>
  26#include <linux/exportfs.h>
  27#include <linux/quotaops.h>
  28#include <linux/vfs.h>
  29#include <linux/mount.h>
  30#include <linux/namei.h>
  31#include <linux/crc32.h>
  32#include <linux/seq_file.h>
  33
  34struct file_system_type reiserfs_fs_type;
  35
  36static const char reiserfs_3_5_magic_string[] = REISERFS_SUPER_MAGIC_STRING;
  37static const char reiserfs_3_6_magic_string[] = REISER2FS_SUPER_MAGIC_STRING;
  38static const char reiserfs_jr_magic_string[] = REISER2FS_JR_SUPER_MAGIC_STRING;
  39
  40int is_reiserfs_3_5(struct reiserfs_super_block *rs)
  41{
  42	return !strncmp(rs->s_v1.s_magic, reiserfs_3_5_magic_string,
  43			strlen(reiserfs_3_5_magic_string));
  44}
  45
  46int is_reiserfs_3_6(struct reiserfs_super_block *rs)
  47{
  48	return !strncmp(rs->s_v1.s_magic, reiserfs_3_6_magic_string,
  49			strlen(reiserfs_3_6_magic_string));
  50}
  51
  52int is_reiserfs_jr(struct reiserfs_super_block *rs)
  53{
  54	return !strncmp(rs->s_v1.s_magic, reiserfs_jr_magic_string,
  55			strlen(reiserfs_jr_magic_string));
  56}
  57
  58static int is_any_reiserfs_magic_string(struct reiserfs_super_block *rs)
  59{
  60	return (is_reiserfs_3_5(rs) || is_reiserfs_3_6(rs) ||
  61		is_reiserfs_jr(rs));
  62}
  63
  64static int reiserfs_remount(struct super_block *s, int *flags, char *data);
  65static int reiserfs_statfs(struct dentry *dentry, struct kstatfs *buf);
  66
  67static int reiserfs_sync_fs(struct super_block *s, int wait)
  68{
  69	struct reiserfs_transaction_handle th;
  70
  71	/*
  72	 * Writeback quota in non-journalled quota case - journalled quota has
  73	 * no dirty dquots
  74	 */
  75	dquot_writeback_dquots(s, -1);
  76	reiserfs_write_lock(s);
  77	if (!journal_begin(&th, s, 1))
  78		if (!journal_end_sync(&th))
  79			reiserfs_flush_old_commits(s);
 
 
  80	reiserfs_write_unlock(s);
  81	return 0;
  82}
  83
  84static void flush_old_commits(struct work_struct *work)
  85{
  86	struct reiserfs_sb_info *sbi;
  87	struct super_block *s;
  88
  89	sbi = container_of(work, struct reiserfs_sb_info, old_work.work);
  90	s = sbi->s_journal->j_work_sb;
  91
  92	spin_lock(&sbi->old_work_lock);
  93	sbi->work_queued = 0;
  94	spin_unlock(&sbi->old_work_lock);
  95
  96	reiserfs_sync_fs(s, 1);
  97}
  98
  99void reiserfs_schedule_old_flush(struct super_block *s)
 100{
 101	struct reiserfs_sb_info *sbi = REISERFS_SB(s);
 102	unsigned long delay;
 103
 104	/*
 105	 * Avoid scheduling flush when sb is being shut down. It can race
 106	 * with journal shutdown and free still queued delayed work.
 107	 */
 108	if (s->s_flags & MS_RDONLY || !(s->s_flags & MS_ACTIVE))
 109		return;
 110
 111	spin_lock(&sbi->old_work_lock);
 112	if (!sbi->work_queued) {
 113		delay = msecs_to_jiffies(dirty_writeback_interval * 10);
 114		queue_delayed_work(system_long_wq, &sbi->old_work, delay);
 115		sbi->work_queued = 1;
 116	}
 117	spin_unlock(&sbi->old_work_lock);
 118}
 119
 120static void cancel_old_flush(struct super_block *s)
 121{
 122	struct reiserfs_sb_info *sbi = REISERFS_SB(s);
 123
 124	cancel_delayed_work_sync(&REISERFS_SB(s)->old_work);
 125	spin_lock(&sbi->old_work_lock);
 126	sbi->work_queued = 0;
 127	spin_unlock(&sbi->old_work_lock);
 128}
 129
 130static int reiserfs_freeze(struct super_block *s)
 131{
 132	struct reiserfs_transaction_handle th;
 133
 134	cancel_old_flush(s);
 135
 136	reiserfs_write_lock(s);
 137	if (!(s->s_flags & MS_RDONLY)) {
 138		int err = journal_begin(&th, s, 1);
 139		if (err) {
 140			reiserfs_block_writes(&th);
 141		} else {
 142			reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s),
 143						     1);
 144			journal_mark_dirty(&th, SB_BUFFER_WITH_SB(s));
 145			reiserfs_block_writes(&th);
 146			journal_end_sync(&th);
 147		}
 148	}
 
 149	reiserfs_write_unlock(s);
 150	return 0;
 151}
 152
 153static int reiserfs_unfreeze(struct super_block *s)
 154{
 155	reiserfs_allow_writes(s);
 156	return 0;
 157}
 158
 159extern const struct in_core_key MAX_IN_CORE_KEY;
 160
 161/*
 162 * this is used to delete "save link" when there are no items of a
 163 * file it points to. It can either happen if unlink is completed but
 164 * "save unlink" removal, or if file has both unlink and truncate
 165 * pending and as unlink completes first (because key of "save link"
 166 * protecting unlink is bigger that a key lf "save link" which
 167 * protects truncate), so there left no items to make truncate
 168 * completion on
 169 */
 170static int remove_save_link_only(struct super_block *s,
 171				 struct reiserfs_key *key, int oid_free)
 172{
 173	struct reiserfs_transaction_handle th;
 174	int err;
 175
 176	/* we are going to do one balancing */
 177	err = journal_begin(&th, s, JOURNAL_PER_BALANCE_CNT);
 178	if (err)
 179		return err;
 180
 181	reiserfs_delete_solid_item(&th, NULL, key);
 182	if (oid_free)
 183		/* removals are protected by direct items */
 184		reiserfs_release_objectid(&th, le32_to_cpu(key->k_objectid));
 185
 186	return journal_end(&th);
 187}
 188
 189#ifdef CONFIG_QUOTA
 190static int reiserfs_quota_on_mount(struct super_block *, int);
 191#endif
 192
 193/* look for uncompleted unlinks and truncates and complete them */
 194static int finish_unfinished(struct super_block *s)
 195{
 196	INITIALIZE_PATH(path);
 197	struct cpu_key max_cpu_key, obj_key;
 198	struct reiserfs_key save_link_key, last_inode_key;
 199	int retval = 0;
 200	struct item_head *ih;
 201	struct buffer_head *bh;
 202	int item_pos;
 203	char *item;
 204	int done;
 205	struct inode *inode;
 206	int truncate;
 207#ifdef CONFIG_QUOTA
 208	int i;
 209	int ms_active_set;
 210	int quota_enabled[REISERFS_MAXQUOTAS];
 211#endif
 212
 213	/* compose key to look for "save" links */
 214	max_cpu_key.version = KEY_FORMAT_3_5;
 215	max_cpu_key.on_disk_key.k_dir_id = ~0U;
 216	max_cpu_key.on_disk_key.k_objectid = ~0U;
 217	set_cpu_key_k_offset(&max_cpu_key, ~0U);
 218	max_cpu_key.key_length = 3;
 219
 220	memset(&last_inode_key, 0, sizeof(last_inode_key));
 221
 222#ifdef CONFIG_QUOTA
 223	/* Needed for iput() to work correctly and not trash data */
 224	if (s->s_flags & MS_ACTIVE) {
 225		ms_active_set = 0;
 226	} else {
 227		ms_active_set = 1;
 228		s->s_flags |= MS_ACTIVE;
 229	}
 230	/* Turn on quotas so that they are updated correctly */
 231	for (i = 0; i < REISERFS_MAXQUOTAS; i++) {
 232		quota_enabled[i] = 1;
 233		if (REISERFS_SB(s)->s_qf_names[i]) {
 234			int ret;
 235
 236			if (sb_has_quota_active(s, i)) {
 237				quota_enabled[i] = 0;
 238				continue;
 239			}
 240			ret = reiserfs_quota_on_mount(s, i);
 241			if (ret < 0)
 242				reiserfs_warning(s, "reiserfs-2500",
 243						 "cannot turn on journaled "
 244						 "quota: error %d", ret);
 245		}
 246	}
 247#endif
 248
 249	done = 0;
 250	REISERFS_SB(s)->s_is_unlinked_ok = 1;
 251	while (!retval) {
 252		int depth;
 253		retval = search_item(s, &max_cpu_key, &path);
 254		if (retval != ITEM_NOT_FOUND) {
 255			reiserfs_error(s, "vs-2140",
 256				       "search_by_key returned %d", retval);
 257			break;
 258		}
 259
 260		bh = get_last_bh(&path);
 261		item_pos = get_item_pos(&path);
 262		if (item_pos != B_NR_ITEMS(bh)) {
 263			reiserfs_warning(s, "vs-2060",
 264					 "wrong position found");
 265			break;
 266		}
 267		item_pos--;
 268		ih = item_head(bh, item_pos);
 269
 270		if (le32_to_cpu(ih->ih_key.k_dir_id) != MAX_KEY_OBJECTID)
 271			/* there are no "save" links anymore */
 272			break;
 273
 274		save_link_key = ih->ih_key;
 275		if (is_indirect_le_ih(ih))
 276			truncate = 1;
 277		else
 278			truncate = 0;
 279
 280		/* reiserfs_iget needs k_dirid and k_objectid only */
 281		item = ih_item_body(bh, ih);
 282		obj_key.on_disk_key.k_dir_id = le32_to_cpu(*(__le32 *) item);
 283		obj_key.on_disk_key.k_objectid =
 284		    le32_to_cpu(ih->ih_key.k_objectid);
 285		obj_key.on_disk_key.k_offset = 0;
 286		obj_key.on_disk_key.k_type = 0;
 287
 288		pathrelse(&path);
 289
 290		inode = reiserfs_iget(s, &obj_key);
 291		if (IS_ERR_OR_NULL(inode)) {
 292			/*
 293			 * the unlink almost completed, it just did not
 294			 * manage to remove "save" link and release objectid
 295			 */
 296			reiserfs_warning(s, "vs-2180", "iget failed for %K",
 297					 &obj_key);
 298			retval = remove_save_link_only(s, &save_link_key, 1);
 299			continue;
 300		}
 301
 302		if (!truncate && inode->i_nlink) {
 303			/* file is not unlinked */
 304			reiserfs_warning(s, "vs-2185",
 305					 "file %K is not unlinked",
 306					 &obj_key);
 307			retval = remove_save_link_only(s, &save_link_key, 0);
 308			continue;
 309		}
 310		depth = reiserfs_write_unlock_nested(inode->i_sb);
 311		dquot_initialize(inode);
 312		reiserfs_write_lock_nested(inode->i_sb, depth);
 313
 314		if (truncate && S_ISDIR(inode->i_mode)) {
 315			/*
 316			 * We got a truncate request for a dir which
 317			 * is impossible.  The only imaginable way is to
 318			 * execute unfinished truncate request then boot
 319			 * into old kernel, remove the file and create dir
 320			 * with the same key.
 321			 */
 322			reiserfs_warning(s, "green-2101",
 323					 "impossible truncate on a "
 324					 "directory %k. Please report",
 325					 INODE_PKEY(inode));
 326			retval = remove_save_link_only(s, &save_link_key, 0);
 327			truncate = 0;
 328			iput(inode);
 329			continue;
 330		}
 331
 332		if (truncate) {
 333			REISERFS_I(inode)->i_flags |=
 334			    i_link_saved_truncate_mask;
 335			/*
 336			 * not completed truncate found. New size was
 337			 * committed together with "save" link
 338			 */
 339			reiserfs_info(s, "Truncating %k to %lld ..",
 340				      INODE_PKEY(inode), inode->i_size);
 341
 342			/* don't update modification time */
 343			reiserfs_truncate_file(inode, 0);
 344
 345			retval = remove_save_link(inode, truncate);
 346		} else {
 347			REISERFS_I(inode)->i_flags |= i_link_saved_unlink_mask;
 348			/* not completed unlink (rmdir) found */
 349			reiserfs_info(s, "Removing %k..", INODE_PKEY(inode));
 350			if (memcmp(&last_inode_key, INODE_PKEY(inode),
 351					sizeof(last_inode_key))){
 352				last_inode_key = *INODE_PKEY(inode);
 353				/* removal gets completed in iput */
 354				retval = 0;
 355			} else {
 356				reiserfs_warning(s, "super-2189", "Dead loop "
 357						 "in finish_unfinished "
 358						 "detected, just remove "
 359						 "save link\n");
 360				retval = remove_save_link_only(s,
 361							&save_link_key, 0);
 362			}
 363		}
 364
 365		iput(inode);
 366		printk("done\n");
 367		done++;
 368	}
 369	REISERFS_SB(s)->s_is_unlinked_ok = 0;
 370
 371#ifdef CONFIG_QUOTA
 372	/* Turn quotas off */
 373	reiserfs_write_unlock(s);
 374	for (i = 0; i < REISERFS_MAXQUOTAS; i++) {
 375		if (sb_dqopt(s)->files[i] && quota_enabled[i])
 376			dquot_quota_off(s, i);
 377	}
 378	reiserfs_write_lock(s);
 379	if (ms_active_set)
 380		/* Restore the flag back */
 381		s->s_flags &= ~MS_ACTIVE;
 382#endif
 383	pathrelse(&path);
 384	if (done)
 385		reiserfs_info(s, "There were %d uncompleted unlinks/truncates. "
 386			      "Completed\n", done);
 387	return retval;
 388}
 389
 390/*
 391 * to protect file being unlinked from getting lost we "safe" link files
 392 * being unlinked. This link will be deleted in the same transaction with last
 393 * item of file. mounting the filesystem we scan all these links and remove
 394 * files which almost got lost
 395 */
 396void add_save_link(struct reiserfs_transaction_handle *th,
 397		   struct inode *inode, int truncate)
 398{
 399	INITIALIZE_PATH(path);
 400	int retval;
 401	struct cpu_key key;
 402	struct item_head ih;
 403	__le32 link;
 404
 405	BUG_ON(!th->t_trans_id);
 406
 407	/* file can only get one "save link" of each kind */
 408	RFALSE(truncate &&
 409	       (REISERFS_I(inode)->i_flags & i_link_saved_truncate_mask),
 410	       "saved link already exists for truncated inode %lx",
 411	       (long)inode->i_ino);
 412	RFALSE(!truncate &&
 413	       (REISERFS_I(inode)->i_flags & i_link_saved_unlink_mask),
 414	       "saved link already exists for unlinked inode %lx",
 415	       (long)inode->i_ino);
 416
 417	/* setup key of "save" link */
 418	key.version = KEY_FORMAT_3_5;
 419	key.on_disk_key.k_dir_id = MAX_KEY_OBJECTID;
 420	key.on_disk_key.k_objectid = inode->i_ino;
 421	if (!truncate) {
 422		/* unlink, rmdir, rename */
 423		set_cpu_key_k_offset(&key, 1 + inode->i_sb->s_blocksize);
 424		set_cpu_key_k_type(&key, TYPE_DIRECT);
 425
 426		/* item head of "safe" link */
 427		make_le_item_head(&ih, &key, key.version,
 428				  1 + inode->i_sb->s_blocksize, TYPE_DIRECT,
 429				  4 /*length */ , 0xffff /*free space */ );
 430	} else {
 431		/* truncate */
 432		if (S_ISDIR(inode->i_mode))
 433			reiserfs_warning(inode->i_sb, "green-2102",
 434					 "Adding a truncate savelink for "
 435					 "a directory %k! Please report",
 436					 INODE_PKEY(inode));
 437		set_cpu_key_k_offset(&key, 1);
 438		set_cpu_key_k_type(&key, TYPE_INDIRECT);
 439
 440		/* item head of "safe" link */
 441		make_le_item_head(&ih, &key, key.version, 1, TYPE_INDIRECT,
 442				  4 /*length */ , 0 /*free space */ );
 443	}
 444	key.key_length = 3;
 445
 446	/* look for its place in the tree */
 447	retval = search_item(inode->i_sb, &key, &path);
 448	if (retval != ITEM_NOT_FOUND) {
 449		if (retval != -ENOSPC)
 450			reiserfs_error(inode->i_sb, "vs-2100",
 451				       "search_by_key (%K) returned %d", &key,
 452				       retval);
 453		pathrelse(&path);
 454		return;
 455	}
 456
 457	/* body of "save" link */
 458	link = INODE_PKEY(inode)->k_dir_id;
 459
 460	/* put "save" link into tree, don't charge quota to anyone */
 461	retval =
 462	    reiserfs_insert_item(th, &path, &key, &ih, NULL, (char *)&link);
 463	if (retval) {
 464		if (retval != -ENOSPC)
 465			reiserfs_error(inode->i_sb, "vs-2120",
 466				       "insert_item returned %d", retval);
 467	} else {
 468		if (truncate)
 469			REISERFS_I(inode)->i_flags |=
 470			    i_link_saved_truncate_mask;
 471		else
 472			REISERFS_I(inode)->i_flags |= i_link_saved_unlink_mask;
 473	}
 474}
 475
 476/* this opens transaction unlike add_save_link */
 477int remove_save_link(struct inode *inode, int truncate)
 478{
 479	struct reiserfs_transaction_handle th;
 480	struct reiserfs_key key;
 481	int err;
 482
 483	/* we are going to do one balancing only */
 484	err = journal_begin(&th, inode->i_sb, JOURNAL_PER_BALANCE_CNT);
 485	if (err)
 486		return err;
 487
 488	/* setup key of "save" link */
 489	key.k_dir_id = cpu_to_le32(MAX_KEY_OBJECTID);
 490	key.k_objectid = INODE_PKEY(inode)->k_objectid;
 491	if (!truncate) {
 492		/* unlink, rmdir, rename */
 493		set_le_key_k_offset(KEY_FORMAT_3_5, &key,
 494				    1 + inode->i_sb->s_blocksize);
 495		set_le_key_k_type(KEY_FORMAT_3_5, &key, TYPE_DIRECT);
 496	} else {
 497		/* truncate */
 498		set_le_key_k_offset(KEY_FORMAT_3_5, &key, 1);
 499		set_le_key_k_type(KEY_FORMAT_3_5, &key, TYPE_INDIRECT);
 500	}
 501
 502	if ((truncate &&
 503	     (REISERFS_I(inode)->i_flags & i_link_saved_truncate_mask)) ||
 504	    (!truncate &&
 505	     (REISERFS_I(inode)->i_flags & i_link_saved_unlink_mask)))
 506		/* don't take quota bytes from anywhere */
 507		reiserfs_delete_solid_item(&th, NULL, &key);
 508	if (!truncate) {
 509		reiserfs_release_objectid(&th, inode->i_ino);
 510		REISERFS_I(inode)->i_flags &= ~i_link_saved_unlink_mask;
 511	} else
 512		REISERFS_I(inode)->i_flags &= ~i_link_saved_truncate_mask;
 513
 514	return journal_end(&th);
 515}
 516
 517static void reiserfs_kill_sb(struct super_block *s)
 518{
 519	if (REISERFS_SB(s)) {
 520		reiserfs_proc_info_done(s);
 521		/*
 522		 * Force any pending inode evictions to occur now. Any
 523		 * inodes to be removed that have extended attributes
 524		 * associated with them need to clean them up before
 525		 * we can release the extended attribute root dentries.
 526		 * shrink_dcache_for_umount will BUG if we don't release
 527		 * those before it's called so ->put_super is too late.
 528		 */
 529		shrink_dcache_sb(s);
 530
 531		dput(REISERFS_SB(s)->xattr_root);
 532		REISERFS_SB(s)->xattr_root = NULL;
 533		dput(REISERFS_SB(s)->priv_root);
 534		REISERFS_SB(s)->priv_root = NULL;
 535	}
 536
 537	kill_block_super(s);
 538}
 539
 540static void reiserfs_put_super(struct super_block *s)
 541{
 542	struct reiserfs_transaction_handle th;
 543	th.t_trans_id = 0;
 544
 545	dquot_disable(s, -1, DQUOT_USAGE_ENABLED | DQUOT_LIMITS_ENABLED);
 546
 547	reiserfs_write_lock(s);
 548
 549	/*
 550	 * change file system state to current state if it was mounted
 551	 * with read-write permissions
 552	 */
 553	if (!(s->s_flags & MS_RDONLY)) {
 554		if (!journal_begin(&th, s, 10)) {
 555			reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s),
 556						     1);
 557			set_sb_umount_state(SB_DISK_SUPER_BLOCK(s),
 558					    REISERFS_SB(s)->s_mount_state);
 559			journal_mark_dirty(&th, SB_BUFFER_WITH_SB(s));
 560		}
 561	}
 562
 563	/*
 564	 * note, journal_release checks for readonly mount, and can
 565	 * decide not to do a journal_end
 566	 */
 567	journal_release(&th, s);
 568
 569	reiserfs_free_bitmap_cache(s);
 570
 571	brelse(SB_BUFFER_WITH_SB(s));
 572
 573	print_statistics(s);
 574
 575	if (REISERFS_SB(s)->reserved_blocks != 0) {
 576		reiserfs_warning(s, "green-2005", "reserved blocks left %d",
 577				 REISERFS_SB(s)->reserved_blocks);
 578	}
 579
 
 
 580	reiserfs_write_unlock(s);
 581	mutex_destroy(&REISERFS_SB(s)->lock);
 582	destroy_workqueue(REISERFS_SB(s)->commit_wq);
 583	kfree(s->s_fs_info);
 584	s->s_fs_info = NULL;
 585}
 586
 587static struct kmem_cache *reiserfs_inode_cachep;
 588
 589static struct inode *reiserfs_alloc_inode(struct super_block *sb)
 590{
 591	struct reiserfs_inode_info *ei;
 592	ei = kmem_cache_alloc(reiserfs_inode_cachep, GFP_KERNEL);
 
 593	if (!ei)
 594		return NULL;
 595	atomic_set(&ei->openers, 0);
 596	mutex_init(&ei->tailpack);
 597#ifdef CONFIG_QUOTA
 598	memset(&ei->i_dquot, 0, sizeof(ei->i_dquot));
 599#endif
 600
 601	return &ei->vfs_inode;
 602}
 603
 604static void reiserfs_i_callback(struct rcu_head *head)
 605{
 606	struct inode *inode = container_of(head, struct inode, i_rcu);
 
 607	kmem_cache_free(reiserfs_inode_cachep, REISERFS_I(inode));
 608}
 609
 610static void reiserfs_destroy_inode(struct inode *inode)
 611{
 612	call_rcu(&inode->i_rcu, reiserfs_i_callback);
 613}
 614
 615static void init_once(void *foo)
 616{
 617	struct reiserfs_inode_info *ei = (struct reiserfs_inode_info *)foo;
 618
 619	INIT_LIST_HEAD(&ei->i_prealloc_list);
 620	inode_init_once(&ei->vfs_inode);
 621}
 622
 623static int __init init_inodecache(void)
 624{
 625	reiserfs_inode_cachep = kmem_cache_create("reiser_inode_cache",
 626						  sizeof(struct
 627							 reiserfs_inode_info),
 628						  0, (SLAB_RECLAIM_ACCOUNT|
 629						      SLAB_MEM_SPREAD|
 630						      SLAB_ACCOUNT),
 631						  init_once);
 632	if (reiserfs_inode_cachep == NULL)
 633		return -ENOMEM;
 634	return 0;
 635}
 636
 637static void destroy_inodecache(void)
 638{
 639	/*
 640	 * Make sure all delayed rcu free inodes are flushed before we
 641	 * destroy cache.
 642	 */
 643	rcu_barrier();
 644	kmem_cache_destroy(reiserfs_inode_cachep);
 645}
 646
 647/* we don't mark inodes dirty, we just log them */
 648static void reiserfs_dirty_inode(struct inode *inode, int flags)
 649{
 650	struct reiserfs_transaction_handle th;
 651
 652	int err = 0;
 
 653
 654	if (inode->i_sb->s_flags & MS_RDONLY) {
 655		reiserfs_warning(inode->i_sb, "clm-6006",
 656				 "writing inode %lu on readonly FS",
 657				 inode->i_ino);
 658		return;
 659	}
 660	reiserfs_write_lock(inode->i_sb);
 661
 662	/*
 663	 * this is really only used for atime updates, so they don't have
 664	 * to be included in O_SYNC or fsync
 665	 */
 666	err = journal_begin(&th, inode->i_sb, 1);
 667	if (err)
 668		goto out;
 669
 670	reiserfs_update_sd(&th, inode);
 671	journal_end(&th);
 672
 673out:
 674	reiserfs_write_unlock(inode->i_sb);
 675}
 676
 677static int reiserfs_show_options(struct seq_file *seq, struct dentry *root)
 678{
 679	struct super_block *s = root->d_sb;
 680	struct reiserfs_journal *journal = SB_JOURNAL(s);
 681	long opts = REISERFS_SB(s)->s_mount_opt;
 682
 683	if (opts & (1 << REISERFS_LARGETAIL))
 684		seq_puts(seq, ",tails=on");
 685	else if (!(opts & (1 << REISERFS_SMALLTAIL)))
 686		seq_puts(seq, ",notail");
 687	/* tails=small is default so we don't show it */
 688
 689	if (!(opts & (1 << REISERFS_BARRIER_FLUSH)))
 690		seq_puts(seq, ",barrier=none");
 691	/* barrier=flush is default so we don't show it */
 692
 693	if (opts & (1 << REISERFS_ERROR_CONTINUE))
 694		seq_puts(seq, ",errors=continue");
 695	else if (opts & (1 << REISERFS_ERROR_PANIC))
 696		seq_puts(seq, ",errors=panic");
 697	/* errors=ro is default so we don't show it */
 698
 699	if (opts & (1 << REISERFS_DATA_LOG))
 700		seq_puts(seq, ",data=journal");
 701	else if (opts & (1 << REISERFS_DATA_WRITEBACK))
 702		seq_puts(seq, ",data=writeback");
 703	/* data=ordered is default so we don't show it */
 704
 705	if (opts & (1 << REISERFS_ATTRS))
 706		seq_puts(seq, ",attrs");
 707
 708	if (opts & (1 << REISERFS_XATTRS_USER))
 709		seq_puts(seq, ",user_xattr");
 710
 711	if (opts & (1 << REISERFS_EXPOSE_PRIVROOT))
 712		seq_puts(seq, ",expose_privroot");
 713
 714	if (opts & (1 << REISERFS_POSIXACL))
 715		seq_puts(seq, ",acl");
 716
 717	if (REISERFS_SB(s)->s_jdev)
 718		seq_show_option(seq, "jdev", REISERFS_SB(s)->s_jdev);
 719
 720	if (journal->j_max_commit_age != journal->j_default_max_commit_age)
 721		seq_printf(seq, ",commit=%d", journal->j_max_commit_age);
 722
 723#ifdef CONFIG_QUOTA
 724	if (REISERFS_SB(s)->s_qf_names[USRQUOTA])
 725		seq_show_option(seq, "usrjquota",
 726				REISERFS_SB(s)->s_qf_names[USRQUOTA]);
 727	else if (opts & (1 << REISERFS_USRQUOTA))
 728		seq_puts(seq, ",usrquota");
 729	if (REISERFS_SB(s)->s_qf_names[GRPQUOTA])
 730		seq_show_option(seq, "grpjquota",
 731				REISERFS_SB(s)->s_qf_names[GRPQUOTA]);
 732	else if (opts & (1 << REISERFS_GRPQUOTA))
 733		seq_puts(seq, ",grpquota");
 734	if (REISERFS_SB(s)->s_jquota_fmt) {
 735		if (REISERFS_SB(s)->s_jquota_fmt == QFMT_VFS_OLD)
 736			seq_puts(seq, ",jqfmt=vfsold");
 737		else if (REISERFS_SB(s)->s_jquota_fmt == QFMT_VFS_V0)
 738			seq_puts(seq, ",jqfmt=vfsv0");
 739	}
 740#endif
 741
 742	/* Block allocator options */
 743	if (opts & (1 << REISERFS_NO_BORDER))
 744		seq_puts(seq, ",block-allocator=noborder");
 745	if (opts & (1 << REISERFS_NO_UNHASHED_RELOCATION))
 746		seq_puts(seq, ",block-allocator=no_unhashed_relocation");
 747	if (opts & (1 << REISERFS_HASHED_RELOCATION))
 748		seq_puts(seq, ",block-allocator=hashed_relocation");
 749	if (opts & (1 << REISERFS_TEST4))
 750		seq_puts(seq, ",block-allocator=test4");
 751	show_alloc_options(seq, s);
 752	return 0;
 753}
 754
 755#ifdef CONFIG_QUOTA
 756static ssize_t reiserfs_quota_write(struct super_block *, int, const char *,
 757				    size_t, loff_t);
 758static ssize_t reiserfs_quota_read(struct super_block *, int, char *, size_t,
 759				   loff_t);
 760
 761static struct dquot **reiserfs_get_dquots(struct inode *inode)
 762{
 763	return REISERFS_I(inode)->i_dquot;
 764}
 765#endif
 766
 767static const struct super_operations reiserfs_sops = {
 768	.alloc_inode = reiserfs_alloc_inode,
 769	.destroy_inode = reiserfs_destroy_inode,
 770	.write_inode = reiserfs_write_inode,
 771	.dirty_inode = reiserfs_dirty_inode,
 772	.evict_inode = reiserfs_evict_inode,
 773	.put_super = reiserfs_put_super,
 
 774	.sync_fs = reiserfs_sync_fs,
 775	.freeze_fs = reiserfs_freeze,
 776	.unfreeze_fs = reiserfs_unfreeze,
 777	.statfs = reiserfs_statfs,
 778	.remount_fs = reiserfs_remount,
 779	.show_options = reiserfs_show_options,
 780#ifdef CONFIG_QUOTA
 781	.quota_read = reiserfs_quota_read,
 782	.quota_write = reiserfs_quota_write,
 783	.get_dquots = reiserfs_get_dquots,
 784#endif
 785};
 786
 787#ifdef CONFIG_QUOTA
 788#define QTYPE2NAME(t) ((t)==USRQUOTA?"user":"group")
 789
 790static int reiserfs_write_dquot(struct dquot *);
 791static int reiserfs_acquire_dquot(struct dquot *);
 792static int reiserfs_release_dquot(struct dquot *);
 793static int reiserfs_mark_dquot_dirty(struct dquot *);
 794static int reiserfs_write_info(struct super_block *, int);
 795static int reiserfs_quota_on(struct super_block *, int, int, struct path *);
 796
 797static const struct dquot_operations reiserfs_quota_operations = {
 798	.write_dquot = reiserfs_write_dquot,
 799	.acquire_dquot = reiserfs_acquire_dquot,
 800	.release_dquot = reiserfs_release_dquot,
 801	.mark_dirty = reiserfs_mark_dquot_dirty,
 802	.write_info = reiserfs_write_info,
 803	.alloc_dquot	= dquot_alloc,
 804	.destroy_dquot	= dquot_destroy,
 805	.get_next_id	= dquot_get_next_id,
 806};
 807
 808static const struct quotactl_ops reiserfs_qctl_operations = {
 809	.quota_on = reiserfs_quota_on,
 810	.quota_off = dquot_quota_off,
 811	.quota_sync = dquot_quota_sync,
 812	.get_state = dquot_get_state,
 813	.set_info = dquot_set_dqinfo,
 814	.get_dqblk = dquot_get_dqblk,
 815	.set_dqblk = dquot_set_dqblk,
 816};
 817#endif
 818
 819static const struct export_operations reiserfs_export_ops = {
 820	.encode_fh = reiserfs_encode_fh,
 821	.fh_to_dentry = reiserfs_fh_to_dentry,
 822	.fh_to_parent = reiserfs_fh_to_parent,
 823	.get_parent = reiserfs_get_parent,
 824};
 825
 826/*
 827 * this struct is used in reiserfs_getopt () for containing the value for
 828 * those mount options that have values rather than being toggles.
 829 */
 830typedef struct {
 831	char *value;
 832	/*
 833	 * bitmask which is to set on mount_options bitmask
 834	 * when this value is found, 0 is no bits are to be changed.
 835	 */
 836	int setmask;
 837	/*
 838	 * bitmask which is to clear on mount_options bitmask
 839	 * when this value is found, 0 is no bits are to be changed.
 840	 * This is applied BEFORE setmask
 841	 */
 842	int clrmask;
 843} arg_desc_t;
 844
 845/* Set this bit in arg_required to allow empty arguments */
 846#define REISERFS_OPT_ALLOWEMPTY 31
 847
 848/*
 849 * this struct is used in reiserfs_getopt() for describing the
 850 * set of reiserfs mount options
 851 */
 852typedef struct {
 853	char *option_name;
 854
 855	/* 0 if argument is not required, not 0 otherwise */
 856	int arg_required;
 857
 858	/* list of values accepted by an option */
 859	const arg_desc_t *values;
 860
 861	/*
 862	 * bitmask which is to set on mount_options bitmask
 863	 * when this value is found, 0 is no bits are to be changed.
 864	 */
 865	int setmask;
 866
 867	/*
 868	 * bitmask which is to clear on mount_options bitmask
 869	 * when this value is found, 0 is no bits are to be changed.
 870	 * This is applied BEFORE setmask
 871	 */
 872	int clrmask;
 873} opt_desc_t;
 874
 875/* possible values for -o data= */
 876static const arg_desc_t logging_mode[] = {
 877	{"ordered", 1 << REISERFS_DATA_ORDERED,
 878	 (1 << REISERFS_DATA_LOG | 1 << REISERFS_DATA_WRITEBACK)},
 879	{"journal", 1 << REISERFS_DATA_LOG,
 880	 (1 << REISERFS_DATA_ORDERED | 1 << REISERFS_DATA_WRITEBACK)},
 881	{"writeback", 1 << REISERFS_DATA_WRITEBACK,
 882	 (1 << REISERFS_DATA_ORDERED | 1 << REISERFS_DATA_LOG)},
 883	{.value = NULL}
 884};
 885
 886/* possible values for -o barrier= */
 887static const arg_desc_t barrier_mode[] = {
 888	{"none", 1 << REISERFS_BARRIER_NONE, 1 << REISERFS_BARRIER_FLUSH},
 889	{"flush", 1 << REISERFS_BARRIER_FLUSH, 1 << REISERFS_BARRIER_NONE},
 890	{.value = NULL}
 891};
 892
 893/*
 894 * possible values for "-o block-allocator=" and bits which are to be set in
 895 * s_mount_opt of reiserfs specific part of in-core super block
 896 */
 897static const arg_desc_t balloc[] = {
 898	{"noborder", 1 << REISERFS_NO_BORDER, 0},
 899	{"border", 0, 1 << REISERFS_NO_BORDER},
 900	{"no_unhashed_relocation", 1 << REISERFS_NO_UNHASHED_RELOCATION, 0},
 901	{"hashed_relocation", 1 << REISERFS_HASHED_RELOCATION, 0},
 902	{"test4", 1 << REISERFS_TEST4, 0},
 903	{"notest4", 0, 1 << REISERFS_TEST4},
 904	{NULL, 0, 0}
 905};
 906
 907static const arg_desc_t tails[] = {
 908	{"on", 1 << REISERFS_LARGETAIL, 1 << REISERFS_SMALLTAIL},
 909	{"off", 0, (1 << REISERFS_LARGETAIL) | (1 << REISERFS_SMALLTAIL)},
 910	{"small", 1 << REISERFS_SMALLTAIL, 1 << REISERFS_LARGETAIL},
 911	{NULL, 0, 0}
 912};
 913
 914static const arg_desc_t error_actions[] = {
 915	{"panic", 1 << REISERFS_ERROR_PANIC,
 916	 (1 << REISERFS_ERROR_RO | 1 << REISERFS_ERROR_CONTINUE)},
 917	{"ro-remount", 1 << REISERFS_ERROR_RO,
 918	 (1 << REISERFS_ERROR_PANIC | 1 << REISERFS_ERROR_CONTINUE)},
 919#ifdef REISERFS_JOURNAL_ERROR_ALLOWS_NO_LOG
 920	{"continue", 1 << REISERFS_ERROR_CONTINUE,
 921	 (1 << REISERFS_ERROR_PANIC | 1 << REISERFS_ERROR_RO)},
 922#endif
 923	{NULL, 0, 0},
 924};
 925
 926/*
 927 * proceed only one option from a list *cur - string containing of mount
 928 * options
 929 * opts - array of options which are accepted
 930 * opt_arg - if option is found and requires an argument and if it is specifed
 931 * in the input - pointer to the argument is stored here
 932 * bit_flags - if option requires to set a certain bit - it is set here
 933 * return -1 if unknown option is found, opt->arg_required otherwise
 934 */
 935static int reiserfs_getopt(struct super_block *s, char **cur, opt_desc_t * opts,
 936			   char **opt_arg, unsigned long *bit_flags)
 937{
 938	char *p;
 939	/*
 940	 * foo=bar,
 941	 * ^   ^  ^
 942	 * |   |  +-- option_end
 943	 * |   +-- arg_start
 944	 * +-- option_start
 945	 */
 946	const opt_desc_t *opt;
 947	const arg_desc_t *arg;
 948
 949	p = *cur;
 950
 951	/* assume argument cannot contain commas */
 952	*cur = strchr(p, ',');
 953	if (*cur) {
 954		*(*cur) = '\0';
 955		(*cur)++;
 956	}
 957
 958	if (!strncmp(p, "alloc=", 6)) {
 959		/*
 960		 * Ugly special case, probably we should redo options
 961		 * parser so that it can understand several arguments for
 962		 * some options, also so that it can fill several bitfields
 963		 * with option values.
 964		 */
 965		if (reiserfs_parse_alloc_options(s, p + 6)) {
 966			return -1;
 967		} else {
 968			return 0;
 969		}
 970	}
 971
 972	/* for every option in the list */
 973	for (opt = opts; opt->option_name; opt++) {
 974		if (!strncmp(p, opt->option_name, strlen(opt->option_name))) {
 975			if (bit_flags) {
 976				if (opt->clrmask ==
 977				    (1 << REISERFS_UNSUPPORTED_OPT))
 978					reiserfs_warning(s, "super-6500",
 979							 "%s not supported.\n",
 980							 p);
 981				else
 982					*bit_flags &= ~opt->clrmask;
 983				if (opt->setmask ==
 984				    (1 << REISERFS_UNSUPPORTED_OPT))
 985					reiserfs_warning(s, "super-6501",
 986							 "%s not supported.\n",
 987							 p);
 988				else
 989					*bit_flags |= opt->setmask;
 990			}
 991			break;
 992		}
 993	}
 994	if (!opt->option_name) {
 995		reiserfs_warning(s, "super-6502",
 996				 "unknown mount option \"%s\"", p);
 997		return -1;
 998	}
 999
1000	p += strlen(opt->option_name);
1001	switch (*p) {
1002	case '=':
1003		if (!opt->arg_required) {
1004			reiserfs_warning(s, "super-6503",
1005					 "the option \"%s\" does not "
1006					 "require an argument\n",
1007					 opt->option_name);
1008			return -1;
1009		}
1010		break;
1011
1012	case 0:
1013		if (opt->arg_required) {
1014			reiserfs_warning(s, "super-6504",
1015					 "the option \"%s\" requires an "
1016					 "argument\n", opt->option_name);
1017			return -1;
1018		}
1019		break;
1020	default:
1021		reiserfs_warning(s, "super-6505",
1022				 "head of option \"%s\" is only correct\n",
1023				 opt->option_name);
1024		return -1;
1025	}
1026
1027	/*
1028	 * move to the argument, or to next option if argument is not
1029	 * required
1030	 */
1031	p++;
1032
1033	if (opt->arg_required
1034	    && !(opt->arg_required & (1 << REISERFS_OPT_ALLOWEMPTY))
1035	    && !strlen(p)) {
1036		/* this catches "option=," if not allowed */
1037		reiserfs_warning(s, "super-6506",
1038				 "empty argument for \"%s\"\n",
1039				 opt->option_name);
1040		return -1;
1041	}
1042
1043	if (!opt->values) {
1044		/* *=NULLopt_arg contains pointer to argument */
1045		*opt_arg = p;
1046		return opt->arg_required & ~(1 << REISERFS_OPT_ALLOWEMPTY);
1047	}
1048
1049	/* values possible for this option are listed in opt->values */
1050	for (arg = opt->values; arg->value; arg++) {
1051		if (!strcmp(p, arg->value)) {
1052			if (bit_flags) {
1053				*bit_flags &= ~arg->clrmask;
1054				*bit_flags |= arg->setmask;
1055			}
1056			return opt->arg_required;
1057		}
1058	}
1059
1060	reiserfs_warning(s, "super-6506",
1061			 "bad value \"%s\" for option \"%s\"\n", p,
1062			 opt->option_name);
1063	return -1;
1064}
1065
1066/* returns 0 if something is wrong in option string, 1 - otherwise */
1067static int reiserfs_parse_options(struct super_block *s,
1068
1069				  /* string given via mount's -o */
1070				  char *options,
1071
1072				  /*
1073				   * after the parsing phase, contains the
1074				   * collection of bitflags defining what
1075				   * mount options were selected.
1076				   */
1077				  unsigned long *mount_options,
1078
1079				  /* strtol-ed from NNN of resize=NNN */
1080				  unsigned long *blocks,
 
1081				  char **jdev_name,
1082				  unsigned int *commit_max_age,
1083				  char **qf_names,
1084				  unsigned int *qfmt)
1085{
1086	int c;
1087	char *arg = NULL;
1088	char *pos;
1089	opt_desc_t opts[] = {
1090		/*
1091		 * Compatibility stuff, so that -o notail for old
1092		 * setups still work
1093		 */
1094		{"tails",.arg_required = 't',.values = tails},
1095		{"notail",.clrmask =
1096		 (1 << REISERFS_LARGETAIL) | (1 << REISERFS_SMALLTAIL)},
1097		{"conv",.setmask = 1 << REISERFS_CONVERT},
1098		{"attrs",.setmask = 1 << REISERFS_ATTRS},
1099		{"noattrs",.clrmask = 1 << REISERFS_ATTRS},
1100		{"expose_privroot", .setmask = 1 << REISERFS_EXPOSE_PRIVROOT},
1101#ifdef CONFIG_REISERFS_FS_XATTR
1102		{"user_xattr",.setmask = 1 << REISERFS_XATTRS_USER},
1103		{"nouser_xattr",.clrmask = 1 << REISERFS_XATTRS_USER},
1104#else
1105		{"user_xattr",.setmask = 1 << REISERFS_UNSUPPORTED_OPT},
1106		{"nouser_xattr",.clrmask = 1 << REISERFS_UNSUPPORTED_OPT},
1107#endif
1108#ifdef CONFIG_REISERFS_FS_POSIX_ACL
1109		{"acl",.setmask = 1 << REISERFS_POSIXACL},
1110		{"noacl",.clrmask = 1 << REISERFS_POSIXACL},
1111#else
1112		{"acl",.setmask = 1 << REISERFS_UNSUPPORTED_OPT},
1113		{"noacl",.clrmask = 1 << REISERFS_UNSUPPORTED_OPT},
1114#endif
1115		{.option_name = "nolog"},
1116		{"replayonly",.setmask = 1 << REPLAYONLY},
1117		{"block-allocator",.arg_required = 'a',.values = balloc},
1118		{"data",.arg_required = 'd',.values = logging_mode},
1119		{"barrier",.arg_required = 'b',.values = barrier_mode},
1120		{"resize",.arg_required = 'r',.values = NULL},
1121		{"jdev",.arg_required = 'j',.values = NULL},
1122		{"nolargeio",.arg_required = 'w',.values = NULL},
1123		{"commit",.arg_required = 'c',.values = NULL},
1124		{"usrquota",.setmask = 1 << REISERFS_USRQUOTA},
1125		{"grpquota",.setmask = 1 << REISERFS_GRPQUOTA},
1126		{"noquota",.clrmask = 1 << REISERFS_USRQUOTA | 1 << REISERFS_GRPQUOTA},
1127		{"errors",.arg_required = 'e',.values = error_actions},
1128		{"usrjquota",.arg_required =
1129		 'u' | (1 << REISERFS_OPT_ALLOWEMPTY),.values = NULL},
1130		{"grpjquota",.arg_required =
1131		 'g' | (1 << REISERFS_OPT_ALLOWEMPTY),.values = NULL},
1132		{"jqfmt",.arg_required = 'f',.values = NULL},
1133		{.option_name = NULL}
1134	};
1135
1136	*blocks = 0;
1137	if (!options || !*options)
1138		/*
1139		 * use default configuration: create tails, journaling on, no
1140		 * conversion to newest format
1141		 */
1142		return 1;
1143
1144	for (pos = options; pos;) {
1145		c = reiserfs_getopt(s, &pos, opts, &arg, mount_options);
1146		if (c == -1)
1147			/* wrong option is given */
1148			return 0;
1149
1150		if (c == 'r') {
1151			char *p;
1152
1153			p = NULL;
1154			/* "resize=NNN" or "resize=auto" */
1155
1156			if (!strcmp(arg, "auto")) {
1157				/* From JFS code, to auto-get the size. */
1158				*blocks =
1159				    s->s_bdev->bd_inode->i_size >> s->
1160				    s_blocksize_bits;
1161			} else {
1162				*blocks = simple_strtoul(arg, &p, 0);
1163				if (*p != '\0') {
1164					/* NNN does not look like a number */
1165					reiserfs_warning(s, "super-6507",
1166							 "bad value %s for "
1167							 "-oresize\n", arg);
1168					return 0;
1169				}
1170			}
1171		}
1172
1173		if (c == 'c') {
1174			char *p = NULL;
1175			unsigned long val = simple_strtoul(arg, &p, 0);
1176			/* commit=NNN (time in seconds) */
1177			if (*p != '\0' || val >= (unsigned int)-1) {
1178				reiserfs_warning(s, "super-6508",
1179						 "bad value %s for -ocommit\n",
1180						 arg);
1181				return 0;
1182			}
1183			*commit_max_age = (unsigned int)val;
1184		}
1185
1186		if (c == 'w') {
1187			reiserfs_warning(s, "super-6509", "nolargeio option "
1188					 "is no longer supported");
1189			return 0;
1190		}
1191
1192		if (c == 'j') {
1193			if (arg && *arg && jdev_name) {
1194				/* Hm, already assigned? */
1195				if (*jdev_name) {
1196					reiserfs_warning(s, "super-6510",
1197							 "journal device was "
1198							 "already specified to "
1199							 "be %s", *jdev_name);
1200					return 0;
1201				}
1202				*jdev_name = arg;
1203			}
1204		}
1205#ifdef CONFIG_QUOTA
1206		if (c == 'u' || c == 'g') {
1207			int qtype = c == 'u' ? USRQUOTA : GRPQUOTA;
1208
1209			if (sb_any_quota_loaded(s) &&
1210			    (!*arg != !REISERFS_SB(s)->s_qf_names[qtype])) {
1211				reiserfs_warning(s, "super-6511",
1212						 "cannot change journaled "
1213						 "quota options when quota "
1214						 "turned on.");
1215				return 0;
1216			}
1217			if (*arg) {	/* Some filename specified? */
1218				if (REISERFS_SB(s)->s_qf_names[qtype]
1219				    && strcmp(REISERFS_SB(s)->s_qf_names[qtype],
1220					      arg)) {
1221					reiserfs_warning(s, "super-6512",
1222							 "%s quota file "
1223							 "already specified.",
1224							 QTYPE2NAME(qtype));
1225					return 0;
1226				}
1227				if (strchr(arg, '/')) {
1228					reiserfs_warning(s, "super-6513",
1229							 "quotafile must be "
1230							 "on filesystem root.");
1231					return 0;
1232				}
1233				qf_names[qtype] = kstrdup(arg, GFP_KERNEL);
 
1234				if (!qf_names[qtype]) {
1235					reiserfs_warning(s, "reiserfs-2502",
1236							 "not enough memory "
1237							 "for storing "
1238							 "quotafile name.");
1239					return 0;
1240				}
1241				if (qtype == USRQUOTA)
1242					*mount_options |= 1 << REISERFS_USRQUOTA;
1243				else
1244					*mount_options |= 1 << REISERFS_GRPQUOTA;
1245			} else {
1246				if (qf_names[qtype] !=
1247				    REISERFS_SB(s)->s_qf_names[qtype])
1248					kfree(qf_names[qtype]);
1249				qf_names[qtype] = NULL;
1250				if (qtype == USRQUOTA)
1251					*mount_options &= ~(1 << REISERFS_USRQUOTA);
1252				else
1253					*mount_options &= ~(1 << REISERFS_GRPQUOTA);
1254			}
1255		}
1256		if (c == 'f') {
1257			if (!strcmp(arg, "vfsold"))
1258				*qfmt = QFMT_VFS_OLD;
1259			else if (!strcmp(arg, "vfsv0"))
1260				*qfmt = QFMT_VFS_V0;
1261			else {
1262				reiserfs_warning(s, "super-6514",
1263						 "unknown quota format "
1264						 "specified.");
1265				return 0;
1266			}
1267			if (sb_any_quota_loaded(s) &&
1268			    *qfmt != REISERFS_SB(s)->s_jquota_fmt) {
1269				reiserfs_warning(s, "super-6515",
1270						 "cannot change journaled "
1271						 "quota options when quota "
1272						 "turned on.");
1273				return 0;
1274			}
1275		}
1276#else
1277		if (c == 'u' || c == 'g' || c == 'f') {
1278			reiserfs_warning(s, "reiserfs-2503", "journaled "
1279					 "quota options not supported.");
1280			return 0;
1281		}
1282#endif
1283	}
1284
1285#ifdef CONFIG_QUOTA
1286	if (!REISERFS_SB(s)->s_jquota_fmt && !*qfmt
1287	    && (qf_names[USRQUOTA] || qf_names[GRPQUOTA])) {
1288		reiserfs_warning(s, "super-6515",
1289				 "journaled quota format not specified.");
1290		return 0;
1291	}
1292	if ((!(*mount_options & (1 << REISERFS_USRQUOTA)) &&
1293	       sb_has_quota_loaded(s, USRQUOTA)) ||
1294	    (!(*mount_options & (1 << REISERFS_GRPQUOTA)) &&
1295	       sb_has_quota_loaded(s, GRPQUOTA))) {
1296		reiserfs_warning(s, "super-6516", "quota options must "
1297				 "be present when quota is turned on.");
1298		return 0;
1299	}
1300#endif
1301
1302	return 1;
1303}
1304
1305static void switch_data_mode(struct super_block *s, unsigned long mode)
1306{
1307	REISERFS_SB(s)->s_mount_opt &= ~((1 << REISERFS_DATA_LOG) |
1308					 (1 << REISERFS_DATA_ORDERED) |
1309					 (1 << REISERFS_DATA_WRITEBACK));
1310	REISERFS_SB(s)->s_mount_opt |= (1 << mode);
1311}
1312
1313static void handle_data_mode(struct super_block *s, unsigned long mount_options)
1314{
1315	if (mount_options & (1 << REISERFS_DATA_LOG)) {
1316		if (!reiserfs_data_log(s)) {
1317			switch_data_mode(s, REISERFS_DATA_LOG);
1318			reiserfs_info(s, "switching to journaled data mode\n");
1319		}
1320	} else if (mount_options & (1 << REISERFS_DATA_ORDERED)) {
1321		if (!reiserfs_data_ordered(s)) {
1322			switch_data_mode(s, REISERFS_DATA_ORDERED);
1323			reiserfs_info(s, "switching to ordered data mode\n");
1324		}
1325	} else if (mount_options & (1 << REISERFS_DATA_WRITEBACK)) {
1326		if (!reiserfs_data_writeback(s)) {
1327			switch_data_mode(s, REISERFS_DATA_WRITEBACK);
1328			reiserfs_info(s, "switching to writeback data mode\n");
1329		}
1330	}
1331}
1332
1333static void handle_barrier_mode(struct super_block *s, unsigned long bits)
1334{
1335	int flush = (1 << REISERFS_BARRIER_FLUSH);
1336	int none = (1 << REISERFS_BARRIER_NONE);
1337	int all_barrier = flush | none;
1338
1339	if (bits & all_barrier) {
1340		REISERFS_SB(s)->s_mount_opt &= ~all_barrier;
1341		if (bits & flush) {
1342			REISERFS_SB(s)->s_mount_opt |= flush;
1343			printk("reiserfs: enabling write barrier flush mode\n");
1344		} else if (bits & none) {
1345			REISERFS_SB(s)->s_mount_opt |= none;
1346			printk("reiserfs: write barriers turned off\n");
1347		}
1348	}
1349}
1350
1351static void handle_attrs(struct super_block *s)
1352{
1353	struct reiserfs_super_block *rs = SB_DISK_SUPER_BLOCK(s);
1354
1355	if (reiserfs_attrs(s)) {
1356		if (old_format_only(s)) {
1357			reiserfs_warning(s, "super-6517", "cannot support "
1358					 "attributes on 3.5.x disk format");
1359			REISERFS_SB(s)->s_mount_opt &= ~(1 << REISERFS_ATTRS);
1360			return;
1361		}
1362		if (!(le32_to_cpu(rs->s_flags) & reiserfs_attrs_cleared)) {
1363			reiserfs_warning(s, "super-6518", "cannot support "
1364					 "attributes until flag is set in "
1365					 "super-block");
1366			REISERFS_SB(s)->s_mount_opt &= ~(1 << REISERFS_ATTRS);
1367		}
1368	}
1369}
1370
1371#ifdef CONFIG_QUOTA
1372static void handle_quota_files(struct super_block *s, char **qf_names,
1373			       unsigned int *qfmt)
1374{
1375	int i;
1376
1377	for (i = 0; i < REISERFS_MAXQUOTAS; i++) {
1378		if (qf_names[i] != REISERFS_SB(s)->s_qf_names[i])
1379			kfree(REISERFS_SB(s)->s_qf_names[i]);
1380		REISERFS_SB(s)->s_qf_names[i] = qf_names[i];
1381	}
1382	if (*qfmt)
1383		REISERFS_SB(s)->s_jquota_fmt = *qfmt;
1384}
1385#endif
1386
1387static int reiserfs_remount(struct super_block *s, int *mount_flags, char *arg)
1388{
1389	struct reiserfs_super_block *rs;
1390	struct reiserfs_transaction_handle th;
1391	unsigned long blocks;
1392	unsigned long mount_options = REISERFS_SB(s)->s_mount_opt;
1393	unsigned long safe_mask = 0;
1394	unsigned int commit_max_age = (unsigned int)-1;
1395	struct reiserfs_journal *journal = SB_JOURNAL(s);
1396	char *new_opts = kstrdup(arg, GFP_KERNEL);
1397	int err;
1398	char *qf_names[REISERFS_MAXQUOTAS];
1399	unsigned int qfmt = 0;
1400#ifdef CONFIG_QUOTA
1401	int i;
1402#endif
1403
1404	sync_filesystem(s);
1405	reiserfs_write_lock(s);
1406
1407#ifdef CONFIG_QUOTA
1408	memcpy(qf_names, REISERFS_SB(s)->s_qf_names, sizeof(qf_names));
1409#endif
1410
1411	rs = SB_DISK_SUPER_BLOCK(s);
1412
1413	if (!reiserfs_parse_options
1414	    (s, arg, &mount_options, &blocks, NULL, &commit_max_age,
1415	    qf_names, &qfmt)) {
1416#ifdef CONFIG_QUOTA
1417		for (i = 0; i < REISERFS_MAXQUOTAS; i++)
1418			if (qf_names[i] != REISERFS_SB(s)->s_qf_names[i])
1419				kfree(qf_names[i]);
1420#endif
1421		err = -EINVAL;
1422		goto out_err_unlock;
1423	}
1424#ifdef CONFIG_QUOTA
1425	handle_quota_files(s, qf_names, &qfmt);
1426#endif
1427
1428	handle_attrs(s);
1429
1430	/* Add options that are safe here */
1431	safe_mask |= 1 << REISERFS_SMALLTAIL;
1432	safe_mask |= 1 << REISERFS_LARGETAIL;
1433	safe_mask |= 1 << REISERFS_NO_BORDER;
1434	safe_mask |= 1 << REISERFS_NO_UNHASHED_RELOCATION;
1435	safe_mask |= 1 << REISERFS_HASHED_RELOCATION;
1436	safe_mask |= 1 << REISERFS_TEST4;
1437	safe_mask |= 1 << REISERFS_ATTRS;
1438	safe_mask |= 1 << REISERFS_XATTRS_USER;
1439	safe_mask |= 1 << REISERFS_POSIXACL;
1440	safe_mask |= 1 << REISERFS_BARRIER_FLUSH;
1441	safe_mask |= 1 << REISERFS_BARRIER_NONE;
1442	safe_mask |= 1 << REISERFS_ERROR_RO;
1443	safe_mask |= 1 << REISERFS_ERROR_CONTINUE;
1444	safe_mask |= 1 << REISERFS_ERROR_PANIC;
1445	safe_mask |= 1 << REISERFS_USRQUOTA;
1446	safe_mask |= 1 << REISERFS_GRPQUOTA;
1447
1448	/*
1449	 * Update the bitmask, taking care to keep
1450	 * the bits we're not allowed to change here
1451	 */
1452	REISERFS_SB(s)->s_mount_opt =
1453	    (REISERFS_SB(s)->
1454	     s_mount_opt & ~safe_mask) | (mount_options & safe_mask);
1455
1456	if (commit_max_age != 0 && commit_max_age != (unsigned int)-1) {
1457		journal->j_max_commit_age = commit_max_age;
1458		journal->j_max_trans_age = commit_max_age;
1459	} else if (commit_max_age == 0) {
1460		/* 0 means restore defaults. */
1461		journal->j_max_commit_age = journal->j_default_max_commit_age;
1462		journal->j_max_trans_age = JOURNAL_MAX_TRANS_AGE;
1463	}
1464
1465	if (blocks) {
1466		err = reiserfs_resize(s, blocks);
1467		if (err != 0)
1468			goto out_err_unlock;
1469	}
1470
1471	if (*mount_flags & MS_RDONLY) {
1472		reiserfs_write_unlock(s);
1473		reiserfs_xattr_init(s, *mount_flags);
1474		/* remount read-only */
1475		if (s->s_flags & MS_RDONLY)
1476			/* it is read-only already */
1477			goto out_ok_unlocked;
1478
1479		err = dquot_suspend(s, -1);
1480		if (err < 0)
1481			goto out_err;
1482
1483		/* try to remount file system with read-only permissions */
1484		if (sb_umount_state(rs) == REISERFS_VALID_FS
1485		    || REISERFS_SB(s)->s_mount_state != REISERFS_VALID_FS) {
1486			goto out_ok_unlocked;
1487		}
1488
1489		reiserfs_write_lock(s);
1490
1491		err = journal_begin(&th, s, 10);
1492		if (err)
1493			goto out_err_unlock;
1494
1495		/* Mounting a rw partition read-only. */
1496		reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s), 1);
1497		set_sb_umount_state(rs, REISERFS_SB(s)->s_mount_state);
1498		journal_mark_dirty(&th, SB_BUFFER_WITH_SB(s));
1499	} else {
1500		/* remount read-write */
1501		if (!(s->s_flags & MS_RDONLY)) {
1502			reiserfs_write_unlock(s);
1503			reiserfs_xattr_init(s, *mount_flags);
1504			goto out_ok_unlocked;	/* We are read-write already */
1505		}
1506
1507		if (reiserfs_is_journal_aborted(journal)) {
1508			err = journal->j_errno;
1509			goto out_err_unlock;
1510		}
1511
1512		handle_data_mode(s, mount_options);
1513		handle_barrier_mode(s, mount_options);
1514		REISERFS_SB(s)->s_mount_state = sb_umount_state(rs);
1515
1516		/* now it is safe to call journal_begin */
1517		s->s_flags &= ~MS_RDONLY;
1518		err = journal_begin(&th, s, 10);
1519		if (err)
1520			goto out_err_unlock;
1521
1522		/* Mount a partition which is read-only, read-write */
1523		reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s), 1);
1524		REISERFS_SB(s)->s_mount_state = sb_umount_state(rs);
1525		s->s_flags &= ~MS_RDONLY;
1526		set_sb_umount_state(rs, REISERFS_ERROR_FS);
1527		if (!old_format_only(s))
1528			set_sb_mnt_count(rs, sb_mnt_count(rs) + 1);
1529		/* mark_buffer_dirty (SB_BUFFER_WITH_SB (s), 1); */
1530		journal_mark_dirty(&th, SB_BUFFER_WITH_SB(s));
1531		REISERFS_SB(s)->s_mount_state = REISERFS_VALID_FS;
1532	}
1533	/* this will force a full flush of all journal lists */
1534	SB_JOURNAL(s)->j_must_wait = 1;
1535	err = journal_end(&th);
1536	if (err)
1537		goto out_err_unlock;
 
1538
1539	reiserfs_write_unlock(s);
1540	if (!(*mount_flags & MS_RDONLY)) {
1541		dquot_resume(s, -1);
1542		reiserfs_write_lock(s);
1543		finish_unfinished(s);
1544		reiserfs_write_unlock(s);
1545		reiserfs_xattr_init(s, *mount_flags);
1546	}
1547
1548out_ok_unlocked:
1549	replace_mount_options(s, new_opts);
 
1550	return 0;
1551
1552out_err_unlock:
1553	reiserfs_write_unlock(s);
1554out_err:
1555	kfree(new_opts);
 
1556	return err;
1557}
1558
1559static int read_super_block(struct super_block *s, int offset)
1560{
1561	struct buffer_head *bh;
1562	struct reiserfs_super_block *rs;
1563	int fs_blocksize;
1564
1565	bh = sb_bread(s, offset / s->s_blocksize);
1566	if (!bh) {
1567		reiserfs_warning(s, "sh-2006",
1568				 "bread failed (dev %s, block %lu, size %lu)",
1569				 s->s_id, offset / s->s_blocksize,
1570				 s->s_blocksize);
1571		return 1;
1572	}
1573
1574	rs = (struct reiserfs_super_block *)bh->b_data;
1575	if (!is_any_reiserfs_magic_string(rs)) {
1576		brelse(bh);
1577		return 1;
1578	}
1579	/*
1580	 * ok, reiserfs signature (old or new) found in at the given offset
1581	 */
1582	fs_blocksize = sb_blocksize(rs);
1583	brelse(bh);
1584	sb_set_blocksize(s, fs_blocksize);
1585
1586	bh = sb_bread(s, offset / s->s_blocksize);
1587	if (!bh) {
1588		reiserfs_warning(s, "sh-2007",
1589				 "bread failed (dev %s, block %lu, size %lu)",
1590				 s->s_id, offset / s->s_blocksize,
1591				 s->s_blocksize);
1592		return 1;
1593	}
1594
1595	rs = (struct reiserfs_super_block *)bh->b_data;
1596	if (sb_blocksize(rs) != s->s_blocksize) {
1597		reiserfs_warning(s, "sh-2011", "can't find a reiserfs "
1598				 "filesystem on (dev %s, block %llu, size %lu)",
1599				 s->s_id,
1600				 (unsigned long long)bh->b_blocknr,
1601				 s->s_blocksize);
1602		brelse(bh);
1603		return 1;
1604	}
1605
1606	if (rs->s_v1.s_root_block == cpu_to_le32(-1)) {
1607		brelse(bh);
1608		reiserfs_warning(s, "super-6519", "Unfinished reiserfsck "
1609				 "--rebuild-tree run detected. Please run\n"
1610				 "reiserfsck --rebuild-tree and wait for a "
1611				 "completion. If that fails\n"
1612				 "get newer reiserfsprogs package");
1613		return 1;
1614	}
1615
1616	SB_BUFFER_WITH_SB(s) = bh;
1617	SB_DISK_SUPER_BLOCK(s) = rs;
1618
1619	/*
1620	 * magic is of non-standard journal filesystem, look at s_version to
1621	 * find which format is in use
1622	 */
1623	if (is_reiserfs_jr(rs)) {
 
 
1624		if (sb_version(rs) == REISERFS_VERSION_2)
1625			reiserfs_info(s, "found reiserfs format \"3.6\""
1626				      " with non-standard journal\n");
1627		else if (sb_version(rs) == REISERFS_VERSION_1)
1628			reiserfs_info(s, "found reiserfs format \"3.5\""
1629				      " with non-standard journal\n");
1630		else {
1631			reiserfs_warning(s, "sh-2012", "found unknown "
1632					 "format \"%u\" of reiserfs with "
1633					 "non-standard magic", sb_version(rs));
1634			return 1;
1635		}
1636	} else
1637		/*
1638		 * s_version of standard format may contain incorrect
1639		 * information, so we just look at the magic string
1640		 */
1641		reiserfs_info(s,
1642			      "found reiserfs format \"%s\" with standard journal\n",
1643			      is_reiserfs_3_5(rs) ? "3.5" : "3.6");
1644
1645	s->s_op = &reiserfs_sops;
1646	s->s_export_op = &reiserfs_export_ops;
1647#ifdef CONFIG_QUOTA
1648	s->s_qcop = &reiserfs_qctl_operations;
1649	s->dq_op = &reiserfs_quota_operations;
1650	s->s_quota_types = QTYPE_MASK_USR | QTYPE_MASK_GRP;
1651#endif
1652
1653	/*
1654	 * new format is limited by the 32 bit wide i_blocks field, want to
1655	 * be one full block below that.
1656	 */
1657	s->s_maxbytes = (512LL << 32) - s->s_blocksize;
1658	return 0;
1659}
1660
1661/* after journal replay, reread all bitmap and super blocks */
1662static int reread_meta_blocks(struct super_block *s)
1663{
1664	ll_rw_block(READ, 1, &SB_BUFFER_WITH_SB(s));
 
1665	wait_on_buffer(SB_BUFFER_WITH_SB(s));
 
1666	if (!buffer_uptodate(SB_BUFFER_WITH_SB(s))) {
1667		reiserfs_warning(s, "reiserfs-2504", "error reading the super");
1668		return 1;
1669	}
1670
1671	return 0;
1672}
1673
1674/* hash detection stuff */
 
1675
1676/*
1677 * if root directory is empty - we set default - Yura's - hash and
1678 * warn about it
1679 * FIXME: we look for only one name in a directory. If tea and yura
1680 * both have the same value - we ask user to send report to the
1681 * mailing list
1682 */
1683static __u32 find_hash_out(struct super_block *s)
1684{
1685	int retval;
1686	struct inode *inode;
1687	struct cpu_key key;
1688	INITIALIZE_PATH(path);
1689	struct reiserfs_dir_entry de;
1690	struct reiserfs_de_head *deh;
1691	__u32 hash = DEFAULT_HASH;
1692	__u32 deh_hashval, teahash, r5hash, yurahash;
1693
1694	inode = d_inode(s->s_root);
1695
1696	make_cpu_key(&key, inode, ~0, TYPE_DIRENTRY, 3);
1697	retval = search_by_entry_key(s, &key, &path, &de);
1698	if (retval == IO_ERROR) {
1699		pathrelse(&path);
1700		return UNSET_HASH;
1701	}
1702	if (retval == NAME_NOT_FOUND)
1703		de.de_entry_num--;
1704
1705	set_de_name_and_namelen(&de);
1706	deh = de.de_deh + de.de_entry_num;
1707
1708	if (deh_offset(deh) == DOT_DOT_OFFSET) {
1709		/* allow override in this case */
1710		if (reiserfs_rupasov_hash(s))
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1711			hash = YURA_HASH;
1712		reiserfs_info(s, "FS seems to be empty, autodetect is using the default hash\n");
1713		goto out;
1714	}
 
 
 
 
 
 
 
 
 
1715
1716	deh_hashval = GET_HASH_VALUE(deh_offset(deh));
1717	r5hash = GET_HASH_VALUE(r5_hash(de.de_name, de.de_namelen));
1718	teahash = GET_HASH_VALUE(keyed_hash(de.de_name, de.de_namelen));
1719	yurahash = GET_HASH_VALUE(yura_hash(de.de_name, de.de_namelen));
1720
1721	if ((teahash == r5hash && deh_hashval == r5hash) ||
1722	    (teahash == yurahash && deh_hashval == yurahash) ||
1723	    (r5hash == yurahash && deh_hashval == yurahash)) {
1724		reiserfs_warning(s, "reiserfs-2506",
1725				 "Unable to automatically detect hash "
1726				 "function. Please mount with -o "
1727				 "hash={tea,rupasov,r5}");
1728		hash = UNSET_HASH;
1729		goto out;
1730	}
1731
1732	if (deh_hashval == yurahash)
1733		hash = YURA_HASH;
1734	else if (deh_hashval == teahash)
1735		hash = TEA_HASH;
1736	else if (deh_hashval == r5hash)
1737		hash = R5_HASH;
1738	else {
1739		reiserfs_warning(s, "reiserfs-2506",
1740				 "Unrecognised hash function");
1741		hash = UNSET_HASH;
1742	}
1743out:
1744	pathrelse(&path);
1745	return hash;
1746}
1747
1748/* finds out which hash names are sorted with */
1749static int what_hash(struct super_block *s)
1750{
1751	__u32 code;
1752
1753	code = sb_hash_function_code(SB_DISK_SUPER_BLOCK(s));
1754
1755	/*
1756	 * reiserfs_hash_detect() == true if any of the hash mount options
1757	 * were used.  We must check them to make sure the user isn't
1758	 * using a bad hash value
1759	 */
1760	if (code == UNSET_HASH || reiserfs_hash_detect(s))
1761		code = find_hash_out(s);
1762
1763	if (code != UNSET_HASH && reiserfs_hash_detect(s)) {
1764		/*
1765		 * detection has found the hash, and we must check against the
1766		 * mount options
1767		 */
1768		if (reiserfs_rupasov_hash(s) && code != YURA_HASH) {
1769			reiserfs_warning(s, "reiserfs-2507",
1770					 "Error, %s hash detected, "
1771					 "unable to force rupasov hash",
1772					 reiserfs_hashname(code));
1773			code = UNSET_HASH;
1774		} else if (reiserfs_tea_hash(s) && code != TEA_HASH) {
1775			reiserfs_warning(s, "reiserfs-2508",
1776					 "Error, %s hash detected, "
1777					 "unable to force tea hash",
1778					 reiserfs_hashname(code));
1779			code = UNSET_HASH;
1780		} else if (reiserfs_r5_hash(s) && code != R5_HASH) {
1781			reiserfs_warning(s, "reiserfs-2509",
1782					 "Error, %s hash detected, "
1783					 "unable to force r5 hash",
1784					 reiserfs_hashname(code));
1785			code = UNSET_HASH;
1786		}
1787	} else {
1788		/*
1789		 * find_hash_out was not called or
1790		 * could not determine the hash
1791		 */
1792		if (reiserfs_rupasov_hash(s)) {
1793			code = YURA_HASH;
1794		} else if (reiserfs_tea_hash(s)) {
1795			code = TEA_HASH;
1796		} else if (reiserfs_r5_hash(s)) {
1797			code = R5_HASH;
1798		}
1799	}
1800
1801	/*
1802	 * if we are mounted RW, and we have a new valid hash code, update
1803	 * the super
1804	 */
1805	if (code != UNSET_HASH &&
1806	    !(s->s_flags & MS_RDONLY) &&
1807	    code != sb_hash_function_code(SB_DISK_SUPER_BLOCK(s))) {
1808		set_sb_hash_function_code(SB_DISK_SUPER_BLOCK(s), code);
1809	}
1810	return code;
1811}
1812
1813/* return pointer to appropriate function */
1814static hashf_t hash_function(struct super_block *s)
1815{
1816	switch (what_hash(s)) {
1817	case TEA_HASH:
1818		reiserfs_info(s, "Using tea hash to sort names\n");
1819		return keyed_hash;
1820	case YURA_HASH:
1821		reiserfs_info(s, "Using rupasov hash to sort names\n");
1822		return yura_hash;
1823	case R5_HASH:
1824		reiserfs_info(s, "Using r5 hash to sort names\n");
1825		return r5_hash;
1826	}
1827	return NULL;
1828}
1829
1830/* this is used to set up correct value for old partitions */
1831static int function2code(hashf_t func)
1832{
1833	if (func == keyed_hash)
1834		return TEA_HASH;
1835	if (func == yura_hash)
1836		return YURA_HASH;
1837	if (func == r5_hash)
1838		return R5_HASH;
1839
1840	BUG();			/* should never happen */
1841
1842	return 0;
1843}
1844
1845#define SWARN(silent, s, id, ...)			\
1846	if (!(silent))				\
1847		reiserfs_warning(s, id, __VA_ARGS__)
1848
1849static int reiserfs_fill_super(struct super_block *s, void *data, int silent)
1850{
1851	struct inode *root_inode;
1852	struct reiserfs_transaction_handle th;
1853	int old_format = 0;
1854	unsigned long blocks;
1855	unsigned int commit_max_age = 0;
1856	int jinit_done = 0;
1857	struct reiserfs_iget_args args;
1858	struct reiserfs_super_block *rs;
1859	char *jdev_name;
1860	struct reiserfs_sb_info *sbi;
1861	int errval = -EINVAL;
1862	char *qf_names[REISERFS_MAXQUOTAS] = {};
1863	unsigned int qfmt = 0;
1864
1865	save_mount_options(s, data);
1866
1867	sbi = kzalloc(sizeof(struct reiserfs_sb_info), GFP_KERNEL);
1868	if (!sbi)
1869		return -ENOMEM;
1870	s->s_fs_info = sbi;
1871	/* Set default values for options: non-aggressive tails, RO on errors */
1872	sbi->s_mount_opt |= (1 << REISERFS_SMALLTAIL);
1873	sbi->s_mount_opt |= (1 << REISERFS_ERROR_RO);
1874	sbi->s_mount_opt |= (1 << REISERFS_BARRIER_FLUSH);
1875	/* no preallocation minimum, be smart in reiserfs_file_write instead */
1876	sbi->s_alloc_options.preallocmin = 0;
 
1877	/* Preallocate by 16 blocks (17-1) at once */
1878	sbi->s_alloc_options.preallocsize = 17;
1879	/* setup default block allocator options */
1880	reiserfs_init_alloc_options(s);
1881
1882	spin_lock_init(&sbi->old_work_lock);
1883	INIT_DELAYED_WORK(&sbi->old_work, flush_old_commits);
1884	mutex_init(&sbi->lock);
1885	sbi->lock_depth = -1;
1886
1887	sbi->commit_wq = alloc_workqueue("reiserfs/%s", WQ_MEM_RECLAIM, 0,
1888					 s->s_id);
1889	if (!sbi->commit_wq) {
1890		SWARN(silent, s, "", "Cannot allocate commit workqueue");
1891		errval = -ENOMEM;
1892		goto error_unlocked;
1893	}
 
1894
1895	jdev_name = NULL;
1896	if (reiserfs_parse_options
1897	    (s, (char *)data, &sbi->s_mount_opt, &blocks, &jdev_name,
1898	     &commit_max_age, qf_names, &qfmt) == 0) {
1899		goto error_unlocked;
1900	}
1901	if (jdev_name && jdev_name[0]) {
1902		sbi->s_jdev = kstrdup(jdev_name, GFP_KERNEL);
1903		if (!sbi->s_jdev) {
1904			SWARN(silent, s, "", "Cannot allocate memory for "
1905				"journal device name");
1906			goto error;
1907		}
1908	}
1909#ifdef CONFIG_QUOTA
1910	handle_quota_files(s, qf_names, &qfmt);
1911#endif
1912
1913	if (blocks) {
1914		SWARN(silent, s, "jmacd-7", "resize option for remount only");
1915		goto error_unlocked;
1916	}
1917
1918	/*
1919	 * try old format (undistributed bitmap, super block in 8-th 1k
1920	 * block of a device)
1921	 */
1922	if (!read_super_block(s, REISERFS_OLD_DISK_OFFSET_IN_BYTES))
1923		old_format = 1;
1924
1925	/*
1926	 * try new format (64-th 1k block), which can contain reiserfs
1927	 * super block
1928	 */
1929	else if (read_super_block(s, REISERFS_DISK_OFFSET_IN_BYTES)) {
1930		SWARN(silent, s, "sh-2021", "can not find reiserfs on %s",
1931		      s->s_id);
1932		goto error_unlocked;
1933	}
1934
1935	rs = SB_DISK_SUPER_BLOCK(s);
1936	/*
1937	 * Let's do basic sanity check to verify that underlying device is not
1938	 * smaller than the filesystem. If the check fails then abort and
1939	 * scream, because bad stuff will happen otherwise.
1940	 */
1941	if (s->s_bdev && s->s_bdev->bd_inode
1942	    && i_size_read(s->s_bdev->bd_inode) <
1943	    sb_block_count(rs) * sb_blocksize(rs)) {
1944		SWARN(silent, s, "", "Filesystem cannot be "
1945		      "mounted because it is bigger than the device");
1946		SWARN(silent, s, "", "You may need to run fsck "
1947		      "or increase size of your LVM partition");
1948		SWARN(silent, s, "", "Or may be you forgot to "
1949		      "reboot after fdisk when it told you to");
1950		goto error_unlocked;
1951	}
1952
1953	sbi->s_mount_state = SB_REISERFS_STATE(s);
1954	sbi->s_mount_state = REISERFS_VALID_FS;
1955
1956	if ((errval = reiserfs_init_bitmap_cache(s))) {
1957		SWARN(silent, s, "jmacd-8", "unable to read bitmap");
1958		goto error_unlocked;
1959	}
1960
1961	errval = -EINVAL;
1962#ifdef CONFIG_REISERFS_CHECK
1963	SWARN(silent, s, "", "CONFIG_REISERFS_CHECK is set ON");
1964	SWARN(silent, s, "", "- it is slow mode for debugging.");
1965#endif
1966
1967	/* make data=ordered the default */
1968	if (!reiserfs_data_log(s) && !reiserfs_data_ordered(s) &&
1969	    !reiserfs_data_writeback(s)) {
1970		sbi->s_mount_opt |= (1 << REISERFS_DATA_ORDERED);
1971	}
1972
1973	if (reiserfs_data_log(s)) {
1974		reiserfs_info(s, "using journaled data mode\n");
1975	} else if (reiserfs_data_ordered(s)) {
1976		reiserfs_info(s, "using ordered data mode\n");
1977	} else {
1978		reiserfs_info(s, "using writeback data mode\n");
1979	}
1980	if (reiserfs_barrier_flush(s)) {
1981		printk("reiserfs: using flush barriers\n");
1982	}
1983
1984	if (journal_init(s, jdev_name, old_format, commit_max_age)) {
1985		SWARN(silent, s, "sh-2022",
1986		      "unable to initialize journal space");
1987		goto error_unlocked;
1988	} else {
1989		/*
1990		 * once this is set, journal_release must be called
1991		 * if we error out of the mount
1992		 */
1993		jinit_done = 1;
1994	}
1995
1996	if (reread_meta_blocks(s)) {
1997		SWARN(silent, s, "jmacd-9",
1998		      "unable to reread meta blocks after journal init");
1999		goto error_unlocked;
2000	}
2001
2002	if (replay_only(s))
2003		goto error_unlocked;
2004
2005	if (bdev_read_only(s->s_bdev) && !(s->s_flags & MS_RDONLY)) {
2006		SWARN(silent, s, "clm-7000",
2007		      "Detected readonly device, marking FS readonly");
2008		s->s_flags |= MS_RDONLY;
2009	}
2010	args.objectid = REISERFS_ROOT_OBJECTID;
2011	args.dirid = REISERFS_ROOT_PARENT_OBJECTID;
2012	root_inode =
2013	    iget5_locked(s, REISERFS_ROOT_OBJECTID, reiserfs_find_actor,
2014			 reiserfs_init_locked_inode, (void *)&args);
2015	if (!root_inode) {
2016		SWARN(silent, s, "jmacd-10", "get root inode failed");
2017		goto error_unlocked;
2018	}
2019
2020	/*
2021	 * This path assumed to be called with the BKL in the old times.
2022	 * Now we have inherited the big reiserfs lock from it and many
2023	 * reiserfs helpers called in the mount path and elsewhere require
2024	 * this lock to be held even if it's not always necessary. Let's be
2025	 * conservative and hold it early. The window can be reduced after
2026	 * careful review of the code.
2027	 */
2028	reiserfs_write_lock(s);
2029
2030	if (root_inode->i_state & I_NEW) {
2031		reiserfs_read_locked_inode(root_inode, &args);
2032		unlock_new_inode(root_inode);
2033	}
2034
2035	s->s_root = d_make_root(root_inode);
2036	if (!s->s_root)
 
2037		goto error;
2038	/* define and initialize hash function */
 
2039	sbi->s_hash_function = hash_function(s);
2040	if (sbi->s_hash_function == NULL) {
2041		dput(s->s_root);
2042		s->s_root = NULL;
2043		goto error;
2044	}
2045
2046	if (is_reiserfs_3_5(rs)
2047	    || (is_reiserfs_jr(rs) && SB_VERSION(s) == REISERFS_VERSION_1))
2048		set_bit(REISERFS_3_5, &sbi->s_properties);
2049	else if (old_format)
2050		set_bit(REISERFS_OLD_FORMAT, &sbi->s_properties);
2051	else
2052		set_bit(REISERFS_3_6, &sbi->s_properties);
2053
2054	if (!(s->s_flags & MS_RDONLY)) {
2055
2056		errval = journal_begin(&th, s, 1);
2057		if (errval) {
2058			dput(s->s_root);
2059			s->s_root = NULL;
2060			goto error;
2061		}
2062		reiserfs_prepare_for_journal(s, SB_BUFFER_WITH_SB(s), 1);
2063
2064		set_sb_umount_state(rs, REISERFS_ERROR_FS);
2065		set_sb_fs_state(rs, 0);
2066
2067		/*
2068		 * Clear out s_bmap_nr if it would wrap. We can handle this
2069		 * case, but older revisions can't. This will cause the
2070		 * file system to fail mount on those older implementations,
2071		 * avoiding corruption. -jeffm
2072		 */
2073		if (bmap_would_wrap(reiserfs_bmap_count(s)) &&
2074		    sb_bmap_nr(rs) != 0) {
2075			reiserfs_warning(s, "super-2030", "This file system "
2076					"claims to use %u bitmap blocks in "
2077					"its super block, but requires %u. "
2078					"Clearing to zero.", sb_bmap_nr(rs),
2079					reiserfs_bmap_count(s));
2080
2081			set_sb_bmap_nr(rs, 0);
2082		}
2083
2084		if (old_format_only(s)) {
2085			/*
2086			 * filesystem of format 3.5 either with standard
2087			 * or non-standard journal
2088			 */
2089			if (convert_reiserfs(s)) {
2090				/* and -o conv is given */
2091				if (!silent)
2092					reiserfs_info(s,
2093						      "converting 3.5 filesystem to the 3.6 format");
2094
2095				if (is_reiserfs_3_5(rs))
2096					/*
2097					 * put magic string of 3.6 format.
2098					 * 2.2 will not be able to
2099					 * mount this filesystem anymore
2100					 */
2101					memcpy(rs->s_v1.s_magic,
2102					       reiserfs_3_6_magic_string,
2103					       sizeof
2104					       (reiserfs_3_6_magic_string));
2105
2106				set_sb_version(rs, REISERFS_VERSION_2);
2107				reiserfs_convert_objectid_map_v1(s);
2108				set_bit(REISERFS_3_6, &sbi->s_properties);
2109				clear_bit(REISERFS_3_5, &sbi->s_properties);
2110			} else if (!silent) {
2111				reiserfs_info(s, "using 3.5.x disk format\n");
2112			}
2113		} else
2114			set_sb_mnt_count(rs, sb_mnt_count(rs) + 1);
2115
2116
2117		journal_mark_dirty(&th, SB_BUFFER_WITH_SB(s));
2118		errval = journal_end(&th);
2119		if (errval) {
2120			dput(s->s_root);
2121			s->s_root = NULL;
2122			goto error;
2123		}
2124
2125		reiserfs_write_unlock(s);
2126		if ((errval = reiserfs_lookup_privroot(s)) ||
2127		    (errval = reiserfs_xattr_init(s, s->s_flags))) {
2128			dput(s->s_root);
2129			s->s_root = NULL;
2130			goto error_unlocked;
2131		}
2132		reiserfs_write_lock(s);
2133
2134		/*
2135		 * look for files which were to be removed in previous session
2136		 */
2137		finish_unfinished(s);
2138	} else {
2139		if (old_format_only(s) && !silent) {
2140			reiserfs_info(s, "using 3.5.x disk format\n");
2141		}
2142
2143		reiserfs_write_unlock(s);
2144		if ((errval = reiserfs_lookup_privroot(s)) ||
2145		    (errval = reiserfs_xattr_init(s, s->s_flags))) {
2146			dput(s->s_root);
2147			s->s_root = NULL;
2148			goto error_unlocked;
2149		}
2150		reiserfs_write_lock(s);
2151	}
2152	/*
2153	 * mark hash in super block: it could be unset. overwrite should be ok
2154	 */
2155	set_sb_hash_function_code(rs, function2code(sbi->s_hash_function));
2156
2157	handle_attrs(s);
2158
2159	reiserfs_proc_info_init(s);
2160
2161	init_waitqueue_head(&(sbi->s_wait));
2162	spin_lock_init(&sbi->bitmap_lock);
2163
2164	reiserfs_write_unlock(s);
2165
2166	return (0);
2167
2168error:
2169	reiserfs_write_unlock(s);
2170
2171error_unlocked:
2172	/* kill the commit thread, free journal ram */
2173	if (jinit_done) {
2174		reiserfs_write_lock(s);
2175		journal_release_error(NULL, s);
2176		reiserfs_write_unlock(s);
2177	}
2178
2179	if (sbi->commit_wq)
2180		destroy_workqueue(sbi->commit_wq);
2181
2182	cancel_delayed_work_sync(&REISERFS_SB(s)->old_work);
2183
2184	reiserfs_free_bitmap_cache(s);
2185	if (SB_BUFFER_WITH_SB(s))
2186		brelse(SB_BUFFER_WITH_SB(s));
2187#ifdef CONFIG_QUOTA
2188	{
2189		int j;
2190		for (j = 0; j < REISERFS_MAXQUOTAS; j++)
2191			kfree(qf_names[j]);
2192	}
2193#endif
2194	kfree(sbi);
2195
2196	s->s_fs_info = NULL;
2197	return errval;
2198}
2199
2200static int reiserfs_statfs(struct dentry *dentry, struct kstatfs *buf)
2201{
2202	struct reiserfs_super_block *rs = SB_DISK_SUPER_BLOCK(dentry->d_sb);
2203
2204	buf->f_namelen = (REISERFS_MAX_NAME(s->s_blocksize));
2205	buf->f_bfree = sb_free_blocks(rs);
2206	buf->f_bavail = buf->f_bfree;
2207	buf->f_blocks = sb_block_count(rs) - sb_bmap_nr(rs) - 1;
2208	buf->f_bsize = dentry->d_sb->s_blocksize;
2209	/* changed to accommodate gcc folks. */
2210	buf->f_type = REISERFS_SUPER_MAGIC;
2211	buf->f_fsid.val[0] = (u32)crc32_le(0, rs->s_uuid, sizeof(rs->s_uuid)/2);
2212	buf->f_fsid.val[1] = (u32)crc32_le(0, rs->s_uuid + sizeof(rs->s_uuid)/2,
2213				sizeof(rs->s_uuid)/2);
2214
2215	return 0;
2216}
2217
2218#ifdef CONFIG_QUOTA
2219static int reiserfs_write_dquot(struct dquot *dquot)
2220{
2221	struct reiserfs_transaction_handle th;
2222	int ret, err;
2223	int depth;
2224
2225	reiserfs_write_lock(dquot->dq_sb);
2226	ret =
2227	    journal_begin(&th, dquot->dq_sb,
2228			  REISERFS_QUOTA_TRANS_BLOCKS(dquot->dq_sb));
2229	if (ret)
2230		goto out;
2231	depth = reiserfs_write_unlock_nested(dquot->dq_sb);
2232	ret = dquot_commit(dquot);
2233	reiserfs_write_lock_nested(dquot->dq_sb, depth);
2234	err = journal_end(&th);
 
2235	if (!ret && err)
2236		ret = err;
2237out:
2238	reiserfs_write_unlock(dquot->dq_sb);
2239	return ret;
2240}
2241
2242static int reiserfs_acquire_dquot(struct dquot *dquot)
2243{
2244	struct reiserfs_transaction_handle th;
2245	int ret, err;
2246	int depth;
2247
2248	reiserfs_write_lock(dquot->dq_sb);
2249	ret =
2250	    journal_begin(&th, dquot->dq_sb,
2251			  REISERFS_QUOTA_INIT_BLOCKS(dquot->dq_sb));
2252	if (ret)
2253		goto out;
2254	depth = reiserfs_write_unlock_nested(dquot->dq_sb);
2255	ret = dquot_acquire(dquot);
2256	reiserfs_write_lock_nested(dquot->dq_sb, depth);
2257	err = journal_end(&th);
 
2258	if (!ret && err)
2259		ret = err;
2260out:
2261	reiserfs_write_unlock(dquot->dq_sb);
2262	return ret;
2263}
2264
2265static int reiserfs_release_dquot(struct dquot *dquot)
2266{
2267	struct reiserfs_transaction_handle th;
2268	int ret, err;
2269
2270	reiserfs_write_lock(dquot->dq_sb);
2271	ret =
2272	    journal_begin(&th, dquot->dq_sb,
2273			  REISERFS_QUOTA_DEL_BLOCKS(dquot->dq_sb));
2274	reiserfs_write_unlock(dquot->dq_sb);
2275	if (ret) {
2276		/* Release dquot anyway to avoid endless cycle in dqput() */
2277		dquot_release(dquot);
2278		goto out;
2279	}
2280	ret = dquot_release(dquot);
2281	reiserfs_write_lock(dquot->dq_sb);
2282	err = journal_end(&th);
 
2283	if (!ret && err)
2284		ret = err;
 
2285	reiserfs_write_unlock(dquot->dq_sb);
2286out:
2287	return ret;
2288}
2289
2290static int reiserfs_mark_dquot_dirty(struct dquot *dquot)
2291{
2292	/* Are we journaling quotas? */
2293	if (REISERFS_SB(dquot->dq_sb)->s_qf_names[USRQUOTA] ||
2294	    REISERFS_SB(dquot->dq_sb)->s_qf_names[GRPQUOTA]) {
2295		dquot_mark_dquot_dirty(dquot);
2296		return reiserfs_write_dquot(dquot);
2297	} else
2298		return dquot_mark_dquot_dirty(dquot);
2299}
2300
2301static int reiserfs_write_info(struct super_block *sb, int type)
2302{
2303	struct reiserfs_transaction_handle th;
2304	int ret, err;
2305	int depth;
2306
2307	/* Data block + inode block */
2308	reiserfs_write_lock(sb);
2309	ret = journal_begin(&th, sb, 2);
2310	if (ret)
2311		goto out;
2312	depth = reiserfs_write_unlock_nested(sb);
2313	ret = dquot_commit_info(sb, type);
2314	reiserfs_write_lock_nested(sb, depth);
2315	err = journal_end(&th);
2316	if (!ret && err)
2317		ret = err;
2318out:
2319	reiserfs_write_unlock(sb);
2320	return ret;
2321}
2322
2323/*
2324 * Turn on quotas during mount time - we need to find the quota file and such...
2325 */
2326static int reiserfs_quota_on_mount(struct super_block *sb, int type)
2327{
2328	return dquot_quota_on_mount(sb, REISERFS_SB(sb)->s_qf_names[type],
2329					REISERFS_SB(sb)->s_jquota_fmt, type);
2330}
2331
2332/*
2333 * Standard function to be called on quota_on
2334 */
2335static int reiserfs_quota_on(struct super_block *sb, int type, int format_id,
2336			     struct path *path)
2337{
2338	int err;
2339	struct inode *inode;
2340	struct reiserfs_transaction_handle th;
2341	int opt = type == USRQUOTA ? REISERFS_USRQUOTA : REISERFS_GRPQUOTA;
2342
2343	reiserfs_write_lock(sb);
2344	if (!(REISERFS_SB(sb)->s_mount_opt & (1 << opt))) {
2345		err = -EINVAL;
2346		goto out;
2347	}
2348
2349	/* Quotafile not on the same filesystem? */
2350	if (path->dentry->d_sb != sb) {
2351		err = -EXDEV;
2352		goto out;
2353	}
2354	inode = d_inode(path->dentry);
2355	/*
2356	 * We must not pack tails for quota files on reiserfs for quota
2357	 * IO to work
2358	 */
2359	if (!(REISERFS_I(inode)->i_flags & i_nopack_mask)) {
2360		err = reiserfs_unpack(inode, NULL);
2361		if (err) {
2362			reiserfs_warning(sb, "super-6520",
2363				"Unpacking tail of quota file failed"
2364				" (%d). Cannot turn on quotas.", err);
2365			err = -EINVAL;
2366			goto out;
2367		}
2368		mark_inode_dirty(inode);
2369	}
2370	/* Journaling quota? */
2371	if (REISERFS_SB(sb)->s_qf_names[type]) {
2372		/* Quotafile not of fs root? */
2373		if (path->dentry->d_parent != sb->s_root)
2374			reiserfs_warning(sb, "super-6521",
2375				 "Quota file not on filesystem root. "
2376				 "Journalled quota will not work.");
2377	}
2378
2379	/*
2380	 * When we journal data on quota file, we have to flush journal to see
2381	 * all updates to the file when we bypass pagecache...
2382	 */
2383	if (reiserfs_file_data_log(inode)) {
2384		/* Just start temporary transaction and finish it */
2385		err = journal_begin(&th, sb, 1);
2386		if (err)
2387			goto out;
2388		err = journal_end_sync(&th);
2389		if (err)
2390			goto out;
2391	}
2392	reiserfs_write_unlock(sb);
2393	return dquot_quota_on(sb, type, format_id, path);
2394out:
2395	reiserfs_write_unlock(sb);
2396	return err;
2397}
2398
2399/*
2400 * Read data from quotafile - avoid pagecache and such because we cannot afford
2401 * acquiring the locks... As quota files are never truncated and quota code
2402 * itself serializes the operations (and no one else should touch the files)
2403 * we don't have to be afraid of races
2404 */
2405static ssize_t reiserfs_quota_read(struct super_block *sb, int type, char *data,
2406				   size_t len, loff_t off)
2407{
2408	struct inode *inode = sb_dqopt(sb)->files[type];
2409	unsigned long blk = off >> sb->s_blocksize_bits;
2410	int err = 0, offset = off & (sb->s_blocksize - 1), tocopy;
2411	size_t toread;
2412	struct buffer_head tmp_bh, *bh;
2413	loff_t i_size = i_size_read(inode);
2414
2415	if (off > i_size)
2416		return 0;
2417	if (off + len > i_size)
2418		len = i_size - off;
2419	toread = len;
2420	while (toread > 0) {
2421		tocopy =
2422		    sb->s_blocksize - offset <
2423		    toread ? sb->s_blocksize - offset : toread;
2424		tmp_bh.b_state = 0;
2425		/*
2426		 * Quota files are without tails so we can safely
2427		 * use this function
2428		 */
2429		reiserfs_write_lock(sb);
2430		err = reiserfs_get_block(inode, blk, &tmp_bh, 0);
2431		reiserfs_write_unlock(sb);
2432		if (err)
2433			return err;
2434		if (!buffer_mapped(&tmp_bh))	/* A hole? */
2435			memset(data, 0, tocopy);
2436		else {
2437			bh = sb_bread(sb, tmp_bh.b_blocknr);
2438			if (!bh)
2439				return -EIO;
2440			memcpy(data, bh->b_data + offset, tocopy);
2441			brelse(bh);
2442		}
2443		offset = 0;
2444		toread -= tocopy;
2445		data += tocopy;
2446		blk++;
2447	}
2448	return len;
2449}
2450
2451/*
2452 * Write to quotafile (we know the transaction is already started and has
2453 * enough credits)
2454 */
2455static ssize_t reiserfs_quota_write(struct super_block *sb, int type,
2456				    const char *data, size_t len, loff_t off)
2457{
2458	struct inode *inode = sb_dqopt(sb)->files[type];
2459	unsigned long blk = off >> sb->s_blocksize_bits;
2460	int err = 0, offset = off & (sb->s_blocksize - 1), tocopy;
2461	int journal_quota = REISERFS_SB(sb)->s_qf_names[type] != NULL;
2462	size_t towrite = len;
2463	struct buffer_head tmp_bh, *bh;
2464
2465	if (!current->journal_info) {
2466		printk(KERN_WARNING "reiserfs: Quota write (off=%llu, len=%llu) cancelled because transaction is not started.\n",
 
2467			(unsigned long long)off, (unsigned long long)len);
2468		return -EIO;
2469	}
 
2470	while (towrite > 0) {
2471		tocopy = sb->s_blocksize - offset < towrite ?
2472		    sb->s_blocksize - offset : towrite;
2473		tmp_bh.b_state = 0;
2474		reiserfs_write_lock(sb);
2475		err = reiserfs_get_block(inode, blk, &tmp_bh, GET_BLOCK_CREATE);
2476		reiserfs_write_unlock(sb);
2477		if (err)
2478			goto out;
2479		if (offset || tocopy != sb->s_blocksize)
2480			bh = sb_bread(sb, tmp_bh.b_blocknr);
2481		else
2482			bh = sb_getblk(sb, tmp_bh.b_blocknr);
2483		if (!bh) {
2484			err = -EIO;
2485			goto out;
2486		}
2487		lock_buffer(bh);
2488		memcpy(bh->b_data + offset, data, tocopy);
2489		flush_dcache_page(bh->b_page);
2490		set_buffer_uptodate(bh);
2491		unlock_buffer(bh);
2492		reiserfs_write_lock(sb);
2493		reiserfs_prepare_for_journal(sb, bh, 1);
2494		journal_mark_dirty(current->journal_info, bh);
2495		if (!journal_quota)
2496			reiserfs_add_ordered_list(inode, bh);
2497		reiserfs_write_unlock(sb);
2498		brelse(bh);
2499		offset = 0;
2500		towrite -= tocopy;
2501		data += tocopy;
2502		blk++;
2503	}
2504out:
2505	if (len == towrite)
 
2506		return err;
 
2507	if (inode->i_size < off + len - towrite)
2508		i_size_write(inode, off + len - towrite);
2509	inode->i_version++;
2510	inode->i_mtime = inode->i_ctime = CURRENT_TIME;
2511	mark_inode_dirty(inode);
 
2512	return len - towrite;
2513}
2514
2515#endif
2516
2517static struct dentry *get_super_block(struct file_system_type *fs_type,
2518			   int flags, const char *dev_name,
2519			   void *data)
2520{
2521	return mount_bdev(fs_type, flags, dev_name, data, reiserfs_fill_super);
2522}
2523
2524static int __init init_reiserfs_fs(void)
2525{
2526	int ret;
2527
2528	ret = init_inodecache();
2529	if (ret)
2530		return ret;
 
2531
2532	reiserfs_proc_info_global_init();
2533
2534	ret = register_filesystem(&reiserfs_fs_type);
2535	if (ret)
2536		goto out;
2537
2538	return 0;
2539out:
 
 
2540	reiserfs_proc_info_global_done();
2541	destroy_inodecache();
2542
2543	return ret;
2544}
2545
2546static void __exit exit_reiserfs_fs(void)
2547{
2548	reiserfs_proc_info_global_done();
2549	unregister_filesystem(&reiserfs_fs_type);
2550	destroy_inodecache();
2551}
2552
2553struct file_system_type reiserfs_fs_type = {
2554	.owner = THIS_MODULE,
2555	.name = "reiserfs",
2556	.mount = get_super_block,
2557	.kill_sb = reiserfs_kill_sb,
2558	.fs_flags = FS_REQUIRES_DEV,
2559};
2560MODULE_ALIAS_FS("reiserfs");
2561
2562MODULE_DESCRIPTION("ReiserFS journaled filesystem");
2563MODULE_AUTHOR("Hans Reiser <reiser@namesys.com>");
2564MODULE_LICENSE("GPL");
2565
2566module_init(init_reiserfs_fs);
2567module_exit(exit_reiserfs_fs);