summaryrefslogtreecommitdiff
path: root/target/linux/generic/patches-2.6.37/218-mini_fo_dentry_check.patch
blob: cf53e4826f9a32a5a9fc053524310ca5c6b6e546 (plain)
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
42
43
44
45
46
47
48
--- a/fs/mini_fo/meta.c
+++ b/fs/mini_fo/meta.c
@@ -48,6 +48,9 @@ int meta_build_lists(dentry_t *dentry)
 					     dtohd2(dentry),
 					     strlen(META_FILENAME));
 		mutex_unlock(&dtohd2(dentry)->d_inode->i_mutex);
+		if (IS_ERR(meta_dentry))
+			goto out_ok;
+
 		if(!meta_dentry->d_inode) {
 			dput(meta_dentry);
 			goto out_ok;
@@ -433,6 +436,8 @@ int meta_write_d_entry(dentry_t *dentry,
 	meta_dentry = lookup_one_len(META_FILENAME,
 				     dtohd2(dentry), strlen (META_FILENAME));
 	mutex_unlock(&dtohd2(dentry)->d_inode->i_mutex);
+	if (IS_ERR(meta_dentry))
+		return PTR_ERR(meta_dentry);
 
 	/* We need to create a META-file */
         if(!meta_dentry->d_inode) {
@@ -538,6 +543,8 @@ int meta_write_r_entry(dentry_t *dentry,
 				     dtohd2(dentry),
 				     strlen (META_FILENAME));
 	mutex_unlock(&dtohd2(dentry)->d_inode->i_mutex);
+	if (IS_ERR(meta_dentry))
+		return PTR_ERR(meta_dentry);
 
         if(!meta_dentry->d_inode) {
                 /* We need to create a META-file */
@@ -656,6 +663,8 @@ int meta_sync_d_list(dentry_t *dentry, i
 				     dtohd2(dentry),
 				     strlen(META_FILENAME));
 	mutex_unlock(&dtohd2(dentry)->d_inode->i_mutex);
+	if (IS_ERR(meta_dentry))
+		return PTR_ERR(meta_dentry);
 
         if(!meta_dentry->d_inode) {
                 /* We need to create a META-file */
@@ -803,6 +812,8 @@ int meta_sync_r_list(dentry_t *dentry, i
 				     dtohd2(dentry),
 				     strlen(META_FILENAME));
 	mutex_unlock(&dtohd2(dentry)->d_inode->i_mutex);
+	if (IS_ERR(meta_dentry))
+		return PTR_ERR(meta_dentry);
 
         if(!meta_dentry->d_inode) {
                 /* We need to create a META-file */