Blame view

fs/ntfs/usnjrnl.c 2.68 KB
3f2faef00   Anton Altaparmakov   NTFS: Stamp the t...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
  /*
   * usnjrnl.h - NTFS kernel transaction log ($UsnJrnl) handling.  Part of the
   *	       Linux-NTFS project.
   *
   * Copyright (c) 2005 Anton Altaparmakov
   *
   * This program/include file is free software; you can redistribute it and/or
   * modify it under the terms of the GNU General Public License as published
   * by the Free Software Foundation; either version 2 of the License, or
   * (at your option) any later version.
   *
   * This program/include file is distributed in the hope that it will be
   * useful, but WITHOUT ANY WARRANTY; without even the implied warranty
   * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   * GNU General Public License for more details.
   *
   * You should have received a copy of the GNU General Public License
   * along with this program (in the main directory of the Linux-NTFS
   * distribution in the file COPYING); if not, write to the Free Software
   * Foundation,Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
   */
  
  #ifdef NTFS_RW
  
  #include <linux/fs.h>
  #include <linux/highmem.h>
  #include <linux/mm.h>
  
  #include "aops.h"
  #include "debug.h"
  #include "endian.h"
  #include "time.h"
  #include "types.h"
  #include "usnjrnl.h"
  #include "volume.h"
  
  /**
   * ntfs_stamp_usnjrnl - stamp the transaction log ($UsnJrnl) on an ntfs volume
   * @vol:	ntfs volume on which to stamp the transaction log
   *
   * Stamp the transaction log ($UsnJrnl) on the ntfs volume @vol and return
c49c31115   Richard Knutsson   [PATCH] fs/ntfs: ...
42
   * 'true' on success and 'false' on error.
3f2faef00   Anton Altaparmakov   NTFS: Stamp the t...
43
44
45
46
   *
   * This function assumes that the transaction log has already been loaded and
   * consistency checked by a call to fs/ntfs/super.c::load_and_init_usnjrnl().
   */
c49c31115   Richard Knutsson   [PATCH] fs/ntfs: ...
47
  bool ntfs_stamp_usnjrnl(ntfs_volume *vol)
3f2faef00   Anton Altaparmakov   NTFS: Stamp the t...
48
49
50
51
52
53
54
55
56
57
58
  {
  	ntfs_debug("Entering.");
  	if (likely(!NVolUsnJrnlStamped(vol))) {
  		sle64 stamp;
  		struct page *page;
  		USN_HEADER *uh;
  
  		page = ntfs_map_page(vol->usnjrnl_max_ino->i_mapping, 0);
  		if (IS_ERR(page)) {
  			ntfs_error(vol->sb, "Failed to read from "
  					"$UsnJrnl/$DATA/$Max attribute.");
c49c31115   Richard Knutsson   [PATCH] fs/ntfs: ...
59
  			return false;
3f2faef00   Anton Altaparmakov   NTFS: Stamp the t...
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
  		}
  		uh = (USN_HEADER*)page_address(page);
  		stamp = get_current_ntfs_time();
  		ntfs_debug("Stamping transaction log ($UsnJrnl): old "
  				"journal_id 0x%llx, old lowest_valid_usn "
  				"0x%llx, new journal_id 0x%llx, new "
  				"lowest_valid_usn 0x%llx.",
  				(long long)sle64_to_cpu(uh->journal_id),
  				(long long)sle64_to_cpu(uh->lowest_valid_usn),
  				(long long)sle64_to_cpu(stamp),
  				i_size_read(vol->usnjrnl_j_ino));
  		uh->lowest_valid_usn =
  				cpu_to_sle64(i_size_read(vol->usnjrnl_j_ino));
  		uh->journal_id = stamp;
  		flush_dcache_page(page);
  		set_page_dirty(page);
  		ntfs_unmap_page(page);
  		/* Set the flag so we do not have to do it again on remount. */
  		NVolSetUsnJrnlStamped(vol);
  	}
  	ntfs_debug("Done.");
c49c31115   Richard Knutsson   [PATCH] fs/ntfs: ...
81
  	return true;
3f2faef00   Anton Altaparmakov   NTFS: Stamp the t...
82
83
84
  }
  
  #endif /* NTFS_RW */