diff options
Diffstat (limited to 'fs/locks.c')
-rw-r--r-- | fs/locks.c | 21 |
1 files changed, 9 insertions, 12 deletions
diff --git a/fs/locks.c b/fs/locks.c index 3c23fd261022..838ca542c556 100644 --- a/fs/locks.c +++ b/fs/locks.c | |||
@@ -458,22 +458,20 @@ static int lease_init(struct file *filp, int type, struct file_lock *fl) | |||
458 | } | 458 | } |
459 | 459 | ||
460 | /* Allocate a file_lock initialised to this type of lease */ | 460 | /* Allocate a file_lock initialised to this type of lease */ |
461 | static int lease_alloc(struct file *filp, int type, struct file_lock **flp) | 461 | static struct file_lock *lease_alloc(struct file *filp, int type) |
462 | { | 462 | { |
463 | struct file_lock *fl = locks_alloc_lock(); | 463 | struct file_lock *fl = locks_alloc_lock(); |
464 | int error = -ENOMEM; | 464 | int error = -ENOMEM; |
465 | 465 | ||
466 | if (fl == NULL) | 466 | if (fl == NULL) |
467 | goto out; | 467 | return ERR_PTR(error); |
468 | 468 | ||
469 | error = lease_init(filp, type, fl); | 469 | error = lease_init(filp, type, fl); |
470 | if (error) { | 470 | if (error) { |
471 | locks_free_lock(fl); | 471 | locks_free_lock(fl); |
472 | fl = NULL; | 472 | return ERR_PTR(error); |
473 | } | 473 | } |
474 | out: | 474 | return fl; |
475 | *flp = fl; | ||
476 | return error; | ||
477 | } | 475 | } |
478 | 476 | ||
479 | /* Check if two locks overlap each other. | 477 | /* Check if two locks overlap each other. |
@@ -1179,12 +1177,10 @@ int __break_lease(struct inode *inode, unsigned int mode) | |||
1179 | int error = 0, future; | 1177 | int error = 0, future; |
1180 | struct file_lock *new_fl, *flock; | 1178 | struct file_lock *new_fl, *flock; |
1181 | struct file_lock *fl; | 1179 | struct file_lock *fl; |
1182 | int alloc_err; | ||
1183 | unsigned long break_time; | 1180 | unsigned long break_time; |
1184 | int i_have_this_lease = 0; | 1181 | int i_have_this_lease = 0; |
1185 | 1182 | ||
1186 | alloc_err = lease_alloc(NULL, mode & FMODE_WRITE ? F_WRLCK : F_RDLCK, | 1183 | new_fl = lease_alloc(NULL, mode & FMODE_WRITE ? F_WRLCK : F_RDLCK); |
1187 | &new_fl); | ||
1188 | 1184 | ||
1189 | lock_kernel(); | 1185 | lock_kernel(); |
1190 | 1186 | ||
@@ -1212,8 +1208,9 @@ int __break_lease(struct inode *inode, unsigned int mode) | |||
1212 | goto out; | 1208 | goto out; |
1213 | } | 1209 | } |
1214 | 1210 | ||
1215 | if (alloc_err && !i_have_this_lease && ((mode & O_NONBLOCK) == 0)) { | 1211 | if (IS_ERR(new_fl) && !i_have_this_lease |
1216 | error = alloc_err; | 1212 | && ((mode & O_NONBLOCK) == 0)) { |
1213 | error = PTR_ERR(new_fl); | ||
1217 | goto out; | 1214 | goto out; |
1218 | } | 1215 | } |
1219 | 1216 | ||
@@ -1260,7 +1257,7 @@ restart: | |||
1260 | 1257 | ||
1261 | out: | 1258 | out: |
1262 | unlock_kernel(); | 1259 | unlock_kernel(); |
1263 | if (!alloc_err) | 1260 | if (!IS_ERR(new_fl)) |
1264 | locks_free_lock(new_fl); | 1261 | locks_free_lock(new_fl); |
1265 | return error; | 1262 | return error; |
1266 | } | 1263 | } |