Blame view

fs/bad_inode.c 5.26 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
11
  /*
   *  linux/fs/bad_inode.c
   *
   *  Copyright (C) 1997, Stephen Tweedie
   *
   *  Provide stub functions for unreadable inodes
   *
   *  Fabian Frederick : August 2003 - All file operations assigned to EIO
   */
  
  #include <linux/fs.h>
630d9c472   Paul Gortmaker   fs: reduce the us...
12
  #include <linux/export.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
13
14
  #include <linux/stat.h>
  #include <linux/time.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
15
  #include <linux/namei.h>
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
16
  #include <linux/poll.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
17

be6aab0e9   Eric Sandeen   [PATCH] fix memor...
18
19
20
21
  static int bad_file_open(struct inode *inode, struct file *filp)
  {
  	return -EIO;
  }
4b6f5d20b   Arjan van de Ven   [PATCH] Make most...
22
  static const struct file_operations bad_file_ops =
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
23
  {
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
24
  	.open		= bad_file_open,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
25
  };
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
26
  static int bad_inode_create (struct inode *dir, struct dentry *dentry,
ebfc3b49a   Al Viro   don't pass nameid...
27
  		umode_t mode, bool excl)
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
28
29
30
31
32
  {
  	return -EIO;
  }
  
  static struct dentry *bad_inode_lookup(struct inode *dir,
00cd8dd3b   Al Viro   stop passing name...
33
  			struct dentry *dentry, unsigned int flags)
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
  {
  	return ERR_PTR(-EIO);
  }
  
  static int bad_inode_link (struct dentry *old_dentry, struct inode *dir,
  		struct dentry *dentry)
  {
  	return -EIO;
  }
  
  static int bad_inode_unlink(struct inode *dir, struct dentry *dentry)
  {
  	return -EIO;
  }
  
  static int bad_inode_symlink (struct inode *dir, struct dentry *dentry,
  		const char *symname)
  {
  	return -EIO;
  }
  
  static int bad_inode_mkdir(struct inode *dir, struct dentry *dentry,
18bb1db3e   Al Viro   switch vfs_mkdir(...
56
  			umode_t mode)
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
57
58
59
60
61
62
63
64
65
66
  {
  	return -EIO;
  }
  
  static int bad_inode_rmdir (struct inode *dir, struct dentry *dentry)
  {
  	return -EIO;
  }
  
  static int bad_inode_mknod (struct inode *dir, struct dentry *dentry,
1a67aafb5   Al Viro   switch ->mknod() ...
67
  			umode_t mode, dev_t rdev)
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
68
69
70
  {
  	return -EIO;
  }
a0dbc5661   Miklos Szeredi   bad_inode: add ->...
71
72
73
  static int bad_inode_rename2(struct inode *old_dir, struct dentry *old_dentry,
  			     struct inode *new_dir, struct dentry *new_dentry,
  			     unsigned int flags)
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
74
75
76
77
78
79
80
81
82
  {
  	return -EIO;
  }
  
  static int bad_inode_readlink(struct dentry *dentry, char __user *buffer,
  		int buflen)
  {
  	return -EIO;
  }
10556cb21   Al Viro   ->permission() sa...
83
  static int bad_inode_permission(struct inode *inode, int mask)
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
84
85
86
87
88
89
90
91
92
93
94
95
96
97
  {
  	return -EIO;
  }
  
  static int bad_inode_getattr(struct vfsmount *mnt, struct dentry *dentry,
  			struct kstat *stat)
  {
  	return -EIO;
  }
  
  static int bad_inode_setattr(struct dentry *direntry, struct iattr *attrs)
  {
  	return -EIO;
  }
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
98
99
100
101
102
  static ssize_t bad_inode_listxattr(struct dentry *dentry, char *buffer,
  			size_t buffer_size)
  {
  	return -EIO;
  }
6195cd1a9   Miklos Szeredi   bad_inode: add mi...
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
  static const char *bad_inode_get_link(struct dentry *dentry,
  				      struct inode *inode,
  				      struct delayed_call *done)
  {
  	return ERR_PTR(-EIO);
  }
  
  static struct posix_acl *bad_inode_get_acl(struct inode *inode, int type)
  {
  	return ERR_PTR(-EIO);
  }
  
  static int bad_inode_fiemap(struct inode *inode,
  			    struct fiemap_extent_info *fieinfo, u64 start,
  			    u64 len)
  {
  	return -EIO;
  }
  
  static int bad_inode_update_time(struct inode *inode, struct timespec *time,
  				 int flags)
  {
  	return -EIO;
  }
  
  static int bad_inode_atomic_open(struct inode *inode, struct dentry *dentry,
  				 struct file *file, unsigned int open_flag,
  				 umode_t create_mode, int *opened)
  {
  	return -EIO;
  }
  
  static int bad_inode_tmpfile(struct inode *inode, struct dentry *dentry,
  			     umode_t mode)
  {
  	return -EIO;
  }
  
  static int bad_inode_set_acl(struct inode *inode, struct posix_acl *acl,
  			     int type)
  {
  	return -EIO;
  }
754661f14   Arjan van de Ven   [PATCH] mark stru...
146
  static const struct inode_operations bad_inode_ops =
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
147
  {
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
148
149
150
151
152
153
154
155
  	.create		= bad_inode_create,
  	.lookup		= bad_inode_lookup,
  	.link		= bad_inode_link,
  	.unlink		= bad_inode_unlink,
  	.symlink	= bad_inode_symlink,
  	.mkdir		= bad_inode_mkdir,
  	.rmdir		= bad_inode_rmdir,
  	.mknod		= bad_inode_mknod,
2773bf00a   Miklos Szeredi   fs: rename "renam...
156
  	.rename		= bad_inode_rename2,
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
157
  	.readlink	= bad_inode_readlink,
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
158
159
160
  	.permission	= bad_inode_permission,
  	.getattr	= bad_inode_getattr,
  	.setattr	= bad_inode_setattr,
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
161
  	.listxattr	= bad_inode_listxattr,
6195cd1a9   Miklos Szeredi   bad_inode: add mi...
162
163
164
165
166
167
168
  	.get_link	= bad_inode_get_link,
  	.get_acl	= bad_inode_get_acl,
  	.fiemap		= bad_inode_fiemap,
  	.update_time	= bad_inode_update_time,
  	.atomic_open	= bad_inode_atomic_open,
  	.tmpfile	= bad_inode_tmpfile,
  	.set_acl	= bad_inode_set_acl,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
  };
  
  
  /*
   * When a filesystem is unable to read an inode due to an I/O error in
   * its read_inode() function, it can call make_bad_inode() to return a
   * set of stubs which will return EIO errors as required. 
   *
   * We only need to do limited initialisation: all other fields are
   * preinitialised to zero automatically.
   */
   
  /**
   *	make_bad_inode - mark an inode bad due to an I/O error
   *	@inode: Inode to mark bad
   *
   *	When an inode cannot be read due to a media or remote network
   *	failure this function makes the inode "bad" and causes I/O operations
   *	on it to fail from this point on.
   */
   
be6aab0e9   Eric Sandeen   [PATCH] fix memor...
190
  void make_bad_inode(struct inode *inode)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
191
192
193
194
195
  {
  	remove_inode_hash(inode);
  
  	inode->i_mode = S_IFREG;
  	inode->i_atime = inode->i_mtime = inode->i_ctime =
c2050a454   Deepa Dinamani   fs: Replace curre...
196
  		current_time(inode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
197
  	inode->i_op = &bad_inode_ops;	
5f6e59ae8   Andreas Gruenbacher   vfs: Use IOP_XATT...
198
  	inode->i_opflags &= ~IOP_XATTR;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
  	inode->i_fop = &bad_file_ops;	
  }
  EXPORT_SYMBOL(make_bad_inode);
  
  /*
   * This tests whether an inode has been flagged as bad. The test uses
   * &bad_inode_ops to cover the case of invalidated inodes as well as
   * those created by make_bad_inode() above.
   */
   
  /**
   *	is_bad_inode - is an inode errored
   *	@inode: inode to test
   *
   *	Returns true if the inode in question has been marked as bad.
   */
   
0e3ef1fe4   Yaowei Bai   fs/bad_inode.c: i...
216
  bool is_bad_inode(struct inode *inode)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
217
218
219
220
221
  {
  	return (inode->i_op == &bad_inode_ops);	
  }
  
  EXPORT_SYMBOL(is_bad_inode);
b46980fee   David Howells   iget: introduce a...
222
223
224
225
226
227
228
229
230
231
232
233
234
235
  
  /**
   * iget_failed - Mark an under-construction inode as dead and release it
   * @inode: The inode to discard
   *
   * Mark an under-construction inode as dead and release it.
   */
  void iget_failed(struct inode *inode)
  {
  	make_bad_inode(inode);
  	unlock_new_inode(inode);
  	iput(inode);
  }
  EXPORT_SYMBOL(iget_failed);